Represents a sequence of transpositions (row/column interchange). More...
#include <Transpositions.h>
Public Types | |
typedef TranspositionsBase < Transpositions > | Base |
typedef Traits::IndicesType | IndicesType |
typedef IndicesType::Scalar | Index |
Public Member Functions | |
Transpositions () | |
template<typename OtherDerived > | |
Transpositions (const TranspositionsBase< OtherDerived > &other) | |
Transpositions (const Transpositions &other) | |
template<typename Other > | |
Transpositions (const MatrixBase< Other > &indices) | |
template<typename OtherDerived > | |
Transpositions & | operator= (const TranspositionsBase< OtherDerived > &other) |
Transpositions & | operator= (const Transpositions &other) |
Transpositions (Index size) | |
const IndicesType & | indices () const |
IndicesType & | indices () |
Protected Attributes | |
IndicesType | m_indices |
Represents a sequence of transpositions (row/column interchange).
SizeAtCompileTime | the number of transpositions, or Dynamic | |
MaxSizeAtCompileTime | the maximum number of transpositions, or Dynamic. This optional parameter defaults to SizeAtCompileTime. Most of the time, you should not have to specify it. |
This class represents a permutation transformation as a sequence of n transpositions . It is internally stored as a vector of integers indices
. Each transposition applied on the left of a matrix ( ) interchanges the rows i
and indices
[i] of the matrix M
. A transposition applied on the right (e.g., ) yields a column interchange.
Compared to the class PermutationMatrix, such a sequence of transpositions is what is computed during a decomposition with pivoting, and it is faster when applying the permutation in-place.
To apply a sequence of transpositions to a matrix, simply use the operator * as in the following example:
Transpositions tr; MatrixXf mat; mat = tr * mat;
In this example, we detect that the matrix appears on both side, and so the transpositions are applied in-place without any temporary or extra copy.
typedef TranspositionsBase<Transpositions> Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::Base |
typedef IndicesType::Scalar Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::Index |
typedef Traits::IndicesType Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::IndicesType |
Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::Transpositions | ( | ) | [inline] |
Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::Transpositions | ( | const TranspositionsBase< OtherDerived > & | other | ) | [inline] |
Copy constructor.
Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::Transpositions | ( | const Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType > & | other | ) | [inline] |
Standard copy constructor. Defined only to prevent a default copy constructor from hiding the other templated constructor
Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::Transpositions | ( | const MatrixBase< Other > & | indices | ) | [inline, explicit] |
Generic constructor from expression of the transposition indices.
Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::Transpositions | ( | Index | size | ) | [inline] |
Constructs an uninitialized permutation matrix of given size.
const IndicesType& Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::indices | ( | ) | const [inline] |
const version of indices().
Reimplemented from TranspositionsBase< Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType > >.
IndicesType& Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::indices | ( | ) | [inline] |
Reimplemented from TranspositionsBase< Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType > >.
Transpositions& Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::operator= | ( | const TranspositionsBase< OtherDerived > & | other | ) | [inline] |
Copies the other transpositions into *this
Reimplemented from TranspositionsBase< Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType > >.
Transpositions& Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::operator= | ( | const Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType > & | other | ) | [inline] |
This is a special case of the templated operator=. Its purpose is to prevent a default operator= from hiding the templated operator=.
IndicesType Transpositions< SizeAtCompileTime, MaxSizeAtCompileTime, IndexType >::m_indices [protected] |