mirror of
https://gitlab.com/libeigen/eigen.git
synced 2024-12-21 07:19:46 +08:00
765219aa51
* rename Cholesky to LLT * rename CholeskyWithoutSquareRoot to LDLT * rename MatrixBase::cholesky() to llt() * rename MatrixBase::choleskyNoSqrt() to ldlt() * make {LLT,LDLT}::solve() API consistent with other modules Note that we are going to keep a source compatibility untill the next beta release. E.g., the "old" Cholesky* classes, etc are still available for some time. To be clear, Eigen beta2 should be (hopefully) source compatible with beta1, and so beta2 will contain all the deprecated API of beta1. Those features marked as deprecated will be removed in beta3 (or in the final 2.0 if there is no beta 3 !). Also includes various updated in sparse Cholesky.
9 lines
459 B
C++
9 lines
459 B
C++
typedef Matrix<float,Dynamic,2> DataMatrix;
|
|
// let's generate some samples on the 3D plane of equation z = 2x+3y (with some noise)
|
|
DataMatrix samples = DataMatrix::Random(12,2);
|
|
VectorXf elevations = 2*samples.col(0) + 3*samples.col(1) + VectorXf::Random(12)*0.1;
|
|
// and let's solve samples * [x y]^T = elevations in least square sense:
|
|
Matrix<float,2,1> xy;
|
|
(samples.adjoint() * samples).llt().solve((samples.adjoint()*elevations), &xy);
|
|
cout << xy << endl;
|