Index of MATH/SMATRIX
SMatrix Package
SMatrix is a C++ package for high performance vector and matrix computations.
It can be used only in problems when the size of the matrices is known at compile time, like in the tracking reconstruction of HEP experiments. It is based on a C++ technique, called expression templates, to achieve an high level optimization. The C++ templates can be used to implement vector and matrix expressions such that these expressions can be transformed at compile time to code which is equivalent to hand optimized code in a low-level language like FORTRAN or C (see for example ref. 1)
The SMatrix has been developed initially by T. Glebe of the Max-Planck-Institut, Heidelberg, as part of the HeraB analysis framework. A subset of the original package has been now incorporated in the ROOT distribution, with the aim to provide to the LHC experiments a stand-alone and high performant matrix package for reconstruction. The API of the current package differs from the original one, in order to be compliant to the ROOT coding conventions.
SMatrix contains generic Matrix and Vector classes to describe matrix and vector of arbitrary dimensions and of arbitrary type. The classes are templated on the scalar type and on the size of the matrix (number of rows and columns) or the vector.
Therefore, the size has to be known at compile time. SMatrix supports symmetric matrices using a storage class (ROOT::Math::MatRepSym) which contains only the N*(N+1)/2 independent element of a NxN symmetric matrix.
It is not in the mandate of this package to provide a complete linear algebra functionality for these classes. What is provided are basic Matrix Template Functions and Vector Template Functions, such as the matrix-matrix, matrix-vector, vector-vector operations, plus some extra functionality for square matrices, like inversion, which is based on the optimized Cramer method for squared matrices of size up to 6x6, and determinant calculation.
For a more detailed descriptions and usage examples see:
The SMatrix package contains only header files. Normally one does not need to build any library for using SMatrix, it consists of only header files. However, in the ROOT distribution a library, libSmatrix is produced containing the C++ dictionary information for vectors, symmetric and squared matrices for double, float and Double32_t types up to dimension 7.
References
-
T. Veldhuizen, Expression Templates, C++ Report, 1995.
-
T. Glebe, SMatrix - A high performance library for Vector/Matrix calculation and Vertexing, HERA-B Software Note 01-134, December 2, 2003 (pdf)
- The Math Chapter in the Users Guide
describing the functionality of SMatrix
N.B.: For browsing the reference SMatrix documentation it is strongly recommended
to look at these online doc. The class documentation shown from the class links below is not complete, it is missing for example template methods.
Further Reading
List of Classes
Class Index
- ROOT::Math::MatRepStd<Double32_t,3,3>
- ROOT::Math::MatRepStd<Double32_t,4,4>
- ROOT::Math::MatRepStd<Double32_t,5,5>
- ROOT::Math::MatRepStd<Double32_t,6,6>
- ROOT::Math::MatRepStd<double,2,2>
- ROOT::Math::MatRepStd<double,3,3>
- ROOT::Math::MatRepStd<double,3,4>
- ROOT::Math::MatRepStd<double,4,3>
- ROOT::Math::MatRepStd<double,4,4>
- ROOT::Math::MatRepStd<double,5,5>
- ROOT::Math::MatRepStd<double,6,6>
- ROOT::Math::MatRepStd<double,7,7>
- ROOT::Math::MatRepStd<double,9,7>
- ROOT::Math::MatRepStd<float,2,2>
- ROOT::Math::MatRepStd<float,3,3>
- ROOT::Math::MatRepStd<float,3,4>
- ROOT::Math::MatRepStd<float,4,3>
- ROOT::Math::MatRepStd<float,4,4>
- ROOT::Math::MatRepStd<float,5,5>
- ROOT::Math::MatRepStd<float,6,6>
- ROOT::Math::MatRepStd<float,7,7>
- ROOT::Math::MatRepStd<float,9,7>
- ROOT::Math::MatRepSym<Double32_t,3>
- ROOT::Math::MatRepSym<Double32_t,4>
- ROOT::Math::MatRepSym<Double32_t,5>
- ROOT::Math::MatRepSym<Double32_t,6>
- ROOT::Math::MatRepSym<double,2>
- ROOT::Math::MatRepSym<double,3>
- ROOT::Math::MatRepSym<double,4>
- ROOT::Math::MatRepSym<double,5>
- ROOT::Math::MatRepSym<double,6>
- ROOT::Math::MatRepSym<double,7>
- ROOT::Math::MatRepSym<float,2>
- ROOT::Math::MatRepSym<float,3>
- ROOT::Math::MatRepSym<float,4>
- ROOT::Math::MatRepSym<float,5>
- ROOT::Math::MatRepSym<float,6>
- ROOT::Math::MatRepSym<float,7>
- ROOT::Math::RowOffsets<2>
- ROOT::Math::RowOffsets<3>
- ROOT::Math::RowOffsets<4>
- ROOT::Math::RowOffsets<5>
- ROOT::Math::RowOffsets<6>
- ROOT::Math::RowOffsets<7>
- ROOT::Math::SMatrix2D
- ROOT::Math::SMatrix2F
- ROOT::Math::SMatrix3D
- ROOT::Math::SMatrix3F
- ROOT::Math::SMatrix4D
- ROOT::Math::SMatrix4F
- ROOT::Math::SMatrix5D
- ROOT::Math::SMatrix5F
- ROOT::Math::SMatrix6D
- ROOT::Math::SMatrix6F
- ROOT::Math::SMatrix7D
- ROOT::Math::SMatrix7F
- ROOT::Math::SMatrix<Double32_t,3,3,ROOT::Math::MatRepStd<Double32_t,3,3> >
- ROOT::Math::SMatrix<Double32_t,3,3,ROOT::Math::MatRepSym<Double32_t,3> >
- ROOT::Math::SMatrix<Double32_t,4,4,ROOT::Math::MatRepStd<Double32_t,4,4> >
- ROOT::Math::SMatrix<Double32_t,4,4,ROOT::Math::MatRepSym<Double32_t,4> >
- ROOT::Math::SMatrix<Double32_t,5,5,ROOT::Math::MatRepStd<Double32_t,5,5> >
- ROOT::Math::SMatrix<Double32_t,5,5,ROOT::Math::MatRepSym<Double32_t,5> >
- ROOT::Math::SMatrix<Double32_t,6,6,ROOT::Math::MatRepStd<Double32_t,6,6> >
- ROOT::Math::SMatrix<Double32_t,6,6,ROOT::Math::MatRepSym<Double32_t,6> >
- ROOT::Math::SMatrix<double,2,2,ROOT::Math::MatRepStd<double,2,2> >
- ROOT::Math::SMatrix<double,2,2,ROOT::Math::MatRepStd<double,2,2> >::SMatrixRow
- ROOT::Math::SMatrix<double,2,2,ROOT::Math::MatRepStd<double,2,2> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,2,2,ROOT::Math::MatRepSym<double,2> >
- ROOT::Math::SMatrix<double,2,2,ROOT::Math::MatRepSym<double,2> >::SMatrixRow
- ROOT::Math::SMatrix<double,2,2,ROOT::Math::MatRepSym<double,2> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,3,3,ROOT::Math::MatRepStd<double,3,3> >
- ROOT::Math::SMatrix<double,3,3,ROOT::Math::MatRepStd<double,3,3> >::SMatrixRow
- ROOT::Math::SMatrix<double,3,3,ROOT::Math::MatRepStd<double,3,3> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,3,3,ROOT::Math::MatRepSym<double,3> >
- ROOT::Math::SMatrix<double,3,3,ROOT::Math::MatRepSym<double,3> >::SMatrixRow
- ROOT::Math::SMatrix<double,3,3,ROOT::Math::MatRepSym<double,3> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,3,4,ROOT::Math::MatRepStd<double,3,4> >
- ROOT::Math::SMatrix<double,3,4,ROOT::Math::MatRepStd<double,3,4> >::SMatrixRow
- ROOT::Math::SMatrix<double,3,4,ROOT::Math::MatRepStd<double,3,4> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,4,3,ROOT::Math::MatRepStd<double,4,3> >
- ROOT::Math::SMatrix<double,4,3,ROOT::Math::MatRepStd<double,4,3> >::SMatrixRow
- ROOT::Math::SMatrix<double,4,3,ROOT::Math::MatRepStd<double,4,3> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,4,4,ROOT::Math::MatRepStd<double,4,4> >
- ROOT::Math::SMatrix<double,4,4,ROOT::Math::MatRepStd<double,4,4> >::SMatrixRow
- ROOT::Math::SMatrix<double,4,4,ROOT::Math::MatRepStd<double,4,4> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,4,4,ROOT::Math::MatRepSym<double,4> >
- ROOT::Math::SMatrix<double,4,4,ROOT::Math::MatRepSym<double,4> >::SMatrixRow
- ROOT::Math::SMatrix<double,4,4,ROOT::Math::MatRepSym<double,4> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,5,5,ROOT::Math::MatRepStd<double,5,5> >
- ROOT::Math::SMatrix<double,5,5,ROOT::Math::MatRepStd<double,5,5> >::SMatrixRow
- ROOT::Math::SMatrix<double,5,5,ROOT::Math::MatRepStd<double,5,5> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,5,5,ROOT::Math::MatRepSym<double,5> >
- ROOT::Math::SMatrix<double,5,5,ROOT::Math::MatRepSym<double,5> >::SMatrixRow
- ROOT::Math::SMatrix<double,5,5,ROOT::Math::MatRepSym<double,5> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,6,6,ROOT::Math::MatRepStd<double,6,6> >
- ROOT::Math::SMatrix<double,6,6,ROOT::Math::MatRepStd<double,6,6> >::SMatrixRow
- ROOT::Math::SMatrix<double,6,6,ROOT::Math::MatRepStd<double,6,6> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,6,6,ROOT::Math::MatRepSym<double,6> >
- ROOT::Math::SMatrix<double,6,6,ROOT::Math::MatRepSym<double,6> >::SMatrixRow
- ROOT::Math::SMatrix<double,6,6,ROOT::Math::MatRepSym<double,6> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,7,7,ROOT::Math::MatRepStd<double,7,7> >
- ROOT::Math::SMatrix<double,7,7,ROOT::Math::MatRepStd<double,7,7> >::SMatrixRow
- ROOT::Math::SMatrix<double,7,7,ROOT::Math::MatRepStd<double,7,7> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,7,7,ROOT::Math::MatRepSym<double,7> >
- ROOT::Math::SMatrix<double,7,7,ROOT::Math::MatRepSym<double,7> >::SMatrixRow
- ROOT::Math::SMatrix<double,7,7,ROOT::Math::MatRepSym<double,7> >::SMatrixRow_const
- ROOT::Math::SMatrix<double,9,7,ROOT::Math::MatRepStd<double,9,7> >
- ROOT::Math::SMatrix<double,9,7,ROOT::Math::MatRepStd<double,9,7> >::SMatrixRow
- ROOT::Math::SMatrix<double,9,7,ROOT::Math::MatRepStd<double,9,7> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,2,2,ROOT::Math::MatRepStd<float,2,2> >
- ROOT::Math::SMatrix<float,2,2,ROOT::Math::MatRepStd<float,2,2> >::SMatrixRow
- ROOT::Math::SMatrix<float,2,2,ROOT::Math::MatRepStd<float,2,2> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,2,2,ROOT::Math::MatRepSym<float,2> >
- ROOT::Math::SMatrix<float,2,2,ROOT::Math::MatRepSym<float,2> >::SMatrixRow
- ROOT::Math::SMatrix<float,2,2,ROOT::Math::MatRepSym<float,2> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,3,3,ROOT::Math::MatRepStd<float,3,3> >
- ROOT::Math::SMatrix<float,3,3,ROOT::Math::MatRepStd<float,3,3> >::SMatrixRow
- ROOT::Math::SMatrix<float,3,3,ROOT::Math::MatRepStd<float,3,3> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,3,3,ROOT::Math::MatRepSym<float,3> >
- ROOT::Math::SMatrix<float,3,3,ROOT::Math::MatRepSym<float,3> >::SMatrixRow
- ROOT::Math::SMatrix<float,3,3,ROOT::Math::MatRepSym<float,3> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,3,4,ROOT::Math::MatRepStd<float,3,4> >
- ROOT::Math::SMatrix<float,3,4,ROOT::Math::MatRepStd<float,3,4> >::SMatrixRow
- ROOT::Math::SMatrix<float,3,4,ROOT::Math::MatRepStd<float,3,4> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,4,3,ROOT::Math::MatRepStd<float,4,3> >
- ROOT::Math::SMatrix<float,4,3,ROOT::Math::MatRepStd<float,4,3> >::SMatrixRow
- ROOT::Math::SMatrix<float,4,3,ROOT::Math::MatRepStd<float,4,3> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,4,4,ROOT::Math::MatRepStd<float,4,4> >
- ROOT::Math::SMatrix<float,4,4,ROOT::Math::MatRepStd<float,4,4> >::SMatrixRow
- ROOT::Math::SMatrix<float,4,4,ROOT::Math::MatRepStd<float,4,4> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,4,4,ROOT::Math::MatRepSym<float,4> >
- ROOT::Math::SMatrix<float,4,4,ROOT::Math::MatRepSym<float,4> >::SMatrixRow
- ROOT::Math::SMatrix<float,4,4,ROOT::Math::MatRepSym<float,4> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,5,5,ROOT::Math::MatRepStd<float,5,5> >
- ROOT::Math::SMatrix<float,5,5,ROOT::Math::MatRepStd<float,5,5> >::SMatrixRow
- ROOT::Math::SMatrix<float,5,5,ROOT::Math::MatRepStd<float,5,5> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,5,5,ROOT::Math::MatRepSym<float,5> >
- ROOT::Math::SMatrix<float,5,5,ROOT::Math::MatRepSym<float,5> >::SMatrixRow
- ROOT::Math::SMatrix<float,5,5,ROOT::Math::MatRepSym<float,5> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,6,6,ROOT::Math::MatRepStd<float,6,6> >
- ROOT::Math::SMatrix<float,6,6,ROOT::Math::MatRepStd<float,6,6> >::SMatrixRow
- ROOT::Math::SMatrix<float,6,6,ROOT::Math::MatRepStd<float,6,6> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,6,6,ROOT::Math::MatRepSym<float,6> >
- ROOT::Math::SMatrix<float,6,6,ROOT::Math::MatRepSym<float,6> >::SMatrixRow
- ROOT::Math::SMatrix<float,6,6,ROOT::Math::MatRepSym<float,6> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,7,7,ROOT::Math::MatRepStd<float,7,7> >
- ROOT::Math::SMatrix<float,7,7,ROOT::Math::MatRepStd<float,7,7> >::SMatrixRow
- ROOT::Math::SMatrix<float,7,7,ROOT::Math::MatRepStd<float,7,7> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,7,7,ROOT::Math::MatRepSym<float,7> >
- ROOT::Math::SMatrix<float,7,7,ROOT::Math::MatRepSym<float,7> >::SMatrixRow
- ROOT::Math::SMatrix<float,7,7,ROOT::Math::MatRepSym<float,7> >::SMatrixRow_const
- ROOT::Math::SMatrix<float,9,7,ROOT::Math::MatRepStd<float,9,7> >
- ROOT::Math::SMatrix<float,9,7,ROOT::Math::MatRepStd<float,9,7> >::SMatrixRow
- ROOT::Math::SMatrix<float,9,7,ROOT::Math::MatRepStd<float,9,7> >::SMatrixRow_const
- ROOT::Math::SMatrixIdentity
- ROOT::Math::SMatrixSym2D
- ROOT::Math::SMatrixSym2F
- ROOT::Math::SMatrixSym3D
- ROOT::Math::SMatrixSym3F
- ROOT::Math::SMatrixSym4D
- ROOT::Math::SMatrixSym4F
- ROOT::Math::SMatrixSym5D
- ROOT::Math::SMatrixSym5F
- ROOT::Math::SMatrixSym6D
- ROOT::Math::SMatrixSym6F
- ROOT::Math::SMatrixSym7D
- ROOT::Math::SMatrixSym7F
- ROOT::Math::SVector<Double32_t,3>
- ROOT::Math::SVector<Double32_t,4>
- ROOT::Math::SVector<Double32_t,5>
- ROOT::Math::SVector<Double32_t,6>
- ROOT::Math::SVector<double,2>
- ROOT::Math::SVector<double,3>
- ROOT::Math::SVector<double,4>
- ROOT::Math::SVector<double,5>
- ROOT::Math::SVector<double,6>
- ROOT::Math::SVector<double,7>
- ROOT::Math::SVector<float,2>
- ROOT::Math::SVector<float,3>
- ROOT::Math::SVector<float,4>
- ROOT::Math::SVector<float,5>
- ROOT::Math::SVector<float,6>
- ROOT::Math::SVector<float,7>