Subversion Repositories wimsdev

Rev

Rev 4330 | Rev 7277 | 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
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
 
20 reyssat 12
slib_example=[0.2,0.4,0.6],5,0.5
13
!exit
14
 
15
:proc
16
 
17
!distribute  item $wims_read_parm into slib_data,slib_n,slib_p
18
!default slib_n= 5
19
!default slib_p=0.5
20
!if $slib_p>=1 or $slib_p<=0 
21
	slib_out=0
22
	!exit
23
!endif
24
slib_out=
25
slib_data=!declosing $slib_data
4501 bpr 26
slib_p=$[$slib_p]
20 reyssat 27
slib_p1=$[1-$slib_p]
28
slib_r=$[$slib_p/$slib_p1]
29
slib_a=$[$slib_p1^($slib_n)]
30
!!slib_bino=!values binomial($slib_n,x)*$slib_p^x*$slib_p1^($slib_n-x) for x =0 to $slib_n
31
slib_cnt= !itemcnt $slib_data
32
slib_pp=$[$slib_p/$slib_p1]
33
!for slib_i =1 to $slib_cnt
34
	slib_di=!item $slib_i of $slib_data
35
	slib_P=0
36
	slib_a=$[$slib_p1^($slib_n)]
37
	!for slib_k=0 to $slib_n
38
		!!slib_a=!item $[$slib_k+1] of $slib_bino
39
		slib_P=$[$slib_P+$slib_a]
40
		!if $slib_P>= $slib_di
41
			slib_out=!append item  $slib_k to $slib_out
42
			!break
43
		!endif
44
		slib_a=$[$slib_a*$slib_pp*($slib_n-$slib_k)/($slib_k+1)]
45
	!next slib_k
46
!next slib_i
47
slib_out=!trim $slib_out