aboutsummaryrefslogtreecommitdiff
path: root/doc/snippets/Tridiagonalization_decomposeInPlace.cpp
blob: 3cdce679b2e96b6507f597f5e5575a735bec9e19 (plain)
1
2
3
4
5
6
7
8
9
10
11
MatrixXd X = MatrixXd::Random(5,5);
MatrixXd A = X + X.transpose();
cout << "Here is a random symmetric 5x5 matrix:" << endl << A << endl << endl;

VectorXd diag(5);
VectorXd subdiag(4);
VectorXd hcoeffs(4);  // Scratch space for householder reflector.
internal::tridiagonalization_inplace(A, diag, subdiag, hcoeffs, true);
cout << "The orthogonal matrix Q is:" << endl << A << endl;
cout << "The diagonal of the tridiagonal matrix T is:" << endl << diag << endl;
cout << "The subdiagonal of the tridiagonal matrix T is:" << endl << subdiag << endl;