andrsnde.c 849 B

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <math.h>
  4. #include "local_proto.h"
  5. double *Cdhc_anderson_darling_exp(double *x, int n)
  6. {
  7. static double y[2];
  8. double sqrt2, mean = 0.0, *xcopy, fx, sum3 = 0.0;
  9. int i;
  10. if ((xcopy = (double *)malloc(n * sizeof(double))) == NULL) {
  11. fprintf(stderr, "Memory error in Cdhc_anderson_darling\n");
  12. exit(EXIT_FAILURE);
  13. }
  14. sqrt2 = sqrt((double)2.0);
  15. for (i = 0; i < n; ++i) {
  16. xcopy[i] = x[i];
  17. mean += x[i];
  18. }
  19. mean /= n;
  20. qsort(xcopy, n, sizeof(double), Cdhc_dcmp);
  21. for (i = 0; i < n; ++i) {
  22. fx = 1 - exp(-xcopy[i] / mean);
  23. sum3 += (2.0 * i + 1) * (log(fx) - xcopy[n - i - 1] / mean);
  24. }
  25. y[0] = (1.0 + 0.3 / n) * (-n - sum3 / n);
  26. #ifdef NOISY
  27. fprintf(stdout, " TEST20 AD(E) =%10.4f\n", y[0]);
  28. #endif /* NOISY */
  29. free(xcopy);
  30. return y;
  31. }