1 | |
---|
2 | #ifndef __Spline_h |
---|
3 | #define __Spline_h |
---|
4 | |
---|
5 | #include "vtkObject.h" |
---|
6 | |
---|
7 | class Spline |
---|
8 | { |
---|
9 | public: |
---|
10 | |
---|
11 | // Description: |
---|
12 | // Set/Get the parametric range. If not set, the range is determined |
---|
13 | // implicitly by keeping track of the (min,max) parameter values for |
---|
14 | // t. If set, the AddPoint() method will clamp the t value to lie |
---|
15 | // within the specified range. |
---|
16 | void SetParametricRange(double tMin, double tMax); |
---|
17 | void SetParametricRange(double tRange[2]) |
---|
18 | {this->SetParametricRange(tRange[0],tRange[1]);} |
---|
19 | void GetParametricRange(double tRange[2]) const; |
---|
20 | |
---|
21 | |
---|
22 | // Description: |
---|
23 | // Compute the coefficients for the spline. |
---|
24 | virtual void Compute () = 0; |
---|
25 | |
---|
26 | // Description: |
---|
27 | // Interpolate the value of the spline at parametric location of t. |
---|
28 | virtual double Evaluate (double t) = 0; |
---|
29 | |
---|
30 | // Description: |
---|
31 | // Return the number of points inserted thus far. |
---|
32 | int GetNumberOfPoints(); |
---|
33 | |
---|
34 | // Description: |
---|
35 | // Add a pair of points to be fit with the spline. |
---|
36 | void AddPoint (double t, double x); |
---|
37 | |
---|
38 | // Description: |
---|
39 | // Remove a point from the data to be fit with the spline. |
---|
40 | void RemovePoint (double t); |
---|
41 | |
---|
42 | // Description: |
---|
43 | // Remove all points from the data. |
---|
44 | void RemoveAllPoints (); |
---|
45 | |
---|
46 | |
---|
47 | |
---|
48 | protected: |
---|
49 | Spline(); |
---|
50 | ~Spline(); |
---|
51 | |
---|
52 | unsigned long ComputeTime; |
---|
53 | // Description: |
---|
54 | // Set/Get ClampValue. If On, results of the interpolation will be |
---|
55 | // clamped to the min/max of the input data. |
---|
56 | int ClampValue; |
---|
57 | double *Intervals; |
---|
58 | double *Coefficients; |
---|
59 | int LeftConstraint; |
---|
60 | // Description: |
---|
61 | // The values of the derivative on the left and right sides. The value |
---|
62 | // is used only if the left(right) constraint is type 1-3. |
---|
63 | double LeftValue; |
---|
64 | // Description: |
---|
65 | // Set the type of constraint of the left(right) end points. Four |
---|
66 | // constraints are available: |
---|
67 | // |
---|
68 | // 0: the first derivative at left(right) most point is determined |
---|
69 | // from the line defined from the first(last) two points. |
---|
70 | // |
---|
71 | // 1: the first derivative at left(right) most point is set to |
---|
72 | // Left(Right)Value. |
---|
73 | // |
---|
74 | // 2: the second derivative at left(right) most point is set to |
---|
75 | // Left(Right)Value. |
---|
76 | // |
---|
77 | // 3: the second derivative at left(right)most points is Left(Right)Value |
---|
78 | // times second derivative at first interior point. |
---|
79 | int RightConstraint; |
---|
80 | double RightValue; |
---|
81 | vtkPiecewiseFunction *PiecewiseFunction; |
---|
82 | // Description: |
---|
83 | // Control whether the spline is open or closed. A closed spline forms |
---|
84 | // a continuous loop: the first and last points are the same, and |
---|
85 | // derivatives are continuous. |
---|
86 | |
---|
87 | int Closed; |
---|
88 | |
---|
89 | // Explicitly specify the parametric range. |
---|
90 | double ParametricRange[2]; |
---|
91 | |
---|
92 | // Helper methods |
---|
93 | double ComputeLeftDerivative(); |
---|
94 | double ComputeRightDerivative(); |
---|
95 | int FindIndex(int size, double t); |
---|
96 | |
---|
97 | private: |
---|
98 | Spline(const Spline&); // Not implemented. |
---|
99 | void operator=(const Spline&); // Not implemented. |
---|
100 | }; |
---|
101 | |
---|
102 | #endif |
---|