add numerical recipes library
This commit is contained in:
32
lib/nr/k_and_r/recipes/kendl1.c
Normal file
32
lib/nr/k_and_r/recipes/kendl1.c
Normal file
@@ -0,0 +1,32 @@
|
||||
|
||||
#include <math.h>
|
||||
|
||||
void kendl1(data1,data2,n,tau,z,prob)
|
||||
float *prob,*tau,*z,data1[],data2[];
|
||||
unsigned long n;
|
||||
{
|
||||
float erfcc();
|
||||
unsigned long n2=0,n1=0,k,j;
|
||||
long is=0;
|
||||
float svar,aa,a2,a1;
|
||||
|
||||
for (j=1;j<n;j++) {
|
||||
for (k=(j+1);k<=n;k++) {
|
||||
a1=data1[j]-data1[k];
|
||||
a2=data2[j]-data2[k];
|
||||
aa=a1*a2;
|
||||
if (aa) {
|
||||
++n1;
|
||||
++n2;
|
||||
aa > 0.0 ? ++is : --is;
|
||||
} else {
|
||||
if (a1) ++n1;
|
||||
if (a2) ++n2;
|
||||
}
|
||||
}
|
||||
}
|
||||
*tau=is/(sqrt((double) n1)*sqrt((double) n2));
|
||||
svar=(4.0*n+10.0)/(9.0*n*(n-1.0));
|
||||
*z=(*tau)/sqrt(svar);
|
||||
*prob=erfcc(fabs(*z)/1.4142136);
|
||||
}
|
||||
Reference in New Issue
Block a user