Convert 3D cartesian coordinates to cylindrical coordinates. More...
#include <vcsl_cylindrical_to_cartesian_3d.h>
Public Member Functions | |
virtual | ~vcsl_cylindrical_to_cartesian_3d () |
virtual bool | is_invertible (double time) const |
Is `this' invertible at time `time'?. | |
virtual bool | is_valid () const |
Is `this' correctly set ?. | |
virtual vnl_vector< double > | execute (const vnl_vector< double > &v, double time) const |
Image of `v' by `this'. | |
virtual vnl_vector< double > | inverse (const vnl_vector< double > &v, double time) const |
Image of `v' by the inverse of `this'. | |
vcl_vector< double > | beat () const |
Return the list of time clocks. | |
unsigned int | duration () const |
Return the time duration. | |
vcl_vector< vcsl_interpolator > | interpolators () const |
Return the list of interpolators. | |
bool | valid_time (double time) const |
Is `time' between the two time bounds ?. | |
int | matching_interval (double time) const |
Return the index of the beat inferior or equal to `time'. | |
void | set_beat (vcl_vector< double > const &new_beat) |
Set the list of time clocks. | |
void | set_interpolators (vcl_vector< vcsl_interpolator > const &i) |
Set the list of interpolators. | |
void | set_static () |
Empty the time clock and interpolators, thereby making the transf static. | |
double | lsi (double v0, double v1, int index, double time) const |
Linear interpolation on scalar values. | |
vnl_vector< double > | lvi (const vnl_vector< double > &v0, const vnl_vector< double > &v1, int index, double time) const |
Linear interpolation on vnl_vectors. | |
vnl_matrix< double > | lmi (const vnl_matrix< double > &m0, const vnl_matrix< double > &m1, int index, double time) const |
Linear interpolation on vnl_matrices. | |
vnl_quaternion< double > | lqi (const vnl_quaternion< double > &v0, const vnl_quaternion< double > &v1, int index, double time) const |
Linear interpolation on quaternions. | |
void | ref () |
void | unref () |
int | get_references () const |
bool | is_referenced () const |
Static Public Member Functions | |
static vcsl_cylindrical_to_cartesian_3d_sptr | instance () |
Return the reference to the unique vcsl_length object. | |
Protected Attributes | |
vcl_vector< double > | beat_ |
List of time clocks. | |
vcl_vector< vcsl_interpolator > | interpolator_ |
Private Member Functions | |
vcsl_cylindrical_to_cartesian_3d () |
Convert 3D cartesian coordinates to cylindrical coordinates.
Definition at line 20 of file vcsl_cylindrical_to_cartesian_3d.h.
vcsl_cylindrical_to_cartesian_3d::vcsl_cylindrical_to_cartesian_3d | ( | ) | [inline, private] |
Definition at line 28 of file vcsl_cylindrical_to_cartesian_3d.h.
virtual vcsl_cylindrical_to_cartesian_3d::~vcsl_cylindrical_to_cartesian_3d | ( | ) | [inline, virtual] |
Definition at line 32 of file vcsl_cylindrical_to_cartesian_3d.h.
vcl_vector<double> vcsl_spatial_transformation::beat | ( | ) | const [inline, inherited] |
Return the list of time clocks.
Definition at line 62 of file vcsl_spatial_transformation.h.
unsigned int vcsl_spatial_transformation::duration | ( | ) | const [inline, inherited] |
Return the time duration.
Definition at line 65 of file vcsl_spatial_transformation.h.
vnl_vector< double > vcsl_cylindrical_to_cartesian_3d::execute | ( | const vnl_vector< double > & | v, |
double | time | ||
) | const [virtual] |
Image of `v' by `this'.
REQUIRE: is_valid() REQUIRE: v.size()==3 Pure virtual function of vcsl_spatial_transformation
Implements vcsl_spatial_transformation.
Definition at line 24 of file vcsl_cylindrical_to_cartesian_3d.cxx.
vcsl_cylindrical_to_cartesian_3d_sptr vcsl_cylindrical_to_cartesian_3d::instance | ( | ) | [static] |
Return the reference to the unique vcsl_length object.
Definition at line 80 of file vcsl_cylindrical_to_cartesian_3d.cxx.
vcl_vector<vcsl_interpolator> vcsl_spatial_transformation::interpolators | ( | ) | const [inline, inherited] |
Return the list of interpolators.
Definition at line 68 of file vcsl_spatial_transformation.h.
vnl_vector< double > vcsl_cylindrical_to_cartesian_3d::inverse | ( | const vnl_vector< double > & | v, |
double | time | ||
) | const [virtual] |
Image of `v' by the inverse of `this'.
REQUIRE: is_valid() REQUIRE: is_invertible(time) REQUIRE: v.size()==3 Pure virtual function of vcsl_spatial_transformation
Implements vcsl_spatial_transformation.
Definition at line 54 of file vcsl_cylindrical_to_cartesian_3d.cxx.
bool vcsl_cylindrical_to_cartesian_3d::is_invertible | ( | double | time | ) | const [virtual] |
Is `this' invertible at time `time'?.
REQUIRE: valid_time(time) Pure virtual function of vcsl_spatial_transformation
Implements vcsl_spatial_transformation.
Definition at line 10 of file vcsl_cylindrical_to_cartesian_3d.cxx.
virtual bool vcsl_cylindrical_to_cartesian_3d::is_valid | ( | ) | const [inline, virtual] |
Is `this' correctly set ?.
Always true. Virtual function of vcsl_spatial_transformation
Reimplemented from vcsl_spatial_transformation.
Definition at line 46 of file vcsl_cylindrical_to_cartesian_3d.h.
vnl_matrix< double > vcsl_spatial_transformation::lmi | ( | const vnl_matrix< double > & | m0, |
const vnl_matrix< double > & | m1, | ||
int | index, | ||
double | time | ||
) | const [inherited] |
Linear interpolation on vnl_matrices.
Definition at line 91 of file vcsl_spatial_transformation.cxx.
vnl_quaternion< double > vcsl_spatial_transformation::lqi | ( | const vnl_quaternion< double > & | v0, |
const vnl_quaternion< double > & | v1, | ||
int | index, | ||
double | time | ||
) | const [inherited] |
Linear interpolation on quaternions.
Definition at line 118 of file vcsl_spatial_transformation.cxx.
double vcsl_spatial_transformation::lsi | ( | double | v0, |
double | v1, | ||
int | index, | ||
double | time | ||
) | const [inherited] |
Linear interpolation on scalar values.
Definition at line 50 of file vcsl_spatial_transformation.cxx.
vnl_vector< double > vcsl_spatial_transformation::lvi | ( | const vnl_vector< double > & | v0, |
const vnl_vector< double > & | v1, | ||
int | index, | ||
double | time | ||
) | const [inherited] |
Linear interpolation on vnl_vectors.
Definition at line 66 of file vcsl_spatial_transformation.cxx.
int vcsl_spatial_transformation::matching_interval | ( | double | time | ) | const [inherited] |
Return the index of the beat inferior or equal to `time'.
REQUIRE: valid_time(time)
Definition at line 19 of file vcsl_spatial_transformation.cxx.
void vcsl_spatial_transformation::set_beat | ( | vcl_vector< double > const & | new_beat | ) | [inline, inherited] |
Set the list of time clocks.
Definition at line 106 of file vcsl_spatial_transformation.h.
void vcsl_spatial_transformation::set_interpolators | ( | vcl_vector< vcsl_interpolator > const & | i | ) | [inline, inherited] |
Set the list of interpolators.
Definition at line 109 of file vcsl_spatial_transformation.h.
void vcsl_spatial_transformation::set_static | ( | ) | [inherited] |
Empty the time clock and interpolators, thereby making the transf static.
Definition at line 41 of file vcsl_spatial_transformation.cxx.
bool vcsl_spatial_transformation::valid_time | ( | double | time | ) | const [inherited] |
Is `time' between the two time bounds ?.
Definition at line 9 of file vcsl_spatial_transformation.cxx.
vcl_vector<double> vcsl_spatial_transformation::beat_ [protected, inherited] |
List of time clocks.
Definition at line 144 of file vcsl_spatial_transformation.h.
vcl_vector<vcsl_interpolator> vcsl_spatial_transformation::interpolator_ [protected, inherited] |
Definition at line 145 of file vcsl_spatial_transformation.h.