diff options
author | Joe Hunkeler <jhunkeler@gmail.com> | 2015-08-11 16:51:37 -0400 |
---|---|---|
committer | Joe Hunkeler <jhunkeler@gmail.com> | 2015-08-11 16:51:37 -0400 |
commit | 40e5a5811c6ffce9b0974e93cdd927cbcf60c157 (patch) | |
tree | 4464880c571602d54f6ae114729bf62a89518057 /pkg/xtools/ranges/rgexclude.gx | |
download | iraf-osx-40e5a5811c6ffce9b0974e93cdd927cbcf60c157.tar.gz |
Repatch (from linux) of OSX IRAF
Diffstat (limited to 'pkg/xtools/ranges/rgexclude.gx')
-rw-r--r-- | pkg/xtools/ranges/rgexclude.gx | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/pkg/xtools/ranges/rgexclude.gx b/pkg/xtools/ranges/rgexclude.gx new file mode 100644 index 00000000..876e4ef7 --- /dev/null +++ b/pkg/xtools/ranges/rgexclude.gx @@ -0,0 +1,56 @@ +# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc. + +include <pkg/rg.h> + +# RG_EXCLUDE -- Exclude points given by ranges. +# +# The output array must be large enough to contain the desired points. +# If the ranges are merged then the input and output arrays may be the same. + +procedure rg_exclude$t (rg, a, nin, b, nout) + +pointer rg # Ranges +PIXEL a[nin] # Input array +int nin # Number of input points +PIXEL b[ARB] # Output array +int nout # Number of output points + +int i, j, k, n, ntemp + +begin + # Error check the range pointer. + + if (rg == NULL) + call error (0, "Range descriptor undefined") + + if (RG_NRGS(rg) == 0) { + call amov$t (a[1], b[1], nin) + nout = nin + } else { + ntemp = 0 + + i = 1 + j = 1 + k = min (nin, min (RG_X1(rg, i), RG_X2(rg, i)) - 1) + n = max (0, k - j + 1) + call amov$t (a[j], b[ntemp+1], n) + ntemp = ntemp + n + + do i = 2, RG_NRGS(rg) { + j = max (1, max (RG_X1(rg, i-1), RG_X2(rg, i-1)) + 1) + k = min (nin, min (RG_X1(rg, i), RG_X2(rg, i)) - 1) + n = max (0, k - j + 1) + call amov$t (a[j], b[ntemp+1], n) + ntemp = ntemp + n + } + + i = RG_NRGS (rg) + j = max (1, max (RG_X1(rg, i), RG_X2(rg, i)) + 1) + k = nin + n = max (0, k - j + 1) + call amov$t (a[j], b[ntemp+1], n) + ntemp = ntemp + n + } + + nout = ntemp +end |