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 /sys/qpoe/gen/qpexsubr.x | |
download | iraf-osx-40e5a5811c6ffce9b0974e93cdd927cbcf60c157.tar.gz |
Repatch (from linux) of OSX IRAF
Diffstat (limited to 'sys/qpoe/gen/qpexsubr.x')
-rw-r--r-- | sys/qpoe/gen/qpexsubr.x | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/sys/qpoe/gen/qpexsubr.x b/sys/qpoe/gen/qpexsubr.x new file mode 100644 index 00000000..147bf14b --- /dev/null +++ b/sys/qpoe/gen/qpexsubr.x @@ -0,0 +1,63 @@ +# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc. + +include <mach.h> +include "../qpex.h" + +# QPEX_SUBLIST -- Extract a sublist spanning the indicated range from a +# larger range list. The number of ranges extracted is returned as the +# function value. + +int procedure qpex_sublistr (x1, x2, xs,xe,nranges,ip, o_xs,o_xe) + +real x1, x2 #I range to be extracted +real xs[nranges],xe[nranges] #I input range list +int nranges #I nranges in input list +int ip #U start position in input list +real o_xs[ARB],o_xe[ARB] #O output sublist + +real tol +int op, i + +begin + tol = (EPSILONR * 10.0) + + # Determine the range containing or immediately following the + # start point of the range of interest. + + while (x1 < xs[ip] && ip > 1) + ip = ip - 1 + while (x1 >= xs[ip]) + if (x1 <= xe[ip] || ip >= nranges) + break + else + ip = ip + 1 + + # Check for an empty output range list. + if (xs[ip] > x2) + return (0) + + # At least one input range contributes something to the output region. + # Copy a portion of the input range list to the ouput range list. + + op = 1 + do i = ip, nranges { + if (xs[i] <= x1) + o_xs[op] = LEFTR - tol + else + o_xs[op] = xs[i] + + if ((xe[i] - x2) >= tol) { + o_xe[op] = RIGHTR + tol + op = op + 1 + break + } else + o_xe[op] = xe[i] + + op = op + 1 + if (xs[i+1] > x2) + break + } + + ip = i + return (op - 1) +end |