10 #ifndef EIGEN_BANDMATRIX_H    11 #define EIGEN_BANDMATRIX_H    17 template<
typename Derived>
    60     inline const CoefficientsType& 
coeffs()
 const { 
return derived().coeffs(); }
    72       Index len = 
coeffs().rows();
    79         len = std::max<Index>(0,
coeffs().rows() - (i + 1 - 
rows() + 
subs()));
   134     template<
typename Dest> 
inline void evalTo(Dest& dst)
 const   139       for (Index i=1; i<=
supers();++i)
   141       for (Index i=1; i<=
subs();++i)
   177 template<
typename _Scalar, 
int _Rows, 
int _Cols, 
int _Supers, 
int _Subs, 
int _Options>
   198 template<
typename _Scalar, 
int Rows, 
int Cols, 
int Supers, 
int Subs, 
int Options>
   214     inline Index 
rows()
 const { 
return m_rows.value(); }
   217     inline Index 
cols()
 const { 
return m_coeffs.cols(); }
   220     inline Index 
supers()
 const { 
return m_supers.value(); }
   223     inline Index 
subs()
 const { 
return m_subs.value(); }
   225     inline const CoefficientsType& 
coeffs()
 const { 
return m_coeffs; }
   226     inline CoefficientsType& 
coeffs() { 
return m_coeffs; }
   236 template<
typename _CoefficientsType,
int _Rows, 
int _Cols, 
int _Supers, 
int _Subs,
int _Options>
   239 template<
typename _CoefficientsType,
int _Rows, 
int _Cols, 
int _Supers, 
int _Subs,
int _Options>
   242   typedef typename _CoefficientsType::Scalar 
Scalar;
   244   typedef typename _CoefficientsType::Index 
Index;
   260 template<
typename _CoefficientsType,
int _Rows, 
int _Cols, 
int _Supers, 
int _Subs,
int _Options>
   278     inline Index 
rows()
 const { 
return m_rows.value(); }
   281     inline Index 
cols()
 const { 
return m_coeffs.cols(); }
   284     inline Index 
supers()
 const { 
return m_supers.value(); }
   287     inline Index 
subs()
 const { 
return m_subs.value(); }
   289     inline const CoefficientsType& 
coeffs()
 const { 
return m_coeffs; }
   311 template<
typename Scalar, 
int Size, 
int Options>
   320     { 
return Base::template diagonal<1>(); }
   322     { 
return Base::template diagonal<1>(); }
   324     { 
return Base::template 
diagonal<-1>(); }
   326     { 
return Base::template 
diagonal<-1>(); }
   334 #endif // EIGEN_BANDMATRIX_H internal::variable_if_dynamic< Index, _Rows > m_rows
internal::variable_if_dynamic< Index, _Supers > m_supers
TridiagonalMatrix(Index size=Size)
internal::traits< BandMatrix >::Index Index
Index diagonalLength(Index i) const 
internal::variable_if_dynamic< Index, Supers > m_supers
CoefficientsType & coeffs()
const Base::template DiagonalIntReturnType<-1 >::Type sub() const 
const Block< const CoefficientsType, 1, Dynamic > diagonal(Index i) const 
internal::traits< BandMatrixWrapper >::Scalar Scalar
#define EIGEN_UNUSED_VARIABLE(var)
const unsigned int LvalueBit
internal::traits< Derived >::CoefficientsType CoefficientsType
Represents a rectangular matrix with a banded storage. 
const DiagonalIntReturnType< N >::Type diagonal() const 
internal::traits< Matrix< _Scalar, _Rows, _Cols, _Options, _MaxRows, _MaxCols > >::Index Index
Holds information about the various numeric (i.e. scalar) types allowed by Eigen. ...
#define EIGEN_STATIC_ASSERT(CONDITION, MSG)
internal::traits< Derived >::Scalar Scalar
const CoefficientsType & coeffs() const 
Block< CoefficientsType, 1, SizeAtCompileTime > diagonal()
EigenBase< Derived > Base
_CoefficientsType::Index Index
const CoefficientsType & m_coeffs
Base::template DiagonalIntReturnType< 1 >::Type super()
DiagonalIntReturnType< N >::Type diagonal()
internal::variable_if_dynamic< Index, Subs > m_subs
internal::traits< BandMatrix >::CoefficientsType CoefficientsType
Represents a tridiagonal matrix with a compact banded storage. 
_CoefficientsType::StorageKind StorageKind
internal::traits< BandMatrix >::Scalar Scalar
BandMatrix(Index rows=Rows, Index cols=Cols, Index supers=Supers, Index subs=Subs)
DenseMatrixType toDenseMatrix() const 
internal::variable_if_dynamic< Index, _Subs > m_subs
_CoefficientsType CoefficientsType
Matrix< Scalar, DataRowsAtCompileTime, ColsAtCompileTime, Options &RowMajor?RowMajor:ColMajor > CoefficientsType
DenseMatrixType::Index Index
internal::traits< Derived >::Index Index
const Base::template DiagonalIntReturnType< 1 >::Type super() const 
EIGEN_DEFAULT_DENSE_INDEX_TYPE DenseIndex
void evalTo(Dest &dst) const 
CoefficientsType m_coeffs
BandMatrixWrapper(const CoefficientsType &coeffs, Index rows=_Rows, Index cols=_Cols, Index supers=_Supers, Index subs=_Subs)
CoefficientsType & coeffs()
Expression of a fixed-size or dynamic-size block. 
#define EIGEN_SIZE_MIN_PREFER_DYNAMIC(a, b)
Block< CoefficientsType, 1, DiagonalSize > BuildType
const CoefficientsType & coeffs() const 
BandMatrix< Scalar, Size, Size, Options &SelfAdjoint?0:1, 1, Options|RowMajor > Base
const Block< const CoefficientsType, 1, SizeAtCompileTime > diagonal() const 
const CoefficientsType & coeffs() const 
internal::variable_if_dynamic< Index, Rows > m_rows
Block< CoefficientsType, Dynamic, 1 > col(Index i)
internal::traits< BandMatrixWrapper >::Index Index
Block< CoefficientsType, 1, Dynamic > diagonal(Index i)
_CoefficientsType::Scalar Scalar
Matrix< Scalar, RowsAtCompileTime, ColsAtCompileTime > DenseMatrixType
internal::conditional< Conjugate, CwiseUnaryOp< internal::scalar_conjugate_op< Scalar >, BuildType >, BuildType >::type Type
Generic expression where a coefficient-wise unary operator is applied to an expression. 
The matrix class, also used for vectors and row-vectors. 
internal::traits< BandMatrixWrapper >::CoefficientsType CoefficientsType
Base::template DiagonalIntReturnType<-1 >::Type sub()