WPILibC++ 2023.4.3-108-ge5452e3
SparsePermutation.h
Go to the documentation of this file.
1// This file is part of Eigen, a lightweight C++ template library
2// for linear algebra.
3//
4// Copyright (C) 2012 Gael Guennebaud <gael.guennebaud@inria.fr>
5//
6// This Source Code Form is subject to the terms of the Mozilla
7// Public License v. 2.0. If a copy of the MPL was not distributed
8// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
9
10#ifndef EIGEN_SPARSE_PERMUTATION_H
11#define EIGEN_SPARSE_PERMUTATION_H
12
13// This file implements sparse * permutation products
14
15namespace Eigen {
16
17namespace internal {
18
19template<typename ExpressionType, int Side, bool Transposed>
20struct permutation_matrix_product<ExpressionType, Side, Transposed, SparseShape>
21{
24
25 typedef typename MatrixTypeCleaned::Scalar Scalar;
26 typedef typename MatrixTypeCleaned::StorageIndex StorageIndex;
27
28 enum {
29 SrcStorageOrder = MatrixTypeCleaned::Flags&RowMajorBit ? RowMajor : ColMajor,
30 MoveOuter = SrcStorageOrder==RowMajor ? Side==OnTheLeft : Side==OnTheRight
31 };
32
33 typedef typename internal::conditional<MoveOuter,
36
37 template<typename Dest,typename PermutationType>
38 static inline void run(Dest& dst, const PermutationType& perm, const ExpressionType& xpr)
39 {
40 MatrixType mat(xpr);
41 if(MoveOuter)
42 {
43 SparseMatrix<Scalar,SrcStorageOrder,StorageIndex> tmp(mat.rows(), mat.cols());
44 Matrix<StorageIndex,Dynamic,1> sizes(mat.outerSize());
45 for(Index j=0; j<mat.outerSize(); ++j)
46 {
47 Index jp = perm.indices().coeff(j);
48 sizes[((Side==OnTheLeft) ^ Transposed) ? jp : j] = StorageIndex(mat.innerVector(((Side==OnTheRight) ^ Transposed) ? jp : j).nonZeros());
49 }
50 tmp.reserve(sizes);
51 for(Index j=0; j<mat.outerSize(); ++j)
52 {
53 Index jp = perm.indices().coeff(j);
54 Index jsrc = ((Side==OnTheRight) ^ Transposed) ? jp : j;
55 Index jdst = ((Side==OnTheLeft) ^ Transposed) ? jp : j;
56 for(typename MatrixTypeCleaned::InnerIterator it(mat,jsrc); it; ++it)
57 tmp.insertByOuterInner(jdst,it.index()) = it.value();
58 }
59 dst = tmp;
60 }
61 else
62 {
63 SparseMatrix<Scalar,int(SrcStorageOrder)==RowMajor?ColMajor:RowMajor,StorageIndex> tmp(mat.rows(), mat.cols());
64 Matrix<StorageIndex,Dynamic,1> sizes(tmp.outerSize());
65 sizes.setZero();
67 if((Side==OnTheLeft) ^ Transposed)
68 perm_cpy = perm;
69 else
70 perm_cpy = perm.transpose();
71
72 for(Index j=0; j<mat.outerSize(); ++j)
73 for(typename MatrixTypeCleaned::InnerIterator it(mat,j); it; ++it)
74 sizes[perm_cpy.indices().coeff(it.index())]++;
75 tmp.reserve(sizes);
76 for(Index j=0; j<mat.outerSize(); ++j)
77 for(typename MatrixTypeCleaned::InnerIterator it(mat,j); it; ++it)
78 tmp.insertByOuterInner(perm_cpy.indices().coeff(it.index()),j) = it.value();
79 dst = tmp;
80 }
81 }
82};
83
84}
85
86namespace internal {
87
88template <int ProductTag> struct product_promote_storage_type<Sparse, PermutationStorage, ProductTag> { typedef Sparse ret; };
89template <int ProductTag> struct product_promote_storage_type<PermutationStorage, Sparse, ProductTag> { typedef Sparse ret; };
90
91// TODO, the following two overloads are only needed to define the right temporary type through
92// typename traits<permutation_sparse_matrix_product<Rhs,Lhs,OnTheRight,false> >::ReturnType
93// whereas it should be correctly handled by traits<Product<> >::PlainObject
94
95template<typename Lhs, typename Rhs, int ProductTag>
97 : public evaluator<typename permutation_matrix_product<Rhs,OnTheLeft,false,SparseShape>::ReturnType>
98{
102
103 enum {
104 Flags = Base::Flags | EvalBeforeNestingBit
105 };
106
107 explicit product_evaluator(const XprType& xpr)
108 : m_result(xpr.rows(), xpr.cols())
109 {
110 ::new (static_cast<Base*>(this)) Base(m_result);
112 }
113
114protected:
116};
117
118template<typename Lhs, typename Rhs, int ProductTag>
120 : public evaluator<typename permutation_matrix_product<Lhs,OnTheRight,false,SparseShape>::ReturnType>
121{
125
126 enum {
127 Flags = Base::Flags | EvalBeforeNestingBit
128 };
129
130 explicit product_evaluator(const XprType& xpr)
131 : m_result(xpr.rows(), xpr.cols())
132 {
133 ::new (static_cast<Base*>(this)) Base(m_result);
135 }
136
137protected:
139};
140
141} // end namespace internal
142
143/** \returns the matrix with the permutation applied to the columns
144 */
145template<typename SparseDerived, typename PermDerived>
149
150/** \returns the matrix with the permutation applied to the rows
151 */
152template<typename SparseDerived, typename PermDerived>
153inline const Product<PermDerived, SparseDerived, AliasFreeProduct>
156
157
158/** \returns the matrix with the inverse permutation applied to the columns.
159 */
160template<typename SparseDerived, typename PermutationType>
161inline const Product<SparseDerived, Inverse<PermutationType>, AliasFreeProduct>
163{
165}
166
167/** \returns the matrix with the inverse permutation applied to the rows.
168 */
169template<typename SparseDerived, typename PermutationType>
170inline const Product<Inverse<PermutationType>, SparseDerived, AliasFreeProduct>
172{
173 return Product<Inverse<PermutationType>, SparseDerived, AliasFreeProduct>(tperm.derived(), matrix.derived());
174}
175
176} // end namespace Eigen
177
178#endif // EIGEN_SPARSE_SELFADJOINTVIEW_H
Base class for permutations.
Definition: PermutationMatrix.h:47
InverseReturnType transpose() const
Definition: PermutationMatrix.h:191
EIGEN_DEVICE_FUNC Derived & derived()
Definition: EigenBase.h:46
const IndicesType & indices() const
const version of indices().
Definition: PermutationMatrix.h:360
EIGEN_DEVICE_FUNC Derived & setZero(Index size)
Resizes to the given size, and sets all coefficients in this expression to zero.
Definition: CwiseNullaryOp.h:562
Expression of the product of two arbitrary matrices or vectors.
Definition: Product.h:75
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const LhsNestedCleaned & lhs() const
Definition: Product.h:107
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const RhsNestedCleaned & rhs() const
Definition: Product.h:109
Base class of any sparse matrices or sparse expressions.
Definition: SparseMatrixBase.h:28
const Derived & derived() const
Definition: SparseMatrixBase.h:143
A versatible sparse matrix representation.
Definition: SparseMatrix.h:98
void reserve(Index reserveSize)
Preallocates reserveSize non zeros.
Definition: SparseMatrix.h:264
Scalar & insertByOuterInner(Index j, Index i)
Definition: SparseMatrix.h:460
type
Definition: core.h:575
@ ColMajor
Storage order is column major (see TopicStorageOrders).
Definition: Constants.h:319
@ RowMajor
Storage order is row major (see TopicStorageOrders).
Definition: Constants.h:321
@ OnTheLeft
Apply transformation on the left.
Definition: Constants.h:332
@ OnTheRight
Apply transformation on the right.
Definition: Constants.h:334
const unsigned int EvalBeforeNestingBit
means the expression should be evaluated by the calling expression
Definition: Constants.h:70
const unsigned int RowMajorBit
for a matrix, this means that the storage order is row-major.
Definition: Constants.h:66
Namespace containing all symbols from the Eigen library.
Definition: Core:141
@ AliasFreeProduct
Definition: Constants.h:500
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:74
const Product< SparseDerived, PermDerived, AliasFreeProduct > operator*(const SparseMatrixBase< SparseDerived > &matrix, const PermutationBase< PermDerived > &perm)
Definition: SparsePermutation.h:147
Definition: Eigen_Colamd.h:50
EIGEN_DEVICE_FUNC Derived & derived()
Definition: EigenBase.h:46
Definition: Constants.h:535
The type used to identify a permutation storage.
Definition: Constants.h:516
The type used to identify a general sparse storage.
Definition: Constants.h:510
Definition: Constants.h:537
Definition: Meta.h:109
Definition: CoreEvaluators.h:91
Definition: ProductEvaluators.h:86
internal::conditional< MoveOuter, SparseMatrix< Scalar, SrcStorageOrder, StorageIndex >, SparseMatrix< Scalar, int(SrcStorageOrder)==RowMajor?ColMajor:RowMajor, StorageIndex > >::type ReturnType
Definition: SparsePermutation.h:35
nested_eval< ExpressionType, 1 >::type MatrixType
Definition: SparsePermutation.h:22
static void run(Dest &dst, const PermutationType &perm, const ExpressionType &xpr)
Definition: SparsePermutation.h:38
remove_all< MatrixType >::type MatrixTypeCleaned
Definition: SparsePermutation.h:23
MatrixTypeCleaned::StorageIndex StorageIndex
Definition: SparsePermutation.h:26
Definition: ProductEvaluators.h:998
permutation_matrix_product< Rhs, OnTheLeft, false, SparseShape >::ReturnType PlainObject
Definition: SparsePermutation.h:100
permutation_matrix_product< Lhs, OnTheRight, false, SparseShape >::ReturnType PlainObject
Definition: SparsePermutation.h:123
Definition: ForwardDeclarations.h:164
T type
Definition: Meta.h:126
Definition: Meta.h:96