solvps.c 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. /* solvps.c CCMATH mathematics library source code.
  2. *
  3. * Copyright (C) 2000 Daniel A. Atkinson All rights reserved.
  4. * This code may be redistributed under the terms of the GNU library
  5. * public license (LGPL). ( See the lgpl.license file for details.)
  6. * ------------------------------------------------------------------------
  7. */
  8. #include "ccmath.h"
  9. int solvps(double *a, double *b, int n)
  10. {
  11. double *p, *q, *r, *s, t;
  12. int j, k;
  13. for (j = 0, p = a; j < n; ++j, p += n + 1) {
  14. for (q = a + j * n; q < p; ++q)
  15. *p -= *q * *q;
  16. if (*p <= 0.)
  17. return -1;
  18. *p = sqrt(*p);
  19. for (k = j + 1, q = p + n; k < n; ++k, q += n) {
  20. for (r = a + j * n, s = a + k * n, t = 0.; r < p;)
  21. t += *r++ * *s++;
  22. *q -= t;
  23. *q /= *p;
  24. }
  25. }
  26. for (j = 0, p = a; j < n; ++j, p += n + 1) {
  27. for (k = 0, q = a + j * n; k < j;)
  28. b[j] -= b[k++] * *q++;
  29. b[j] /= *p;
  30. }
  31. for (j = n - 1, p = a + n * n - 1; j >= 0; --j, p -= n + 1) {
  32. for (k = j + 1, q = p + n; k < n; q += n)
  33. b[j] -= b[k++] * *q;
  34. b[j] /= *p;
  35. }
  36. return 0;
  37. }