45 #include <pcl/registration/eigen.h>
49 namespace registration
57 template <
typename Po
intSourceT,
typename Po
intTargetT,
typename Scalar =
float>
61 using Matrix4 = Eigen::Matrix<Scalar, 4, 4>;
62 using VectorX = Eigen::Matrix<Scalar, Eigen::Dynamic, 1>;
63 using Vector4 = Eigen::Matrix<Scalar, 4, 1>;
65 using Ptr = shared_ptr<WarpPointRigid<PointSourceT, PointTargetT, Scalar> >;
66 using ConstPtr = shared_ptr<const WarpPointRigid<PointSourceT, PointTargetT, Scalar> >;
92 warpPoint (
const PointSourceT& pnt_in, PointSourceT& pnt_out)
const
void warpPoint(const PointSourceT &pnt_in, Vector4 &pnt_out) const
Warp a point given a transformation matrix.
Matrix4 transform_matrix_
WarpPointRigid(int nr_dim)
Constructor.
shared_ptr< WarpPointRigid< PointSourceT, PointTargetT, Scalar > > Ptr
void warpPoint(const PointSourceT &pnt_in, PointSourceT &pnt_out) const
Warp a point given a transformation matrix.
Eigen::Matrix< Scalar, 4, 4 > Matrix4
Eigen::Matrix< Scalar, 4, 1 > Vector4
virtual void setParam(const VectorX &p)=0
Set warp parameters.
const Matrix4 & getTransform() const
Get the Transform used.
virtual ~WarpPointRigid()
Destructor.
shared_ptr< const WarpPointRigid< PointSourceT, PointTargetT, Scalar > > ConstPtr
Eigen::Matrix< Scalar, Eigen::Dynamic, 1 > VectorX
int getDimension() const
Get the number of dimensions.
#define PCL_MAKE_ALIGNED_OPERATOR_NEW
Macro to signal a class requires a custom allocator.
Defines functions, macros and traits for allocating and using memory.
Defines all the PCL and non-PCL macros used.