Subversion Repositories wimsdev

Rev

Rev 20 | Rev 4161 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
20 reyssat 1
!if $wims_read_parm!=slib_header
2
!goto proc
3
!endif
4
slib_title=Probability density function of Hypergeometric law 
5
slib_parms=4\
6
,[data]\
7
,N\
8
,K\
9
,n
10
slib_example=[2,4,7],12,4,3
11
slib_author=Bernadette PERRIN-RIOU
12
slib_out=Values of probability density function of Hypergeometric
13
slib_comment=data can be a list of reals
14
P(X=i)=binomial(K,i)*binomial(N-K,n-i)/binomial(N,n)
3265 bpr 15
slib_require=pari
20 reyssat 16
!exit
17
 
18
:proc
19
 
20
!distribute  item $wims_read_parm into slib_data,slib_N,slib_K,slib_n
21
 
22
slib_b= $[binomial($slib_N,$slib_n)^(-1)]
23
 
24
slib_min= $[max(0,$slib_n+$slib_K-$slib_N)]
25
slib_max= $[min($slib_n,$slib_N)]
26
!if $slib_max<$slib_min
27
	slib_out=0
28
	!exit
29
!endif
30
 
31
slib_data=!declosing $slib_data
32
slib_data1=!values rint(x)  for x in $slib_data
33
slib_cnt=!itemcnt $slib_data
34
slib_out= !exec pari slib_data=[$slib_data1]; vector($slib_cnt,x,1.*binomial($slib_K,slib_data[x])*binomial($slib_N-$slib_K,$slib_n-slib_data[x])*$slib_b)
35
 
36
slib_out=!trim $slib_out
37
 
38
!for slib_i=1 to $slib_cnt
39
	slib_tmp=!item $slib_i of $slib_data
40
	!if $[rint($slib_tmp)-$slib_tmp]<>0 or $slib_tmp < 0
41
		slib_out=!replace internal item number $slib_i by 0 in $slib_out
42
	!endif
43
!next slib_i
44
 
45
slib_out=!trim $slib_out
46