Rev 4330 | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
20 | reyssat | 1 | !if $wims_read_parm!=slib_header |
13586 | bpr | 2 | !goto proc |
20 | reyssat | 3 | !endif |
4161 | bpr | 4 | |
20 | reyssat | 5 | slib_parms=4\ |
6 | ,[data]\ |
||
7 | ,N\ |
||
8 | ,K\ |
||
9 | ,n |
||
10 | slib_example=[2,4,7],12,4,3 |
||
4330 | bpr | 11 | slib_author=Sophie, Lemaire; Bernadette, Perrin-Riou |
4161 | bpr | 12 | |
3265 | bpr | 13 | slib_require=pari |
20 | reyssat | 14 | !exit |
15 | |||
16 | :proc |
||
17 | |||
4330 | bpr | 18 | !distribute item $wims_read_parm into slib_data,slib_N,slib_K,slib_n |
20 | reyssat | 19 | |
20 | slib_b= $[binomial($slib_N,$slib_n)^(-1)] |
||
21 | |||
22 | slib_min= $[max(0,$slib_n+$slib_K-$slib_N)] |
||
23 | slib_max= $[min($slib_n,$slib_N)] |
||
24 | !if $slib_max<$slib_min |
||
25 | slib_out=0 |
||
26 | !exit |
||
27 | !endif |
||
28 | |||
29 | slib_data=!declosing $slib_data |
||
30 | slib_data1=!values rint(x) for x in $slib_data |
||
31 | slib_cnt=!itemcnt $slib_data |
||
32 | 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) |
||
33 | |||
34 | slib_out=!trim $slib_out |
||
35 | |||
36 | !for slib_i=1 to $slib_cnt |
||
37 | slib_tmp=!item $slib_i of $slib_data |
||
38 | !if $[rint($slib_tmp)-$slib_tmp]<>0 or $slib_tmp < 0 |
||
39 | slib_out=!replace internal item number $slib_i by 0 in $slib_out |
||
40 | !endif |
||
41 | !next slib_i |
||
42 | |||
43 | slib_out=!trim $slib_out |