Click or drag to resize
CsAkima Class
Extension of the Spline class to handle the Akima cubic spline.
Inheritance Hierarchy

Namespace: Imsl.Math
Assembly: ImslCS (in ImslCS.dll) Version: 6.5.2.0
Syntax
[SerializableAttribute]
public class CsAkima : Spline

The CsAkima type exposes the following members.

Constructors
  NameDescription
Public methodCsAkima
Constructs the Akima cubic spline interpolant to the given data points.
Top
Methods
  NameDescription
Public methodDerivative(Double)
Returns the value of the first derivative of the spline at a point.
(Inherited from Spline.)
Public methodDerivative(Double, Int32)
Returns the value of the derivative of the spline at a point.
(Inherited from Spline.)
Public methodDerivative(Double, Int32)
Returns the value of the derivative of the spline at each point of an array.
(Inherited from Spline.)
Public methodEquals
Determines whether the specified object is equal to the current object.
(Inherited from Object.)
Public methodEval(Double)
Returns the value of the spline at a point.
(Inherited from Spline.)
Public methodEval(Double)
Returns the value of the spline at each point of an array.
(Inherited from Spline.)
Protected methodFinalize
Allows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection.
(Inherited from Object.)
Public methodGetBreakpoints
Returns a copy of the breakpoints.
(Inherited from Spline.)
Public methodGetHashCode
Serves as a hash function for a particular type.
(Inherited from Object.)
Public methodGetType
Gets the Type of the current instance.
(Inherited from Object.)
Public methodIntegral
Returns the value of an integral of the spline.
(Inherited from Spline.)
Protected methodMemberwiseClone
Creates a shallow copy of the current Object.
(Inherited from Object.)
Public methodToString
Returns a string that represents the current object.
(Inherited from Object.)
Top
Remarks

Class CsAkima computes a C^1 cubic spline interpolant to a set of data points (x_i, f_i) for i = 0, \ldots, n-1. The breakpoints of the spline are the abscissas. Endpoint conditions are automatically determined by the program; see Akima (1970) or de Boor (1978).

If the data points arise from the values of a smooth, say C^4, function f, i.e. f_i = f(x_i), then the error will behave in a predictable fashion. Let \xi be the breakpoint vector for the above spline interpolant. Then, the maximum absolute error satisfies

\left\| {f - s} \right\|_{\left[ {\xi_0 ,
            \xi_{n-1} } \right]} \le C\left\| f^{(2)}\right\|_{[\xi_0,\xi_{n-1}}
            \left| \xi \right|^2

where

|\xi| \;: = \max\limits_{i = 1,\ldots,n-1} |\xi_i -\xi_{i-1}|

CsAkima is based on a method by Akima (1970) to combat wiggles in the interpolant. The method is nonlinear; and although the interpolant is a piecewise cubic, cubic polynomials are not reproduced. (However, linear polynomials are reproduced.)

See Also

Reference

Other Resources