10 #ifndef EIGEN_INDEXED_VIEW_H
11 #define EIGEN_INDEXED_VIEW_H
17 template<
typename XprType,
typename RowIndices,
typename ColIndices>
24 MaxRowsAtCompileTime = RowsAtCompileTime !=
Dynamic ? int(RowsAtCompileTime) :
Dynamic,
25 MaxColsAtCompileTime = ColsAtCompileTime !=
Dynamic ? int(ColsAtCompileTime) :
Dynamic,
28 IsRowMajor = (MaxRowsAtCompileTime==1&&MaxColsAtCompileTime!=1) ? 1
29 : (MaxColsAtCompileTime==1&&MaxRowsAtCompileTime!=1) ? 0
34 InnerIncr = IsRowMajor ? ColIncr : RowIncr,
35 OuterIncr = IsRowMajor ? RowIncr : ColIncr,
37 HasSameStorageOrderAsXprType = (IsRowMajor == XprTypeIsRowMajor),
41 InnerSize = XprTypeIsRowMajor ? ColsAtCompileTime : RowsAtCompileTime,
42 IsBlockAlike = InnerIncr==1 && OuterIncr==1,
45 InnerStrideAtCompileTime = InnerIncr<0 || InnerIncr==
DynamicIndex || XprInnerStride==
Dynamic ?
Dynamic : XprInnerStride * InnerIncr,
46 OuterStrideAtCompileTime = OuterIncr<0 || OuterIncr==
DynamicIndex || XprOuterstride==
Dynamic ?
Dynamic : XprOuterstride * OuterIncr,
49 ReturnAsBlock = (!ReturnAsScalar) && IsBlockAlike,
50 ReturnAsIndexedView = (!ReturnAsScalar) && (!ReturnAsBlock),
57 FlagsLinearAccessBit = (RowsAtCompileTime == 1 || ColsAtCompileTime == 1) ?
LinearAccessBit : 0,
58 Flags = (
traits<XprType>::Flags & (HereditaryBits | DirectAccessMask )) | FlagsLvalueBit | FlagsRowMajorBit | FlagsLinearAccessBit
66 template<
typename XprType,
typename RowIndices,
typename ColIndices,
typename StorageKind>
108 template<
typename XprType,
typename RowIndices,
typename ColIndices>
117 typedef typename internal::remove_all<XprType>::type NestedExpression;
119 template<
typename T0,
typename T1>
125 Index rows()
const {
return internal::size(m_rowIndices); }
128 Index cols()
const {
return internal::size(m_colIndices); }
131 const typename internal::remove_all<XprType>::type&
135 typename internal::remove_reference<XprType>::type&
139 const RowIndices&
rowIndices()
const {
return m_rowIndices; }
142 const ColIndices&
colIndices()
const {
return m_colIndices; }
145 MatrixTypeNested m_xpr;
146 RowIndices m_rowIndices;
147 ColIndices m_colIndices;
152 template<
typename XprType,
typename RowIndices,
typename ColIndices,
typename StorageKind>
163 template<
typename ArgType,
typename RowIndices,
typename ColIndices>
183 EIGEN_INTERNAL_CHECK_COST_VALUE(CoeffReadCost);
186 typedef typename XprType::Scalar Scalar;
187 typedef typename XprType::CoeffReturnType CoeffReturnType;
189 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
190 CoeffReturnType coeff(
Index row,
Index col)
const
192 return m_argImpl.coeff(m_xpr.rowIndices()[row], m_xpr.colIndices()[col]);
195 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
198 return m_argImpl.coeffRef(m_xpr.rowIndices()[row], m_xpr.colIndices()[col]);
201 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
202 Scalar& coeffRef(
Index index)
204 EIGEN_STATIC_ASSERT_LVALUE(
XprType)
205 Index row = XprType::RowsAtCompileTime == 1 ? 0 : index;
206 Index col = XprType::RowsAtCompileTime == 1 ? index : 0;
207 return m_argImpl.coeffRef( m_xpr.rowIndices()[row], m_xpr.colIndices()[col]);
210 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
211 const Scalar& coeffRef(
Index index)
const
213 Index row = XprType::RowsAtCompileTime == 1 ? 0 : index;
214 Index col = XprType::RowsAtCompileTime == 1 ? index : 0;
215 return m_argImpl.coeffRef( m_xpr.rowIndices()[row], m_xpr.colIndices()[col]);
218 EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
219 const CoeffReturnType coeff(
Index index)
const
221 Index row = XprType::RowsAtCompileTime == 1 ? 0 : index;
222 Index col = XprType::RowsAtCompileTime == 1 ? index : 0;
223 return m_argImpl.coeff( m_xpr.rowIndices()[row], m_xpr.colIndices()[col]);
237 #endif // EIGEN_INDEXED_VIEW_H