source:
CIVL/mods/dev.civl.com/examples/compare/CholeskyDecomposition/choldc.c@
cb4d4f4
| Last change on this file since cb4d4f4 was aad342c, checked in by , 3 years ago | |
|---|---|
|
|
| File size: 373 bytes | |
| Rev | Line | |
|---|---|---|
| [9765af0] | 1 | #include <math.h> |
| 2 | ||
| 3 | void choldc(float **a, int n, float p[]) | |
| 4 | { | |
| 5 | void nrerror(char error_text[]); | |
| 6 | int i, j, k; | |
| 7 | float sum; | |
| 8 | ||
| 9 | for (i=0; i<=n; i++) { | |
| 10 | for (j=i; j<=n; j++ ) { | |
| 11 | for (sum=a[i][j], k=i-1; k>=1; k--) sum -= a[i][k]*a[j][k]; | |
| 12 | if (i == j) { | |
| 13 | if (sum <= 0.0) | |
| 14 | nrerror("choldc failed"); | |
| 15 | p[i] = sqrt(sum); | |
| 16 | } else a[j][i]=sum/p[i]; | |
| 17 | } | |
| 18 | } | |
| 19 | } |
Note:
See TracBrowser
for help on using the repository browser.
