namespace Eigen { /** \page TutorialCore Tutorial 1/4 - Core features \ingroup Tutorial
\b Table \b of \b contents - \ref TutorialCoreGettingStarted - \ref TutorialCoreSimpleExampleFixedSize - \ref TutorialCoreSimpleExampleDynamicSize - \ref TutorialCoreMatrixTypes - \ref TutorialCoreCoefficients - \ref TutorialCoreMatrixInitialization - \ref TutorialCoreArithmeticOperators - \ref TutorialCoreReductions - \ref TutorialCoreMatrixBlocks - \ref TutorialCoreDiagonalMatrices - \ref TutorialCoreTransposeAdjoint - \ref TutorialCoreDotNorm - \ref TutorialCoreTriangularMatrix - \ref TutorialCoreSelfadjointMatrix - \ref TutorialCoreSpecialTopics \n\include Tutorial_simple_example_fixed_size.cpp | output: \include Tutorial_simple_example_fixed_size.out |
\include Tutorial_simple_example_dynamic_size.cpp | output: \include Tutorial_simple_example_dynamic_size.out |
Fixed-size matrix or vector | Dynamic-size matrix | Dynamic-size vector |
\code typedef {Matrix3f|Array33f} FixedXD; FixedXD x; x = FixedXD::Zero(); x = FixedXD::Ones(); x = FixedXD::Constant(value); x = FixedXD::Identity(); x = FixedXD::Random(); x.setZero(); x.setOnes(); x.setIdentity(); x.setConstant(value); x.setRandom(); \endcode | \code typedef {MatrixXf|ArrayXXf} Dynamic2D; Dynamic2D x; x = Dynamic2D::Zero(rows, cols); x = Dynamic2D::Ones(rows, cols); x = Dynamic2D::Constant(rows, cols, value); x = Dynamic2D::Identity(rows, cols); x = Dynamic2D::Random(rows, cols); x.setZero(rows, cols); x.setOnes(rows, cols); x.setConstant(rows, cols, value); x.setIdentity(rows, cols); x.setRandom(rows, cols); \endcode | \code typedef {VectorXf|ArrayXf} Dynamic1D; Dynamic1D x; x = Dynamic1D::Zero(size); x = Dynamic1D::Ones(size); x = Dynamic1D::Constant(size, value); x = Dynamic1D::Identity(size); x = Dynamic1D::Random(size); x.setZero(size); x.setOnes(size); x.setConstant(size, value); N/A x.setRandom(size); \endcode |
\redstar the Random() and setRandom() functions require the inclusion of the Array module (\c \#include \c | ||
The following are for matrix only: \matrixworld | ||
\code x = FixedXD::Identity(); x.setIdentity(); \endcode | \code x = Dynamic2D::Identity(rows, cols); x.setIdentity(rows, cols); \endcode | |
Basis vectors \matrixworld \link MatrixBase::Unit [details]\endlink | ||
\code Vector3f::UnitX() // 1 0 0 Vector3f::UnitY() // 0 1 0 Vector3f::UnitZ() // 0 0 1 \endcode | \code VectorXf::Unit(size,i) VectorXf::Unit(4,1) == Vector4f(0,1,0,0) == Vector4f::UnitY() \endcode |
\code cout << MatrixXf::Constant(2, 3, sqrt(2)) << endl; RowVector3i v; v.setConstant(6); cout << "v = " << v << endl; \endcode | output: \code 1.41 1.41 1.41 1.41 1.41 1.41 v = 6 6 6 \endcode |
\include Tutorial_commainit_01.cpp | output: \verbinclude Tutorial_commainit_01.out |
\include Tutorial_commainit_02.cpp | output: \verbinclude Tutorial_commainit_02.out |
matrix/vector product \matrixworld | \code col2 = mat1 * col1; row2 = row1 * mat1; row1 *= mat1; mat3 = mat1 * mat2; mat3 *= mat1; \endcode |
add/subtract | \code mat3 = mat1 + mat2; mat3 += mat1; mat3 = mat1 - mat2; mat3 -= mat1;\endcode |
scalar product | \code mat3 = mat1 * s1; mat3 = s1 * mat1; mat3 *= s1; mat3 = mat1 / s1; mat3 /= s1;\endcode |
Other coefficient wise operators | \code mat1.cwiseProduct(mat2); mat1.cwiseQuotient(mat2); mat1.cwiseMin(mat2); mat1.cwiseMax(mat2); mat1.cwiseAbs2(); mat1.cwiseSqrt(); mat1.cwiseAbs();\endcode |
|
|
\link MatrixBase::dot() dot product \endlink (inner product) \matrixworld | \code scalar = vec1.dot(vec2);\endcode |
outer product \matrixworld | \code mat = vec1 * vec2.transpose();\endcode |
\link MatrixBase::cross() cross product \endlink \matrixworld | \code
#include |
\code 5 3 1 mat = 2 7 8 9 4 6 \endcode | \code mat.minCoeff(); \endcode | \code 1 \endcode |
\code mat.colwise().minCoeff(); \endcode | \code 2 3 1 \endcode | |
\code mat.rowwise().minCoeff(); \endcode | \code 1 2 4 \endcode |
Default versions | Optimized versions when the size \n is known at compile time | |
\code vec1.head(n)\endcode | \code vec1.head | the first \c n coeffs |
\code vec1.tail(n)\endcode | \code vec1.tail | the last \c n coeffs |
\code vec1.segment(pos,n)\endcode | \code vec1.segment |
the \c size coeffs in \n the range [\c pos : \c pos + \c n [ |
Read-write access to sub-matrices: | ||
\code mat1.block(i,j,rows,cols)\endcode \link DenseBase::block(int,int,int,int) (more) \endlink | \code mat1.block |
the \c rows x \c cols sub-matrix \n starting from position (\c i,\c j) |
\code mat1.corner(TopLeft,rows,cols) mat1.corner(TopRight,rows,cols) mat1.corner(BottomLeft,rows,cols) mat1.corner(BottomRight,rows,cols)\endcode \link DenseBase::corner(CornerType,int,int) (more) \endlink | \code
mat1.corner |
the \c rows x \c cols sub-matrix \n taken in one of the four corners |
\code mat4x4.minor(i,j) = mat3x3; mat3x3 = mat4x4.minor(i,j);\endcode | \link DenseBase::minor() minor \endlink (read-write) |
\link MatrixBase::asDiagonal() make a diagonal matrix \endlink from a vector \n this product is automatically optimized ! | \code mat3 = mat1 * vec2.asDiagonal();\endcode |
Access \link MatrixBase::diagonal() the diagonal of a matrix \endlink as a vector (read/write) | \code vec1 = mat1.diagonal(); mat1.diagonal() = vec1; \endcode |
\link DenseBase::transpose() transposition \endlink (read-write) | \code mat3 = mat1.transpose() * mat2; mat3.transpose() = mat1 * mat2.transpose(); \endcode |
\link MatrixBase::adjoint() adjoint \endlink (read only) \matrixworld\n | \code mat3 = mat1.adjoint() * mat2; \endcode |
\link MatrixBase::dot() Dot-product \endlink of two vectors | \code vec1.dot(vec2);\endcode |
\link MatrixBase::norm() norm \endlink of a vector \n \link MatrixBase::squaredNorm() squared norm \endlink of a vector | \code vec.norm(); \endcode \n \code vec.squaredNorm() \endcode |
returns a \link MatrixBase::normalized() normalized \endlink vector \n \link MatrixBase::normalize() normalize \endlink a vector | \code vec3 = vec1.normalized(); vec1.normalize();\endcode |
Reference a read/write triangular part of a given \n matrix (or expression) m with optional unit diagonal: | \code
m.triangularView |
Writing to a specific triangular part:\n (only the referenced triangular part is evaluated) | \code
m1.triangularView |
Conversion to a dense matrix setting the opposite triangular part to zero: | \code
m2 = m1.triangularView |
Products: | \code
m3 += s1 * m1.adjoint().triangularView |
Solving linear equations:\n(\f$ m_2 := m_1^{-1} m_2 \f$) | \code
m1.triangularView |
Conversion to a dense matrix: | \code
m2 = m.selfadjointView |
Product with another general matrix or vector: | \code
m3 = s1 * m1.conjugate().selfadjointView |
Rank 1 and rank K update: | \code
// fast version of m1 += s1 * m2 * m2.adjoint():
m1.selfadjointView |
Rank 2 update: (\f$ m += s u v^* + s v u^* \f$) | \code
m.selfadjointView |
Solving linear equations:\n(\f$ m_2 := m_1^{-1} m_2 \f$) | \code
// via a standard Cholesky factorization
m1.selfadjointView |