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/ingundeleted.x | |
download | iraf-linux-fa080de7afc95aa1c19a6e6fc0e0708ced2eadc4.tar.gz |
Initial commit
Diffstat (limited to 'pkg/xtools/inlfit/ingundeleted.x')
-rw-r--r-- | pkg/xtools/inlfit/ingundeleted.x | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/pkg/xtools/inlfit/ingundeleted.x b/pkg/xtools/inlfit/ingundeleted.x new file mode 100644 index 00000000..5b7717d9 --- /dev/null +++ b/pkg/xtools/inlfit/ingundeleted.x @@ -0,0 +1,92 @@ +include <gset.h> +include <mach.h> +include <pkg/gtools.h> + +define MSIZE 2.0 # Mark size (real) + + +# ING_UNDELETE -- Undelete data point nearest the cursor. The nearest point to +# the cursor in NDC coordinates is determined. + +procedure ing_undeleted (in, gp, gt, nl, x, y, wts, userwts, npts, nvars, + wx, wy) + +pointer in # INLFIT pointer +pointer gp # GIO pointer +pointer gt # GTOOLS pointer +pointer nl # NLFIT pointer +double x[ARB] # Independent variables (npts * nvars) +double y[npts] # Dependent variables +double wts[npts], userwts[npts] # Weight arrays +int npts # Number of points +int nvars # Number of variables +real wx, wy # Position to be nearest + +pointer sp, xout, yout +int gt_geti() + +begin + # Allocate memory for the axes data. + call smark (sp) + call salloc (xout, npts, TY_DOUBLE) + call salloc (yout, npts, TY_DOUBLE) + + # Get the axes data. + call ing_axesd (in, gt, nl, 1, x, y, Memd[xout], npts, nvars) + call ing_axesd (in, gt, nl, 2, x, y, Memd[yout], npts, nvars) + + # Transpose axes if necessary. + if (gt_geti (gt, GTTRANSPOSE) == NO) + call ing_u1d (in, gp, Memd[xout], Memd[yout], wts, userwts, + npts, wx, wy) + else + call ing_u1d (in, gp, Memd[yout], Memd[xout], wts, userwts, + npts, wy, wx) + + # Free memory. + call sfree (sp) +end + + +# ING_U1 -- Do the actual undelete. + +procedure ing_u1d (in, gp, x, y, wts, userwts, npts, wx, wy) + +pointer in # ICFIT pointer +pointer gp # GIO pointer +double x[npts], y[npts] # Data points +double wts[npts], userwts[npts] # Weight arrays +int npts # Number of points +real wx, wy # Position to be nearest + +int i, j +real x0, y0, r2, r2min + +begin + # Transform world cursor coordinates to NDC. + call gctran (gp, wx, wy, wx, wy, 1, 0) + + # Search for nearest point to a point with zero weight. + r2min = MAX_REAL + do i = 1, npts { + if (wts[i] != double (0.0)) + next + call gctran (gp, real (x[i]), real (y[i]), x0, y0, 1, 0) + r2 = (x0 - wx) ** 2 + (y0 - wy) ** 2 + if (r2 < r2min) { + r2min = r2 + j = i + } + } + + # Unmark the deleted point and reset the weight. + if (j != 0) { + call gscur (gp, real (x[j]), real (y[j])) + call gseti (gp, G_PMLTYPE, GL_CLEAR) + call gmark (gp, real (x[j]), real (y[j]), GM_CROSS, MSIZE, MSIZE) + call gseti (gp, G_PMLTYPE, GL_SOLID) + #call gline (gp, real (x[j]), real (y[j]), real (x[j]), real (y[j])) + call gmark (gp, real (x[j]), real (y[j]), GM_PLUS, MSIZE, MSIZE) + wts[j] = userwts[j] + } +end |