Subversion Repositories wimsdev

Rev

Rev 7692 | 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
 
20 reyssat 12
slib_example=[0.2,0.4,0.6],5,0.5
3265 bpr 13
slib_require=pari
20 reyssat 14
!exit
15
 
16
:proc
17
 
18
!distribute  item $wims_read_parm into slib_data,slib_n,slib_p
19
!default slib_n= 5
20
!default slib_p=0.5
7692 bpr 21
!if $slib_p>=1 or $slib_p<=0
20 reyssat 22
	slib_out=0
23
	!exit
24
!endif
25
slib_out=
26
slib_data=!declosing $slib_data
4501 bpr 27
slib_p=$[$slib_p]
20 reyssat 28
slib_p1=$[1-$slib_p]
29
slib_r=$[$slib_p/$slib_p1]
30
slib_a=$[$slib_p1^($slib_n)]
31
slib_cnt= !itemcnt $slib_data
32
!for slib_i =1 to $slib_cnt
33
	slib_di=!item $slib_i of $slib_data
34
	slib_k=!exec pari {slib_P=0;slib_x=$slib_n;\
35
	 while(slib_P< $slib_di, slib_x=slib_x+1;\
4501 bpr 36
 	 slib_P = slib_P + binomial(slib_x-1,$slib_n-1) * $slib_p^$slib_n * $slib_p1^(slib_x-$slib_n));\
20 reyssat 37
		print(slib_x)}
38
	slib_out=!append item  $slib_k to $slib_out
39
!next slib_i
40
slib_out=!trim $slib_out