10 #ifndef EIGEN_SELECT_H 11 #define EIGEN_SELECT_H 31 template<
typename ConditionMatrixType,
typename ThenMatrixType,
typename ElseMatrixType>
32 struct traits<
Select<ConditionMatrixType, ThenMatrixType, ElseMatrixType> >
42 RowsAtCompileTime = ConditionMatrixType::RowsAtCompileTime,
43 ColsAtCompileTime = ConditionMatrixType::ColsAtCompileTime,
44 MaxRowsAtCompileTime = ConditionMatrixType::MaxRowsAtCompileTime,
45 MaxColsAtCompileTime = ConditionMatrixType::MaxColsAtCompileTime,
46 Flags = (
unsigned int)ThenMatrixType::Flags & ElseMatrixType::Flags &
HereditaryBits,
54 template<
typename ConditionMatrixType,
typename ThenMatrixType,
typename ElseMatrixType>
63 Select(const ConditionMatrixType& a_conditionMatrix,
64 const ThenMatrixType& a_thenMatrix,
65 const ElseMatrixType& a_elseMatrix)
66 : m_condition(a_conditionMatrix), m_then(a_thenMatrix), m_else(a_elseMatrix)
68 eigen_assert(m_condition.rows() == m_then.rows() && m_condition.rows() == m_else.rows());
69 eigen_assert(m_condition.cols() == m_then.cols() && m_condition.cols() == m_else.cols());
72 Index
rows()
const {
return m_condition.rows(); }
73 Index
cols()
const {
return m_condition.cols(); }
75 const Scalar
coeff(Index i, Index j)
const 77 if (m_condition.coeff(i,j))
78 return m_then.coeff(i,j);
80 return m_else.coeff(i,j);
83 const Scalar
coeff(Index i)
const 85 if (m_condition.coeff(i))
86 return m_then.coeff(i);
88 return m_else.coeff(i);
121 template<
typename Derived>
122 template<
typename ThenDerived,
typename ElseDerived>
135 template<
typename Derived>
136 template<
typename ThenDerived>
139 const typename ThenDerived::Scalar& elseScalar)
const 142 derived(), thenMatrix.derived(), ThenDerived::Constant(rows(),cols(),elseScalar));
150 template<
typename Derived>
151 template<
typename ElseDerived>
157 derived(), ElseDerived::Constant(rows(),cols(),thenScalar), elseMatrix.derived());
162 #endif // EIGEN_SELECT_H const ThenMatrixType & thenMatrix() const
traits< ThenMatrixType >::XprKind XprKind
const Scalar coeff(Index i, Index j) const
ThenMatrixType::Nested ThenMatrixNested
ElseMatrixType::Nested m_else
Base class for all dense matrices, vectors, and arrays.
internal::dense_xpr_base< Select >::type Base
const Scalar coeff(Index i) const
const unsigned int HereditaryBits
ElseMatrixType::Nested ElseMatrixNested
const ConditionMatrixType & conditionMatrix() const
#define EIGEN_DENSE_PUBLIC_INTERFACE(Derived)
#define EIGEN_SIZE_MAX(a, b)
const ElseMatrixType & elseMatrix() const
traits< ThenMatrixType >::Scalar Scalar
ConditionMatrixType::Nested ConditionMatrixNested
ThenMatrixType::Nested m_then
ConditionMatrixType::Nested m_condition
const Select< Derived, ThenDerived, ElseDerived > select(const DenseBase< ThenDerived > &thenMatrix, const DenseBase< ElseDerived > &elseMatrix) const
Expression of a coefficient wise version of the C++ ternary operator ?: