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> >
38 typedef typename ConditionMatrixType::Nested ConditionMatrixNested;
39 typedef typename ThenMatrixType::Nested ThenMatrixNested;
40 typedef typename ElseMatrixType::Nested ElseMatrixNested;
42 RowsAtCompileTime = ConditionMatrixType::RowsAtCompileTime,
43 ColsAtCompileTime = ConditionMatrixType::ColsAtCompileTime,
44 MaxRowsAtCompileTime = ConditionMatrixType::MaxRowsAtCompileTime,
45 MaxColsAtCompileTime = ConditionMatrixType::MaxColsAtCompileTime,
46 Flags = (
unsigned int)ThenMatrixType::Flags & ElseMatrixType::Flags &
RowMajorBit
51 template<
typename ConditionMatrixType,
typename ThenMatrixType,
typename ElseMatrixType>
58 EIGEN_DENSE_PUBLIC_INTERFACE(
Select)
60 inline EIGEN_DEVICE_FUNC
61 Select(
const ConditionMatrixType& a_conditionMatrix,
62 const ThenMatrixType& a_thenMatrix,
63 const ElseMatrixType& a_elseMatrix)
64 : m_condition(a_conditionMatrix), m_then(a_thenMatrix), m_else(a_elseMatrix)
66 eigen_assert(m_condition.rows() == m_then.rows() && m_condition.rows() == m_else.rows());
67 eigen_assert(m_condition.cols() == m_then.cols() && m_condition.cols() == m_else.cols());
70 inline EIGEN_DEVICE_FUNC
Index rows()
const {
return m_condition.rows(); }
71 inline EIGEN_DEVICE_FUNC
Index cols()
const {
return m_condition.cols(); }
73 inline EIGEN_DEVICE_FUNC
76 if (m_condition.coeff(i,j))
77 return m_then.coeff(i,j);
79 return m_else.coeff(i,j);
82 inline EIGEN_DEVICE_FUNC
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);
91 inline EIGEN_DEVICE_FUNC
const ConditionMatrixType& conditionMatrix()
const
96 inline EIGEN_DEVICE_FUNC
const ThenMatrixType& thenMatrix()
const
101 inline EIGEN_DEVICE_FUNC
const ElseMatrixType& elseMatrix()
const
107 typename ConditionMatrixType::Nested m_condition;
108 typename ThenMatrixType::Nested m_then;
109 typename ElseMatrixType::Nested m_else;
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