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
 
4986 bpr 12
slib_example=[1,3,5],3,0.7
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_p
20 reyssat 19
 
20
!default slib_n= 5
21
!default slib_p=0.5
22
 
7692 bpr 23
!if $slib_p>=1 or $slib_p<=0
20 reyssat 24
	slib_out=0
25
	!exit
26
!endif
27
slib_out=
28
slib_data=!declosing $slib_data
29
slib_cnt= !itemcnt $slib_data
30
slib_data1=!values rint(x)  for x in $slib_data
31
 
32
slib_n=$[rint($slib_n)]
4501 bpr 33
slib_p=$[$slib_p]
34
slib_p1=$[1-$slib_p]
20 reyssat 35
slib_out=!exec pari {slib_data=[$slib_data1];\
36
print(vector($slib_cnt,i,binomial(slib_data[i]-1,$slib_n-1)\
37
*$slib_p^($slib_n)*$slib_p1^(slib_data[i]-$slib_n)));}
38
 
39
slib_out=!trim $slib_out
40
!for slib_i=1 to $slib_cnt
41
	slib_tmp=!item $slib_i of $slib_data
42
	!if $[rint($slib_tmp)-$slib_tmp]<>0 or $slib_tmp<$slib_n
43
		slib_out=!replace internal item number $slib_i by 0 in $slib_out
44
	!endif
7692 bpr 45
!next slib_i
20 reyssat 46
slib_out=!trim $slib_out