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 |