NAG Library Routine Document
E01SAF generates a two-dimensional surface interpolating a set of scattered data points, using the method of Renka and Cline.
||M, TRIANG(7*M), IFAIL
||X(M), Y(M), F(M), GRADS(2,M)
E01SAF constructs an interpolating surface through a set of scattered data points , for , using a method due to Renka and Cline. In the plane, the data points must be distinct. The constructed surface is continuous and has continuous first derivatives.
The method involves firstly creating a triangulation with all the
data points as nodes, the triangulation being as nearly equiangular as possible (see Cline and Renka (1984)
). Then gradients in the
-directions are estimated at node
as the partial derivatives of a quadratic function of
which interpolates the data value
and which fits the data values at nearby nodes (those within a certain distance chosen by the algorithm) in a weighted least squares sense. The weights are chosen such that closer nodes have more influence than more distant nodes on derivative estimates at node
. The computed partial derivatives, with the
values, at the three nodes of each triangle define a piecewise polynomial surface of a certain form which is the interpolant on that triangle. See Renka and Cline (1984)
for more detailed information on the algorithm,
a development of that by Lawson (1977)
. The code is derived from Renka (1984)
can subsequently be evaluated at any point
inside or outside the domain of the data by a call to
Points outside the domain are evaluated by extrapolation.
Cline A K and Renka R L (1984) A storage-efficient method for construction of a Thiessen triangulation Rocky Mountain J. Math. 14 119–139
Lawson C L (1977) Software for surface interpolation Mathematical Software III (ed J R Rice) 161–194 Academic Press
Renka R L (1984) Algorithm 624: triangulation and interpolation of arbitrarily distributed points in the plane ACM Trans. Math. Software 10 440–442
Renka R L and Cline A K (1984) A triangle-based interpolation method Rocky Mountain J. Math. 14 223–237
- 1: M – INTEGERInput
On entry: , the number of data points.
- 2: X(M) – REAL (KIND=nag_wp) arrayInput
- 3: Y(M) – REAL (KIND=nag_wp) arrayInput
- 4: F(M) – REAL (KIND=nag_wp) arrayInput
: the coordinates of the
th data point, for
. The data points are accepted in any order, but see Section 8
the nodes must not all be collinear, and each node must be unique.
- 5: TRIANG() – INTEGER arrayOutput
: a data structure defining the computed triangulation, in a form suitable for passing to E01SBF
- 6: GRADS(,M) – REAL (KIND=nag_wp) arrayOutput
: the estimated partial derivatives at the nodes, in a form suitable for passing to E01SBF
. The derivatives at node
with respect to
are contained in
- 7: IFAIL – INTEGERInput/Output
must be set to
. If you are unfamiliar with this parameter you should refer to Section 3.3
in the Essential Introduction for details.
For environments where it might be inappropriate to halt program execution when an error is detected, the value
is recommended. If the output of error messages is undesirable, then the value
is recommended. Otherwise, if you are not familiar with this parameter, the recommended value is
. When the value is used it is essential to test the value of IFAIL on exit.
unless the routine detects an error or a warning has been flagged (see Section 6
6 Error Indicators and Warnings
If on entry
, explanatory error messages are output on the current error message unit (as defined by X04AAF
Errors or warnings detected by the routine:
|On entry,||all the (X,Y) pairs are collinear.|
|On entry,|| for some .|
On successful exit, the computational errors should be negligible in most situations but you should always check the computed surface for acceptability, by drawing contours for instance. The surface always interpolates the input data exactly.
The time taken for a call of E01SAF is approximately proportional to the number of data points,
. The routine is more efficient if, before entry, the values in X
are arranged so that the X
array is in ascending order.
This example reads in a set of
data points and calls E01SAF
to construct an interpolating surface. It then calls
to evaluate the interpolant at a sample of points on a rectangular grid.
Note that this example is not typical of a realistic problem: the number of data points would normally be larger, and the interpolant would need to be evaluated on a finer grid to obtain an accurate plot, say.
9.1 Program Text
Program Text (e01safe.f90)
9.2 Program Data
Program Data (e01safe.d)
9.3 Program Results
Program Results (e01safe.r)