MayaFlux 0.2.0
Digital-First Multimedia Processing Framework
Loading...
Searching...
No Matches

◆ catmull_rom_spline()

Eigen::VectorXd MayaFlux::Kinesis::catmull_rom_spline ( const Eigen::MatrixXd &  control_points,
double  t,
double  tension = 0.5 
)

Catmull-Rom spline interpolation using Eigen matrices.

Parameters
control_points4xN matrix where columns are control points (p0, p1, p2, p3)
tParameter in [0,1]
tensionTension parameter (default 0.5)
Returns
Interpolated point as Nx1 vector

Definition at line 159 of file MotionCurves.cpp.

163{
164 if (control_points.cols() != 4) {
165 error<std::invalid_argument>(
166 Journal::Component::Kinesis,
167 Journal::Context::Runtime,
168 std::source_location::current(),
169 "Catmull-Rom interpolation requires 4 control points, but got {}",
170 control_points.cols());
171 }
172
173 Eigen::Matrix4d basis_matrix = BasisMatrices::catmull_rom_with_tension(tension);
174 Eigen::Vector4d t_vector(t * t * t, t * t, t, 1.0);
175 Eigen::Vector4d coeffs = basis_matrix * t_vector;
176
177 return control_points * coeffs;
178}

References MayaFlux::Kinesis::BasisMatrices::catmull_rom_with_tension(), MayaFlux::Journal::Kinesis, and MayaFlux::Journal::Runtime.

Referenced by interpolate().

+ Here is the call graph for this function:
+ Here is the caller graph for this function: