aboutsummaryrefslogtreecommitdiff
path: root/math/gsurfit/gsvectord.x
diff options
context:
space:
mode:
authorJoe Hunkeler <jhunkeler@gmail.com>2015-08-11 16:51:37 -0400
committerJoe Hunkeler <jhunkeler@gmail.com>2015-08-11 16:51:37 -0400
commit40e5a5811c6ffce9b0974e93cdd927cbcf60c157 (patch)
tree4464880c571602d54f6ae114729bf62a89518057 /math/gsurfit/gsvectord.x
downloadiraf-osx-40e5a5811c6ffce9b0974e93cdd927cbcf60c157.tar.gz
Repatch (from linux) of OSX IRAF
Diffstat (limited to 'math/gsurfit/gsvectord.x')
-rw-r--r--math/gsurfit/gsvectord.x57
1 files changed, 57 insertions, 0 deletions
diff --git a/math/gsurfit/gsvectord.x b/math/gsurfit/gsvectord.x
new file mode 100644
index 00000000..8bb980e6
--- /dev/null
+++ b/math/gsurfit/gsvectord.x
@@ -0,0 +1,57 @@
+# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.
+
+include <math/gsurfit.h>
+include "dgsurfitdef.h"
+
+# GSVECTOR -- Procedure to evaluate the fitted surface at an array of points.
+# The GS_NCOEFF(sf) coefficients are stored in the
+# vector COEFF.
+
+procedure dgsvector (sf, x, y, zfit, npts)
+
+pointer sf # pointer to surface descriptor structure
+double x[ARB] # x value
+double y[ARB] # y value
+double zfit[ARB] # fits surface values
+int npts # number of data points
+
+begin
+ # evaluate the surface along the vector
+ switch (GS_TYPE(sf)) {
+ case GS_POLYNOMIAL:
+ if (GS_XORDER(sf) == 1) {
+ call dgs_1devpoly (COEFF(GS_COEFF(sf)), y, zfit, npts,
+ GS_YORDER(sf), GS_YMAXMIN(sf), GS_YRANGE(sf))
+ } else if (GS_YORDER(sf) == 1) {
+ call dgs_1devpoly (COEFF(GS_COEFF(sf)), x, zfit, npts,
+ GS_XORDER(sf), GS_XMAXMIN(sf), GS_XRANGE(sf))
+ } else
+ call dgs_evpoly (COEFF(GS_COEFF(sf)), x, y, zfit, npts,
+ GS_XTERMS(sf), GS_XORDER(sf), GS_YORDER(sf), GS_XMAXMIN(sf),
+ GS_XRANGE(sf), GS_YMAXMIN(sf), GS_YRANGE(sf))
+ case GS_CHEBYSHEV:
+ if (GS_XORDER(sf) == 1) {
+ call dgs_1devcheb (COEFF(GS_COEFF(sf)), y, zfit, npts,
+ GS_YORDER(sf), GS_YMAXMIN(sf), GS_YRANGE(sf))
+ } else if (GS_YORDER(sf) == 1) {
+ call dgs_1devcheb (COEFF(GS_COEFF(sf)), x, zfit, npts,
+ GS_XORDER(sf), GS_XMAXMIN(sf), GS_XRANGE(sf))
+ } else
+ call dgs_evcheb (COEFF(GS_COEFF(sf)), x, y, zfit, npts,
+ GS_XTERMS(sf), GS_XORDER(sf), GS_YORDER(sf), GS_XMAXMIN(sf),
+ GS_XRANGE(sf), GS_YMAXMIN(sf), GS_YRANGE(sf))
+ case GS_LEGENDRE:
+ if (GS_XORDER(sf) == 1) {
+ call dgs_1devleg (COEFF(GS_COEFF(sf)), y, zfit, npts,
+ GS_YORDER(sf), GS_YMAXMIN(sf), GS_YRANGE(sf))
+ } else if (GS_YORDER(sf) == 1) {
+ call dgs_1devleg (COEFF(GS_COEFF(sf)), x, zfit, npts,
+ GS_XORDER(sf), GS_XMAXMIN(sf), GS_XRANGE(sf))
+ } else
+ call dgs_evleg (COEFF(GS_COEFF(sf)), x, y, zfit, npts,
+ GS_XTERMS(sf), GS_XORDER(sf), GS_YORDER(sf), GS_XMAXMIN(sf),
+ GS_XRANGE(sf), GS_YMAXMIN(sf), GS_YRANGE(sf))
+ default:
+ call error (0, "GSVECTOR: Unknown surface type.")
+ }
+end