Subversion Repositories wimsdev

Rev

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