ILNumerics Ultimate VS

CubicInterpolatorComplexApply Method

ILNumerics Ultimate VS Documentation
ILNumerics - Technical Application Development
Computes interpolated values using this cubic interpolator for new query points Xn.

[ILNumerics Interpolation Toolbox]

Namespace:  ILNumerics.Toolboxes
Assembly:  ILNumerics.Toolboxes.Interpolation (in ILNumerics.Toolboxes.Interpolation.dll) Version: 5.5.0.0 (5.5.7503.3146)
Syntax

public override RetArray<complex> Apply(
	InArray<double> Xn,
	InCell arguments = null
)

Parameters

Xn
Type: ILNumericsInArrayDouble
Query points, specified as a scalar, vector or n-dim array of real numbers.
arguments (Optional)
Type: ILNumericsInCell
(Ignored)

Return Value

Type: RetArraycomplex
Interpolated data, see remarks for size details.
Exceptions

ExceptionCondition
ArgumentNullExceptionIf an input parameters are NULL
InvalidOperationExceptionIf Interpolation object has been disposed before Apply() calls
Remarks

Xn defines new positions for the interpolation based on the trained object state. The shape of Xn is not taken into account. Values of Xn are read in sequential, column-major order.

Interpolation values are computed from the original values V used to train this interpolator object. The array returned will have the same shape as V, except the working dimension of V is replaced with n interpolated values, n = Xn.S.NumberOfElements. The 'working dimension' index of V is 1 if V is a row vector, 0 otherwise.

[ILNumerics Interpolation Toolbox]

Examples

// Define some sample points as a function: f(x) = sin(x);
Array<complex> X = linspace<complex>(-pi, pi, 10);
Array<complex> V = sin(X);

// Create Interpolator Object order 5
using (var interp = new CubicInterpolatorDouble(V, X)) 
{ 
    // Get some random scalar values
    complex val1 = (complex)interp.Apply(0.024);
    complex val2 = (complex)interp.Apply(-0.21);

    // Get 10 linear spaced values defined on range (-0.5, 1.25)
    Array<complex> valRange = interp.Apply(linspace<complex>(-0.5, 1.25, 10));

    // Get 30 interpolated values using Xn query points defined as array[3 x 2 x 5]
    Array<complex> Xn = counter(0.0, 0.1, 3, 2, 5);
    Array<complex> Vn = interp.Apply(Xn);
}

See Also

Reference