TR-mbed 1.0
Loading...
Searching...
No Matches
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>
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 {
41 if(MoveOuter)
42 {
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());
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
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
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
145template<typename SparseDerived, typename PermDerived>
149
152template<typename SparseDerived, typename PermDerived>
153inline const Product<PermDerived, SparseDerived, AliasFreeProduct>
156
157
160template<typename SparseDerived, typename PermutationType>
161inline const Product<SparseDerived, Inverse<PermutationType>, AliasFreeProduct>
166
169template<typename SparseDerived, typename PermutationType>
170inline const Product<Inverse<PermutationType>, SparseDerived, AliasFreeProduct>
175
176} // end namespace Eigen
177
178#endif // EIGEN_SPARSE_SELFADJOINTVIEW_H
MatrixXf mat
Definition Tutorial_AdvancedInitialization_CommaTemporary.cpp:1
int rows
Definition Tutorial_commainit_02.cpp:1
int cols
Definition Tutorial_commainit_02.cpp:1
SCALAR Scalar
Definition bench_gemm.cpp:46
Definition Inverse.h:70
Base class for permutations.
Definition PermutationMatrix.h:47
EIGEN_DEVICE_FUNC Derived & derived()
Definition EigenBase.h:46
Expression of the product of two arbitrary matrices or vectors.
Definition Product.h:75
Base class of any sparse matrices or sparse expressions.
Definition SparseMatrixBase.h:28
A versatible sparse matrix representation.
Definition SparseMatrix.h:98
Map< Matrix< T, Dynamic, Dynamic, ColMajor >, 0, OuterStride<> > matrix(T *data, int rows, int cols, int stride)
Definition common.h:110
std::vector< Array2i > sizes
Definition dense_solvers.cpp:12
@ ColMajor
Definition Constants.h:319
@ RowMajor
Definition Constants.h:321
@ OnTheLeft
Definition Constants.h:332
@ OnTheRight
Definition Constants.h:334
const unsigned int EvalBeforeNestingBit
Definition Constants.h:70
const unsigned int RowMajorBit
Definition Constants.h:66
return int(ret)+1
@ Lhs
Definition TensorContractionMapper.h:19
@ Rhs
Definition TensorContractionMapper.h:18
Namespace containing all symbols from the Eigen library.
Definition bench_norm.cpp:85
@ AliasFreeProduct
Definition Constants.h:500
EIGEN_DEVICE_FUNC const Product< MatrixDerived, PermutationDerived, AliasFreeProduct > operator*(const MatrixBase< MatrixDerived > &matrix, const PermutationBase< PermutationDerived > &permutation)
Definition PermutationMatrix.h:515
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition Meta.h:74
Definition BandTriangularSolver.h:13
Definition Constants.h:535
Definition Constants.h:516
Definition Constants.h:537
Definition Constants.h:510
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< Lhs, OnTheRight, false, SparseShape >::ReturnType PlainObject
Definition SparsePermutation.h:123
permutation_matrix_product< Rhs, OnTheLeft, false, SparseShape >::ReturnType PlainObject
Definition SparsePermutation.h:100
Definition ForwardDeclarations.h:164
Definition ForwardDeclarations.h:17
std::ptrdiff_t j
Definition tut_arithmetic_redux_minmax.cpp:2