|
static | interpolate ($source,... $args) |
| Interpolate. More...
|
|
static | getSplinePoints ($source, array $args=[]) |
| Determine where the input $source argument is a callback function, a set of arrays, or neither. More...
|
|
static | validateSpline (array $points, $degree=2) |
| Validate that there are enough input arrays (points), that each point array has precisely three numbers, and that no two points share the same first number (x-component) More...
|
|
static | getPoints ($source, array $args=[]) |
| Determine where the input $source argument is a callback function, a set of arrays, or neither. More...
|
|
static | validate (array $points, $degree=2) |
| Validate that there are enough input arrays (points), that each point array has precisely two numbers, and that no two points share the same first number (x-component) More...
|
|
Clamped Cubic Spline Interpolating Polyonomial.
In numerical analysis, cubic splines are used for polynomial interpolation.
A cubic spline is a spline constructed of piecewise third-order polynomials which pass through a set of m control points." In the case of the Clamped cubic spline, the first derivative of piecewise polynomial is set to equal the first derivative of our input at the endpoints.
Cubic spline interpolation belongs to a collection of techniques that interpolate a function or a set of values, producing a continuous polynomial. In the case of the cubic spline, a piecewise function (polynomial) is produced. We can either directly supply a set of inputs and their corresponding outputs for said function, or if we explicitly know the function, we can define it as a callback function and then generate a set of points by evaluating that function at n points between a start and end point. We then use these values to interpolate our piecewise polynomial.
https://en.wikipedia.org/wiki/Spline_interpolation http://mathworld.wolfram.com/CubicSpline.html
static MathPHP\NumericalAnalysis\Interpolation\ClampedCubicSpline::getSplinePoints |
( |
|
$source, |
|
|
array |
$args = [] |
|
) |
| |
|
static |
Determine where the input $source argument is a callback function, a set of arrays, or neither.
If $source is a callback function, run it through the functionToPoints() method with the input $args, and set $points to output array. If $source is a set of arrays, simply set $points to $source. If $source is neither, throw an Exception.
- Todo:
Add method to verify function is continuous on our interval
Add method to verify input arguments are valid. Verify $start and $end are numbers, $end > $start, and $points is an integer > 1
- Parameters
-
callable | array | $source | The source of our approximation. Should be either a callback function or a set of arrays. |
array | $args | The arguments of our callback function: derivative, start, end, and n. Example: [$derivative, 0, 8, 5]. If $source is a set of arrays, $args will default to []. |
- Returns
- array
- Exceptions
-