add numerical recipes library
This commit is contained in:
31
lib/nr/k_and_r/recipes/moment.c
Normal file
31
lib/nr/k_and_r/recipes/moment.c
Normal file
@@ -0,0 +1,31 @@
|
||||
|
||||
#include <math.h>
|
||||
|
||||
void moment(data,n,ave,adev,sdev,var,skew,curt)
|
||||
float *adev,*ave,*curt,*sdev,*skew,*var,data[];
|
||||
int n;
|
||||
{
|
||||
void nrerror();
|
||||
int j;
|
||||
float ep=0.0,s,p;
|
||||
|
||||
if (n <= 1) nrerror("n must be at least 2 in moment");
|
||||
s=0.0;
|
||||
for (j=1;j<=n;j++) s += data[j];
|
||||
*ave=s/n;
|
||||
*adev=(*var)=(*skew)=(*curt)=0.0;
|
||||
for (j=1;j<=n;j++) {
|
||||
*adev += fabs(s=data[j]-(*ave));
|
||||
ep += s;
|
||||
*var += (p=s*s);
|
||||
*skew += (p *= s);
|
||||
*curt += (p *= s);
|
||||
}
|
||||
*adev /= n;
|
||||
*var=(*var-ep*ep/n)/(n-1);
|
||||
*sdev=sqrt(*var);
|
||||
if (*var) {
|
||||
*skew /= (n*(*var)*(*sdev));
|
||||
*curt=(*curt)/(n*(*var)*(*var))-3.0;
|
||||
} else nrerror("No skew/kurtosis when variance = 0 (in moment)");
|
||||
}
|
||||
Reference in New Issue
Block a user