Go to the documentation of this file.
11 #ifndef EIGEN_PERMUTATIONMATRIX_H
12 #define EIGEN_PERMUTATIONMATRIX_H
45 template<
typename Derived>
52 #ifndef EIGEN_PARSED_BY_DOXYGEN
73 template<
typename OtherDerived>
81 template<
typename OtherDerived>
90 #ifndef EIGEN_PARSED_BY_DOXYGEN
110 #ifndef EIGEN_PARSED_BY_DOXYGEN
111 template<
typename DenseDerived>
208 #ifndef EIGEN_PARSED_BY_DOXYGEN
210 template<
typename OtherDerived>
215 template<
typename Lhs,
typename Rhs>
219 for (
Index i=0; i<
rows();++i)
indices().coeffRef(i) = lhs.indices().coeff(rhs.indices().coeff(i));
229 template<
typename Other>
237 template<
typename Other>
245 template<
typename Other>
friend
263 while(r<
n && mask[r]) r++;
283 template<
int SizeAtCompileTime,
int MaxSizeAtCompileTime,
typename _StorageIndex>
285 :
traits<Matrix<_StorageIndex,SizeAtCompileTime,SizeAtCompileTime,0,MaxSizeAtCompileTime,MaxSizeAtCompileTime> >
307 template<
int SizeAtCompileTime,
int MaxSizeAtCompileTime,
typename _StorageIndex>
316 #ifndef EIGEN_PARSED_BY_DOXYGEN
332 template<
typename OtherDerived>
336 #ifndef EIGEN_PARSED_BY_DOXYGEN
349 template<
typename Other>
354 template<
typename Other>
362 template<
typename Other>
370 template<
typename Other>
376 #ifndef EIGEN_PARSED_BY_DOXYGEN
395 #ifndef EIGEN_PARSED_BY_DOXYGEN
396 template<
typename Other>
403 m_indices.coeffRef(other.derived().nestedExpression().indices().
coeff(i)) = i;
405 template<
typename Lhs,
typename Rhs>
420 template<
int SizeAtCompileTime,
int MaxSizeAtCompileTime,
typename _StorageIndex,
int _PacketAccess>
422 :
traits<Matrix<_StorageIndex,SizeAtCompileTime,SizeAtCompileTime,0,MaxSizeAtCompileTime,MaxSizeAtCompileTime> >
431 template<
int SizeAtCompileTime,
int MaxSizeAtCompileTime,
typename _StorageIndex,
int _PacketAccess>
433 :
public PermutationBase<Map<PermutationMatrix<SizeAtCompileTime, MaxSizeAtCompileTime, _StorageIndex>,_PacketAccess> >
439 #ifndef EIGEN_PARSED_BY_DOXYGEN
445 : m_indices(indicesPtr)
449 : m_indices(indicesPtr,
size)
453 template<
typename Other>
455 {
return Base::operator=(other.
derived()); }
458 template<
typename Other>
460 {
return Base::operator=(tr.
derived()); }
462 #ifndef EIGEN_PARSED_BY_DOXYGEN
468 m_indices = other.m_indices;
485 template<
typename _IndicesType>
493 RowsAtCompileTime = _IndicesType::SizeAtCompileTime,
494 ColsAtCompileTime = _IndicesType::SizeAtCompileTime,
495 MaxRowsAtCompileTime = IndicesType::MaxSizeAtCompileTime,
496 MaxColsAtCompileTime = IndicesType::MaxSizeAtCompileTime,
513 template<
typename _IndicesType>
520 #ifndef EIGEN_PARSED_BY_DOXYGEN
540 template<
typename MatrixDerived,
typename PermutationDerived>
552 template<
typename PermutationDerived,
typename MatrixDerived>
554 const Product<PermutationDerived, MatrixDerived, AliasFreeProduct>
563 template<
typename PermutationType>
565 :
public EigenBase<Inverse<PermutationType> >
575 #ifndef EIGEN_PARSED_BY_DOXYGEN
578 RowsAtCompileTime = PermTraits::RowsAtCompileTime,
579 ColsAtCompileTime = PermTraits::ColsAtCompileTime,
580 MaxRowsAtCompileTime = PermTraits::MaxRowsAtCompileTime,
581 MaxColsAtCompileTime = PermTraits::MaxColsAtCompileTime
585 #ifndef EIGEN_PARSED_BY_DOXYGEN
586 template<
typename DenseDerived>
590 for (
Index i=0; i<derived().rows();++i)
591 other.coeffRef(i, derived().nestedExpression().indices().coeff(i)) =
typename DenseDerived::Scalar(1);
602 template<
typename OtherDerived>
friend
611 template<
typename OtherDerived>
619 template<
typename Derived>
633 #endif // EIGEN_PERMUTATIONMATRIX_H
PermutationStorage StorageKind
Expression of the inverse of another expression.
Inverse< PermutationType > InverseType
EIGEN_DEVICE_FUNC Derived & setZero()
Derived & operator=(const PermutationBase &other)
EIGEN_DEVICE_FUNC Derived & derived()
PermutationStorage StorageKind
Matrix< _StorageIndex, SizeAtCompileTime, 1, 0, MaxSizeAtCompileTime, 1 > IndicesType
const friend Product< OtherDerived, InverseType, AliasFreeProduct > operator*(const MatrixBase< OtherDerived > &matrix, const InverseType &trPerm)
const Product< InverseType, OtherDerived, AliasFreeProduct > operator*(const MatrixBase< OtherDerived > &matrix) const
PermutationMatrix(internal::PermPermProduct_t, const Lhs &lhs, const Rhs &rhs)
Eigen::Index Index
The interface type of indices.
const IndicesType & indices() const
PermutationMatrix< IndicesType::SizeAtCompileTime, IndicesType::MaxSizeAtCompileTime, StorageIndex > PlainPermutationType
Matrix< StorageIndex, RowsAtCompileTime, ColsAtCompileTime, 0, MaxRowsAtCompileTime, MaxColsAtCompileTime > DenseMatrixType
Traits::StorageIndex StorageIndex
InverseReturnType transpose() const
PermutationMatrix(const TranspositionsBase< Other > &tr)
const StorageIndex & coeff(Index i) const
Map & operator=(const PermutationBase< Other > &other)
IndicesType::Scalar StorageIndex
Traits::IndicesType IndicesType
void resize(Index newSize)
internal::traits< Map > Traits
Map & operator=(const TranspositionsBase< Other > &tr)
const IndicesType & indices() const
PermutationMatrix(const PermutationMatrix &other)
void setIdentity(Index newSize)
Map< Matrix< T, Dynamic, Dynamic, ColMajor >, 0, OuterStride<> > matrix(T *data, int rows, int cols, int stride)
DenseMatrixType toDenseMatrix() const
Traits::StorageIndex StorageIndex
const EIGEN_DEVICE_FUNC Product< MatrixDerived, PermutationDerived, AliasFreeProduct > operator*(const MatrixBase< MatrixDerived > &matrix, const PermutationBase< PermutationDerived > &permutation)
#define eigen_internal_assert(x)
EigenBase< Derived > Base
const PermutationWrapper< const Derived > asPermutation() const
PermutationBase< PermutationWrapper > Base
Derived & operator=(const PermutationBase< OtherDerived > &other)
Derived & applyTranspositionOnTheLeft(Index i, Index j)
PermutationWrapper(const IndicesType &indices)
Class to view a vector of integers as a permutation matrix.
PermutationBase< Map > Base
PlainPermutationType eval() const
void evalTo(MatrixBase< DenseDerived > &other) const
PermutationType::PlainPermutationType PlainPermutationType
Traits::IndicesType IndicesType
const IndicesType & indices() const
Map< const Matrix< _StorageIndex, SizeAtCompileTime, 1, 0, MaxSizeAtCompileTime, 1 >, _PacketAccess > IndicesType
PermutationMatrix & operator=(const TranspositionsBase< Other > &tr)
PlainPermutationType operator*(const InverseImpl< Other, PermutationStorage > &other) const
void assignTranspose(const PermutationBase< OtherDerived > &other)
void evalTo(MatrixBase< DenseDerived > &other) const
Expression of the product of two arbitrary matrices or vectors.
InverseReturnType inverse() const
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Scalar & coeffRef(Index rowId, Index colId)
_StorageIndex StorageIndex
A matrix or vector expression mapping an existing array of data.
Scalar coeff(Index row, Index col) const
internal::traits< PermutationType > PermTraits
Map(const StorageIndex *indicesPtr, Index size)
DenseMatrixType toDenseMatrix() const
PermutationMatrix & operator=(const PermutationMatrix &other)
void assignProduct(const Lhs &lhs, const Rhs &rhs)
Index determinant() const
const internal::remove_all< typename IndicesType::Nested >::type & indices() const
PermutationStorage StorageKind
PermutationMatrix(Index size)
PermutationMatrix(const InverseImpl< Other, PermutationStorage > &other)
internal::traits< Derived > Traits
PermutationMatrix & operator=(const PermutationBase< Other > &other)
Base class for permutations.
PlainPermutationType operator*(const PermutationBase< Other > &other) const
PermutationBase< PermutationMatrix > Base
friend PlainPermutationType operator*(const InverseImpl< Other, PermutationStorage > &other, const PermutationBase &perm)
_StorageIndex StorageIndex
Map(const StorageIndex *indicesPtr)
IndicesType::Nested m_indices
static constexpr size_t size(Tuple< Args... > &)
Provides access to the number of elements in a tuple as a compile-time constant expression.
The matrix class, also used for vectors and row-vectors.
Derived & applyTranspositionOnTheRight(Index i, Index j)
Base class for all dense matrices, vectors, and expressions.
EIGEN_DEVICE_FUNC Derived & derived()
Traits::IndicesType IndicesType
const typedef PermutationMatrix & Nested
internal::traits< PermutationMatrix > Traits
int EIGEN_BLAS_FUNC() swap(int *n, RealScalar *px, int *incx, RealScalar *py, int *incy)
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
PlainPermutationType PlainObject
Map & operator=(const Map &other)
PermutationMatrix(const MatrixBase< Other > &indices)
Derived & operator=(const TranspositionsBase< OtherDerived > &tr)
internal::traits< PermutationWrapper > Traits
_IndicesType::Scalar StorageIndex
PermutationMatrix(const PermutationBase< OtherDerived > &other)
PermutationType::DenseMatrixType DenseMatrixType
Traits::IndicesType IndicesType
Inverse< Derived > InverseReturnType
control_box_rst
Author(s): Christoph Rösmann
autogenerated on Wed Mar 2 2022 00:06:03