chisqe.c 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <math.h>
  4. double *Cdhc_chi_square_exp(double *x, int n)
  5. {
  6. static double y[2];
  7. double mean = 0.0, sum3 = 0.0, *v;
  8. int i, j, k, *f;
  9. k = rint(4.0 * pow(0.75 * (n - 1.0) * (n - 1.0), 0.2));
  10. while ((double)(n / k) < 5.0)
  11. --k;
  12. if ((f = (int *)calloc(k, sizeof(int))) == NULL) {
  13. fprintf(stderr, "Memory error in Cdhc_chi_square\n");
  14. exit(EXIT_FAILURE);
  15. }
  16. if ((v = (double *)malloc((k + 1) * sizeof(double))) == NULL) {
  17. fprintf(stderr, "Memory error in Cdhc_chi_square\n");
  18. exit(EXIT_FAILURE);
  19. }
  20. for (i = 0; i < n; ++i)
  21. mean += x[i];
  22. mean = n / mean;
  23. v[0] = 0.0;
  24. for (i = 1; i < k; ++i)
  25. v[i] = -log(1.0 - (double)i / k) / mean;
  26. v[k] = 1e9;
  27. for (i = 0; i < n; ++i) {
  28. j = 0;
  29. while (j < k) {
  30. if (x[i] > v[j] && x[i] <= v[j + 1]) {
  31. f[j]++;
  32. j = k;
  33. }
  34. j++;
  35. }
  36. }
  37. for (i = 0; i < k; ++i)
  38. sum3 += f[i] * f[i];
  39. y[0] = sum3 * k / n - n;
  40. y[1] = (double)k - 2.0;
  41. #ifdef NOISY
  42. fprintf(stdout, " TEST21 CS(E) =%10.4f DOF =%10.4f\n", y[0], y[1]);
  43. #endif /* NOISY */
  44. free(f);
  45. free(v);
  46. return y;
  47. }