chisqn.c 1.3 KB

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