BSpline1dNd Class
Bspline knots and poles for 1d-to-Nd.
- The "pole" (aka control point) of this class is a block of
poleLength
numbers. - Derived classes (not this class) assign meaning such as x,y,z,w.
- for instance, an instance of this class with
poleLength===3
does not know if its poles are x,y,z or weighted 2D x,y,w
Methods
Name | Description | |
---|---|---|
constructor(numPoles: number, poleLength: number, order: number, knots: KnotVector): BSpline1dNd Protected | initialize arrays for given spline dimensions. | |
addKnot(knot: number, totalMultiplicity: number): boolean | Insert knot and resulting pole into the instance, optionally multiple times. | |
evaluateBasisFunctionsInSpan(spanIndex: number, spanFraction: number, f: Float64Array, df?: Float64Array, ddf?: Float64Array): boolean | Evaluate the order basis functions (and optionally one or two derivatives) at a given fractional position within indexed span. |
|
evaluateBuffersAtKnot(u: number, numDerivative: number0): void | Evaluate the function values and 1 or 2 derivatives into this.poleBuffer , this.poleBuffer1 and this.poleBuffer2 |
|
evaluateBuffersInSpan(spanIndex: number, spanFraction: number): void | * Evaluate the basis functions at spanIndex and fraction. | |
evaluateBuffersInSpan1(spanIndex: number, spanFraction: number): void | * Evaluate the basis functions and one derivative at spanIndex and fraction. | |
getPoint3dPole(i: number, result?: Point3d): undefined | Point3d | copy 3 values of pole i into a point. |
|
reverseInPlace(): void | Reverse the (blocked) poles (in this.packedData in place. |
|
spanFractionToKnot(span: number, localFraction: number): number | Map a span index and local fraction to knot value. | |
sumPoleBuffer1ForSpan(spanIndex: number): void | sum poles in poleBuffer1 at span spanIndex by the weights in the basisBuffer1 , i.e. |
|
sumPoleBuffer2ForSpan(spanIndex: number): void | sum poles in poleBuffer2 at span spanIndex by the weights in the basisBuffer2 , i.e. |
|
sumPoleBufferForSpan(spanIndex: number): void | sum poles in poleBuffer at span spanIndex by the weights in the basisBuffer |
|
testClosablePolygon(mode?: BSplineWrapMode): boolean | Test if the leading and trailing polygon coordinates are replicated in the manner of a "closed" bspline polygon which has been expanded | |
testCloseablePolygon(mode?: BSplineWrapMode): boolean | Test if the leading and trailing polygon coordinates are replicated in the manner of a "closed" bspline polygon which has been expanded | Deprecated |
create(numPoles: number, poleLength: number, order: number, knots: KnotVector): undefined | BSpline1dNd Static | create a 1Bspline1dNd` |
Properties
Name | Type | Description | |
---|---|---|---|
basisBuffer | Float64Array | preallocated array (length === order ) used as temporary in evaluations |
|
basisBuffer1 | Float64Array | preallocated array (length === order ) used as temporary in evaluations |
|
basisBuffer2 | Float64Array | preallocated array (length === order ) used as temporary in evaluations |
|
degree Accessor ReadOnly | number | (property accessor) Return the degree of the polynomials. | |
knots | KnotVector | knots of the bspline | |
numPoles Accessor ReadOnly | number | (property accessor) Return the number of poles | |
numSpan Accessor ReadOnly | number | (property accessor) Return the number of bezier spans (including null spans at multiple knots) | |
order Accessor ReadOnly | number | (property accessor) Return the number of order (one more than degree) of the polynomials | |
packedData | Float64Array | poles, packed in blocks of poleLength doubles. |
|
poleBuffer | Float64Array | preallocated array (length === poleLength ) used as temporary in evaluations |
|
poleBuffer1 | Float64Array | preallocated array (length === poleLength ) used as temporary in evaluations |
|
poleBuffer2 | Float64Array | preallocated array (length === poleLength ) used as temporary in evaluations |
|
poleLength | number | (property accessor) Return the number of numeric values per pole. |
Defined in
- bspline/BSpline1dNd.ts Line 20
Last Updated: 18 January, 2025
Found something wrong, missing, or unclear on this page?Raise an issue in our repo.