Rev 13586 | 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=3\ |
6 | ,[data]\ |
||
7 | 5,n\ |
||
8 | 0.5,p |
||
9 | |||
4330 | bpr | 10 | slib_author=Sophie, Lemaire; Bernadette, Perrin-Riou |
4161 | bpr | 11 | |
7277 | bpr | 12 | slib_example=0.5,11,0.5\ |
13 | 0.5,4,0.5\ |
||
14 | [0.5,0.3,0.6],101,0.5\ |
||
15 | 0.3,800,0.61\ |
||
16 | 0.3,900,0.34\ |
||
11336 | bpr | 17 | [0.2,0.4,0.6],5,0.5 |
10075 | bpr | 18 | slib_require=octave |
7277 | bpr | 19 | |
20 | reyssat | 20 | !exit |
21 | |||
22 | :proc |
||
7277 | bpr | 23 | !reset slib_out |
18193 | bpr | 24 | !distribute item $wims_read_parm into slib_data,slib_n,slib_p |
20 | reyssat | 25 | !default slib_n= 5 |
26 | !default slib_p=0.5 |
||
7692 | bpr | 27 | !if $slib_p>=1 or $slib_p<=0 |
20 | reyssat | 28 | slib_out=0 |
29 | !exit |
||
30 | !endif |
||
31 | slib_out= |
||
32 | slib_data=!declosing $slib_data |
||
4501 | bpr | 33 | slib_p=$[$slib_p] |
7277 | bpr | 34 | |
35 | !if $slib_p=0.5 and 0.5 isitemof $slib_data |
||
36 | !for slib_q in $slib_data |
||
37 | !if $slib_q=0.5 |
||
38 | !if $[$slib_n%2]=0 |
||
39 | slib_out=!append item $[$slib_n/2] to $slib_out |
||
40 | !else |
||
41 | slib_out=!append item $[($slib_n-1)/2] to $slib_out |
||
42 | !endif |
||
43 | !else |
||
44 | slib_res=!exec octave binoinv($slib_q, $slib_n, $slib_p) |
||
45 | slib_out=!append item $slib_res to $slib_out |
||
46 | !endif |
||
47 | !next |
||
48 | !goto end |
||
7692 | bpr | 49 | !endif |
7277 | bpr | 50 | |
51 | slib_out=!exec octave binoinv([$slib_data], $slib_n, $slib_p) |
||
52 | |||
53 | :end |
||
54 | |||
55 | slib_out=!words2items $slib_out |
||
56 | slib_out=!trim $slib_out |
||
57 | |||
58 | !exit |
||
59 | old |
||
60 | |||
20 | reyssat | 61 | slib_p1=$[1-$slib_p] |
62 | slib_r=$[$slib_p/$slib_p1] |
||
7277 | bpr | 63 | slib_a=$slib_p1^($slib_n) |
20 | reyssat | 64 | slib_cnt= !itemcnt $slib_data |
65 | slib_pp=$[$slib_p/$slib_p1] |
||
7277 | bpr | 66 | |
20 | reyssat | 67 | !for slib_i =1 to $slib_cnt |
68 | slib_di=!item $slib_i of $slib_data |
||
69 | slib_P=0 |
||
70 | slib_a=$[$slib_p1^($slib_n)] |
||
71 | !for slib_k=0 to $slib_n |
||
72 | !!slib_a=!item $[$slib_k+1] of $slib_bino |
||
73 | slib_P=$[$slib_P+$slib_a] |
||
7277 | bpr | 74 | slib_out=!append item $slib_P to $slib_out |
75 | !ifval $slib_P>= $slib_di |
||
18193 | bpr | 76 | slib_out=!append item $slib_k to $slib_out |
20 | reyssat | 77 | !break |
78 | !endif |
||
79 | slib_a=$[$slib_a*$slib_pp*($slib_n-$slib_k)/($slib_k+1)] |
||
80 | !next slib_k |
||
81 | !next slib_i |
||
7277 | bpr | 82 | !default slib_out=$slib_k |
20 | reyssat | 83 | slib_out=!trim $slib_out |