2#include "./InternalHeaderCheck.h"
9template <
typename Scalar>
10void qrsolv(Matrix<Scalar, Dynamic, Dynamic> &s,
12 const VectorXi &ipvt,
const Matrix<Scalar, Dynamic, 1> &diag,
const Matrix<Scalar, Dynamic, 1> &qtb,
13 Matrix<Scalar, Dynamic, 1> &x, Matrix<Scalar, Dynamic, 1> &sdiag)
16 typedef DenseIndex
Index;
22 Matrix<Scalar, Dynamic, 1> wa(n);
23 JacobiRotation<Scalar> givens;
34 s.topLeftCorner(n, n).template triangularView<StrictlyLower>() = s.topLeftCorner(n, n).transpose();
37 for (j = 0; j < n; ++j) {
41 if (diag[l] == 0.)
break;
42 sdiag.tail(n - j).setZero();
49 for (k = j; k < n; ++k) {
52 givens.makeGivens(-s(k, k), sdiag[k]);
56 s(k, k) = givens.c() * s(k, k) + givens.s() * sdiag[k];
57 temp = givens.c() * wa[k] + givens.s() * qtbpj;
58 qtbpj = -givens.s() * wa[k] + givens.c() * qtbpj;
62 for (i = k + 1; i < n; ++i) {
63 temp = givens.c() * s(i, k) + givens.s() * sdiag[i];
64 sdiag[i] = -givens.s() * s(i, k) + givens.c() * sdiag[i];
73 for (nsing = 0; nsing < n && sdiag[nsing] != 0; nsing++) {
76 wa.tail(n - nsing).setZero();
77 s.topLeftCorner(nsing, nsing).transpose().template triangularView<Upper>().solveInPlace(wa.head(nsing));
84 for (j = 0; j < n; ++j) x[ipvt[j]] = wa[j];
Matrix< int, Dynamic, 1 > VectorXi
Namespace containing all symbols from the Eigen library.
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index