CVR-Lib last update 20 Sep 2009

cvr::affineTransformation2D Class Reference
[Geometric Image Transformations]

Class affineTransformation2D. More...

#include <cvrAffineTransformation2D.h>

Inheritance diagram for cvr::affineTransformation2D:

Inheritance graph
[legend]
Collaboration diagram for cvr::affineTransformation2D:

Collaboration graph
[legend]

List of all members.

Classes

class  parameters
 The parameters for the class affineTransformation2D. More...

Public Member Functions

 affineTransformation2D ()
 affineTransformation2D (const parameters &par)
 affineTransformation2D (const affineTransformation2D &other)
virtual ~affineTransformation2D ()
template<class P >
bool apply (P &srcdest) const
template<class P >
bool apply (const P &src, P &dest) const
template<class P >
bool estimate (const std::vector< P > &setA, const std::vector< P > &setB)
template<class P >
bool estimateLLS (const std::vector< P > &setA, const std::vector< P > &setB)
template<class P >
bool estimateLLS (const ivector &selection, const std::vector< P > &setA, const std::vector< P > &setB)
int dof () const
void generateMatrix (fmatrix &mat) const
void decompose (float &theta, float &phi, float &lambda1, float &lambda2, float &tx, float &ty) const
fmatrix generateMatrix () const
affineTransformation2Dcopy (const affineTransformation2D &other)
affineTransformation2Doperator= (const affineTransformation2D &other)
virtual const std::string & name () const
virtual affineTransformation2Dclone () const
virtual affineTransformation2DnewInstance () const
const parametersgetParameters () const
bool updateParameters ()

Protected Member Functions

parametersgetRWParameters ()

Protected Attributes

fpoint trans_
float a00_
float a01_
float a10_
float a11_
linearLeastSquares lls_


Detailed Description

Class affineTransformation2D.

The affine transformation for 2D spaces performs a planar modification of points in which only rotation, translation, (anisotropic) scaling and sheer are applied.

With homogeneous coordinates, the affine transformation can be stated as

\[ \begin{bmatrix} x'\\y'\\1 \end{bmatrix} = \begin{bmatrix} a_{00} & a_{01} & t_x \\ a_{10} & a_{11} & t_y \\ 0 & 0 & 1 \end{bmatrix} \begin{bmatrix} x\\y\\1 \end{bmatrix} \]

This class transforms points only, and therefore is not intended for images, in which case you should use cvr::matrixTransform. You can however obtain from this class the matrix used by cvr::matrixTransform::parameters to generate the same results.

Most apply methods are templates of a point type P, i.e. the type P is usually a container that can be accessed with the operator[], like the types cvr::point<T>, cvr::vector<T>.

See also:
affineTransformation2D::parameters

euclideanTransformation2D

euclideanTransformation3D

affineTransformation2D

projectiveTransformation2D


Constructor & Destructor Documentation

cvr::affineTransformation2D::affineTransformation2D (  ) 

Default constructor.

cvr::affineTransformation2D::affineTransformation2D ( const parameters par  ) 

Construct a functor using the given parameters.

cvr::affineTransformation2D::affineTransformation2D ( const affineTransformation2D other  ) 

Copy constructor.

Parameters:
other the object to be copied

virtual cvr::affineTransformation2D::~affineTransformation2D (  )  [virtual]

Destructor.


Member Function Documentation

template<class P >
bool cvr::affineTransformation2D::apply ( const P &  src,
P &  dest 
) const [inline]

Transform the point src and write the transformation on the dest point.

Parameters:
src point<T> with the source data.
dest point<T> where the result will be left.
Returns:
true if apply successful or false otherwise.

template<class P >
bool cvr::affineTransformation2D::apply ( P &  srcdest  )  const [inline]

Transform the given point.

Parameters:
srcdest point<T> with the source data. The result will be left here too.
Returns:
true if apply successful or false otherwise.

virtual affineTransformation2D* cvr::affineTransformation2D::clone (  )  const [virtual]

Returns a pointer to a clone of this functor.

Implements cvr::functor.

affineTransformation2D& cvr::affineTransformation2D::copy ( const affineTransformation2D other  ) 

Copy data of "other" functor.

Parameters:
other the functor to be copied
Returns:
a reference to this functor object

void cvr::affineTransformation2D::decompose ( float &  theta,
float &  phi,
float &  lambda1,
float &  lambda2,
float &  tx,
float &  ty 
) const

Decompose matrix.

This method decomposes the computed matrix as a series of simpler processes.

The affine transformation matrix H is interpreted as the 3x3 matrix

\[ H = \begin{bmatrix} A & t \\ 0^T & 1 \end{bmatrix} \]

where the 2x2 submatrix A can be decomposed as a series of pure rotations, and asymmetrical scalations, as follow:

\[ A = R(\theta) R(-\phi) D R(\phi) \]

with

\[ D = \begin{bmatrix} \lambda_1 & 0 \\ 0 & \lambda_2 \end{bmatrix} \]

int cvr::affineTransformation2D::dof (  )  const

Degrees of freedom of the transformation.

Usually this means the minimal number of parameters with which the transforamtion matrix can be generated.

template<class P >
bool cvr::affineTransformation2D::estimate ( const std::vector< P > &  setA,
const std::vector< P > &  setB 
) [inline]

Estimate a transformation that maps the first set of points into the second set of points.

The resulting estimation is left in the parameters.

This method assumes that the corresponding point to setA[idx] is stored in setB[idx].

Only the first dof()/2 correspondences will be used for the estimation, and you need at least dof()/2 elements for the transformation to be computed.

template<class P >
bool cvr::affineTransformation2D::estimateLLS ( const ivector selection,
const std::vector< P > &  setA,
const std::vector< P > &  setB 
) [inline]

Do a linear least squares error minimization for a transformation that maps the first set of points into the second set of points.

The resulting estimation is left in the parameters.

This method assumes that the corresponding point to setA[idx] is stored in setB[idx].

For the LLS to be computed, more than dof()/2 correspondences are necessary for the estimation.

For the estimation, just the points with the indices specified in selection are given.

Returns:
true if successful, false otherwise

template<class P >
bool cvr::affineTransformation2D::estimateLLS ( const std::vector< P > &  setA,
const std::vector< P > &  setB 
) [inline]

Do a linear least squares error minimization for a transformation that maps the first set of points into the second set of points.

The resulting estimation is left in the parameters.

This method assumes that the corresponding point to setA[idx] is stored in setB[idx].

For the LLS to be computed, more than dof()/2 correspondences are necessary for the estimation.

fmatrix cvr::affineTransformation2D::generateMatrix (  )  const

Generate the transformation matrix that would be required by cvr::matrixTransform to generate the same coordinate transformation.

The result is, so to speak, the matrix representation of the parameters.

void cvr::affineTransformation2D::generateMatrix ( fmatrix mat  )  const

Generate the transformation matrix that would be required by cvr::matrixTransform to generate the same coordinate transformation.

The result is, so to speak, the matrix representation of the parameters.

This method is provided to keep consistency with other matrix transformation functors, since in this case, the conversion between the parameters and the matrix is completely straightforward.

Parameters:
mat matrix container of the result.

const parameters& cvr::affineTransformation2D::getParameters (  )  const

Returns used parameters.

Reimplemented from cvr::parametersManager.

parameters& cvr::affineTransformation2D::getRWParameters (  )  [protected]

Returns used parameters.

virtual const std::string& cvr::affineTransformation2D::name (  )  const [virtual]

Returns the complete name of the functor class.

Implements cvr::functor.

virtual affineTransformation2D* cvr::affineTransformation2D::newInstance (  )  const [virtual]

Returns a pointer to a new instance of this functor.

Implements cvr::functor.

affineTransformation2D& cvr::affineTransformation2D::operator= ( const affineTransformation2D other  ) 

Alias for copy member.

Parameters:
other the functor to be copied
Returns:
a reference to this functor object

bool cvr::affineTransformation2D::updateParameters (  )  [virtual]

Update parameters.

Reimplemented from cvr::parametersManager.


Member Data Documentation

Shadow of matrix element.

Shadow of matrix element.

Shadow of matrix element.

Shadow of matrix element.

Singular value decomposition.

Convenience method to avoid the SVD to be present in the template implementation

Shadow of the translation point.


The documentation for this class was generated from the following file:

Generated on Sun Sep 20 22:08:56 2009 for CVR-Lib by Doxygen 1.5.8