template<typename _MatrixType>
class Eigen::BDCSVD< _MatrixType >
class Bidiagonal Divide and Conquer SVD
- Template Parameters
-
_MatrixType | the type of the matrix of which we are computing the SVD decomposition |
This class first reduces the input matrix to bi-diagonal form using class UpperBidiagonalization, and then performs a divide-and-conquer diagonalization. Small blocks are diagonalized using class JacobiSVD. You can control the switching size with the setSwitchSize() method, default is 16. For small matrice (<16), it is thus preferable to directly use JacobiSVD. For larger ones, BDCSVD is highly recommended and can several order of magnitude faster.
- Warning
- this algorithm is unlikely to provide accurate result when compiled with unsafe math optimizations. For instance, this concerns Intel's compiler (ICC), which perfroms such optimization by default unless you compile with the
-fp-model
precise
option. Likewise, the -ffast-math
option of GCC or clang will significantly degrade the accuracy.
- See also
- class JacobiSVD
|
| BDCSVD () |
| Default Constructor. More...
|
|
| BDCSVD (const MatrixType &matrix, unsigned int computationOptions=0) |
| Constructor performing the decomposition of given matrix. More...
|
|
| BDCSVD (Index rows, Index cols, unsigned int computationOptions=0) |
| Default Constructor with memory preallocation. More...
|
|
BDCSVD & | compute (const MatrixType &matrix) |
| Method performing the decomposition of given matrix using current options. More...
|
|
BDCSVD & | compute (const MatrixType &matrix, unsigned int computationOptions) |
| Method performing the decomposition of given matrix using custom options. More...
|
|
bool | computeU () const |
|
bool | computeV () const |
|