00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 #ifndef EIGEN_SELECT_H
00011 #define EIGEN_SELECT_H
00012 
00013 namespace Eigen { 
00014 
00030 namespace internal {
00031 template<typename ConditionMatrixType, typename ThenMatrixType, typename ElseMatrixType>
00032 struct traits<Select<ConditionMatrixType, ThenMatrixType, ElseMatrixType> >
00033  : traits<ThenMatrixType>
00034 {
00035   typedef typename traits<ThenMatrixType>::Scalar Scalar;
00036   typedef Dense StorageKind;
00037   typedef typename traits<ThenMatrixType>::XprKind XprKind;
00038   typedef typename ConditionMatrixType::Nested ConditionMatrixNested;
00039   typedef typename ThenMatrixType::Nested ThenMatrixNested;
00040   typedef typename ElseMatrixType::Nested ElseMatrixNested;
00041   enum {
00042     RowsAtCompileTime = ConditionMatrixType::RowsAtCompileTime,
00043     ColsAtCompileTime = ConditionMatrixType::ColsAtCompileTime,
00044     MaxRowsAtCompileTime = ConditionMatrixType::MaxRowsAtCompileTime,
00045     MaxColsAtCompileTime = ConditionMatrixType::MaxColsAtCompileTime,
00046     Flags = (unsigned int)ThenMatrixType::Flags & ElseMatrixType::Flags & HereditaryBits,
00047     CoeffReadCost = traits<typename remove_all<ConditionMatrixNested>::type>::CoeffReadCost
00048                   + EIGEN_SIZE_MAX(traits<typename remove_all<ThenMatrixNested>::type>::CoeffReadCost,
00049                                    traits<typename remove_all<ElseMatrixNested>::type>::CoeffReadCost)
00050   };
00051 };
00052 }
00053 
00054 template<typename ConditionMatrixType, typename ThenMatrixType, typename ElseMatrixType>
00055 class Select : internal::no_assignment_operator,
00056   public internal::dense_xpr_base< Select<ConditionMatrixType, ThenMatrixType, ElseMatrixType> >::type
00057 {
00058   public:
00059 
00060     typedef typename internal::dense_xpr_base<Select>::type Base;
00061     EIGEN_DENSE_PUBLIC_INTERFACE(Select)
00062 
00063     Select(const ConditionMatrixType& conditionMatrix,
00064            const ThenMatrixType& thenMatrix,
00065            const ElseMatrixType& elseMatrix)
00066       : m_condition(conditionMatrix), m_then(thenMatrix), m_else(elseMatrix)
00067     {
00068       eigen_assert(m_condition.rows() == m_then.rows() && m_condition.rows() == m_else.rows());
00069       eigen_assert(m_condition.cols() == m_then.cols() && m_condition.cols() == m_else.cols());
00070     }
00071 
00072     Index rows() const { return m_condition.rows(); }
00073     Index cols() const { return m_condition.cols(); }
00074 
00075     const Scalar coeff(Index i, Index j) const
00076     {
00077       if (m_condition.coeff(i,j))
00078         return m_then.coeff(i,j);
00079       else
00080         return m_else.coeff(i,j);
00081     }
00082 
00083     const Scalar coeff(Index i) const
00084     {
00085       if (m_condition.coeff(i))
00086         return m_then.coeff(i);
00087       else
00088         return m_else.coeff(i);
00089     }
00090 
00091     const ConditionMatrixType& conditionMatrix() const
00092     {
00093       return m_condition;
00094     }
00095 
00096     const ThenMatrixType& thenMatrix() const
00097     {
00098       return m_then;
00099     }
00100 
00101     const ElseMatrixType& elseMatrix() const
00102     {
00103       return m_else;
00104     }
00105 
00106   protected:
00107     typename ConditionMatrixType::Nested m_condition;
00108     typename ThenMatrixType::Nested m_then;
00109     typename ElseMatrixType::Nested m_else;
00110 };
00111 
00112 
00121 template<typename Derived>
00122 template<typename ThenDerived,typename ElseDerived>
00123 inline const Select<Derived,ThenDerived,ElseDerived>
00124 DenseBase<Derived>::select(const DenseBase<ThenDerived>& thenMatrix,
00125                             const DenseBase<ElseDerived>& elseMatrix) const
00126 {
00127   return Select<Derived,ThenDerived,ElseDerived>(derived(), thenMatrix.derived(), elseMatrix.derived());
00128 }
00129 
00135 template<typename Derived>
00136 template<typename ThenDerived>
00137 inline const Select<Derived,ThenDerived, typename ThenDerived::ConstantReturnType>
00138 DenseBase<Derived>::select(const DenseBase<ThenDerived>& thenMatrix,
00139                             typename ThenDerived::Scalar elseScalar) const
00140 {
00141   return Select<Derived,ThenDerived,typename ThenDerived::ConstantReturnType>(
00142     derived(), thenMatrix.derived(), ThenDerived::Constant(rows(),cols(),elseScalar));
00143 }
00144 
00150 template<typename Derived>
00151 template<typename ElseDerived>
00152 inline const Select<Derived, typename ElseDerived::ConstantReturnType, ElseDerived >
00153 DenseBase<Derived>::select(typename ElseDerived::Scalar thenScalar,
00154                             const DenseBase<ElseDerived>& elseMatrix) const
00155 {
00156   return Select<Derived,typename ElseDerived::ConstantReturnType,ElseDerived>(
00157     derived(), ElseDerived::Constant(rows(),cols(),thenScalar), elseMatrix.derived());
00158 }
00159 
00160 } 
00161 
00162 #endif // EIGEN_SELECT_H