public abstract class BSpline extends Object implements Serializable, Cloneable
B-splines provide a particularly convenient and suitable basis for a given class of smooth ppoly functions. Such a class is specified by giving its breakpoint sequence, its order k, and the required smoothness across each of the interior breakpoints. The corresponding B-spline basis is specified by giving its knot sequence t∈RM. The specification rule is as follows: If the class is to have all derivatives up to and including the j-th derivative continuous across the interior breakpoint ξi, then the number ξi should occur k - j - 1 times in the knot sequence. Assuming that ξ1 and ξn are the endpoints of the interval of interest, choose the first k knots equal to ξ1 and the last k knots equal to ξn. This can be done because the B-splines are defined to be right continuous near ξ1 and left continuous near ξn.
When the above construction is completed, a knot sequence t of length M is generated, and there are m: = M-k B-splines of order k, for example B0,...,Bm−1, spanning the ppoly functions on the interval with the indicated smoothness. That is, each ppoly function in this class has a unique representation p=a0B0+a1B1+...+am−1Bm−1 as a linear combination of B-splines. A B-spline is a particularly compact piecewise polynomial function. Bi is a nonnegative function that is nonzero only on the interval [ti,ti+k]. More precisely, the support of the i-th B-spline is [ti,ti+k]. No piecewise polynomial function in the same class (other than the zero function) has smaller support (i.e., vanishes on more intervals) than a B-spline. This makes B-splines particularly attractive basis functions since the influence of any particular B-spline coefficient extends only over a few intervals.
Modifier and Type | Field and Description |
---|---|
protected double[] |
coef
The B-spline coefficient array.
|
protected double[] |
knot
The knot array of length n + order, where n is the number
of coefficients in the B-spline.
|
protected int |
order
Order of the spline.
|
Constructor and Description |
---|
BSpline() |
Modifier and Type | Method and Description |
---|---|
double |
derivative(double x)
Returns the value of the first derivative of the B-spline at a point.
|
double[] |
derivative(double[] x,
int ideriv)
Returns the value of the derivative of the B-spline at each point of an
array.
|
double |
derivative(double x,
int ideriv)
Returns the value of the derivative of the B-spline at a point.
|
double[] |
getKnots()
Returns a copy of the knot sequence.
|
Spline |
getSpline()
Returns a
Spline representation of the B-spline. |
double |
integral(double a,
double b)
Returns the value of an integral of the B-spline.
|
double |
value(double x)
Returns the value of the B-spline at a point.
|
double[] |
value(double[] x)
Returns the value of the B-spline at each point of an array.
|
protected int order
protected double[] knot
protected double[] coef
public double value(double x)
x
- a double
specifying the point at which the
B-spline is to be evaluateddouble
giving the value of the B-spline at the
point xpublic double derivative(double x)
x
- a double
specifying a point at which the
derivative is to be evaluateddouble
containing the value of the first
derivative of the B-spline at the point x
public double derivative(double x, int ideriv)
x
- a double
specifying a point at which the
derivative is to be evaluatedideriv
- an int
specifying the derivative to be
computed. If zero, the function value is returned. If
one, the first derivative is returned, etc.double
containing the value of the derivative of
the B-spline at the point x
public double[] value(double[] x)
x
- a double
array of points at which the B-spline
is to be evaluateddouble
array containing the value of the B-spline
at each point of the array x
public double[] derivative(double[] x, int ideriv)
x
- a double
array of points at which the
derivative is to be evaluatedideriv
- an int
specifying the derivative to be
computed. If zero, the function value is returned. If
one, the first derivative is returned, etc.double
array containing the value of the
derivative the B-spline at each point of the array
x
public double[] getKnots()
double
array containing a copy of the knot
sequence.public double integral(double a, double b)
a
- a double
specifying the lower limit of
integrationb
- a double
specifying the upper limit of
integrationdouble
which specifies the B-spline integral
value from a
to b
public Spline getSpline()
Spline
representation of the B-spline.Spline
representation of the BSpline
Copyright © 2020 Rogue Wave Software. All rights reserved.