diff options
author | Joseph Hunkeler <jhunkeler@gmail.com> | 2015-07-08 20:46:52 -0400 |
---|---|---|
committer | Joseph Hunkeler <jhunkeler@gmail.com> | 2015-07-08 20:46:52 -0400 |
commit | fa080de7afc95aa1c19a6e6fc0e0708ced2eadc4 (patch) | |
tree | bdda434976bc09c864f2e4fa6f16ba1952b1e555 /pkg/xtools/inlfit/inrmsd.x | |
download | iraf-linux-fa080de7afc95aa1c19a6e6fc0e0708ced2eadc4.tar.gz |
Initial commit
Diffstat (limited to 'pkg/xtools/inlfit/inrmsd.x')
-rw-r--r-- | pkg/xtools/inlfit/inrmsd.x | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/pkg/xtools/inlfit/inrmsd.x b/pkg/xtools/inlfit/inrmsd.x new file mode 100644 index 00000000..26800de7 --- /dev/null +++ b/pkg/xtools/inlfit/inrmsd.x @@ -0,0 +1,31 @@ +# IN_RMS -- Compute rms of points which have a non-zero weight. + +double procedure in_rmsd (y, fit, wts, npts) + +double y[npts] # function +double fit[npts] # fit +double wts[npts] # weights +int npts # number of points + +int i, ndata +double resid, rms + +begin + rms = double (0.0) + ndata = 0 + + do i = 1, npts { + if (wts[i] == double (0.0)) + next + resid = y[i] - fit[i] + rms = rms + resid * resid + ndata = ndata + 1 + } + + if (ndata > 0) + rms = sqrt (rms / ndata) + else + rms = double (0.0) + + return (rms) +end |