blob: 0a1fea1ea1566d693c14030a46621334e61d3aeb [file] [edit]
// IWYU pragma: private
// SPDX-FileCopyrightText: The Eigen Authors
// SPDX-License-Identifier: MPL-2.0
#ifndef EIGEN_NONLINEAROPTIMIZATION_R1MPYQ_H
#define EIGEN_NONLINEAROPTIMIZATION_R1MPYQ_H
#include "./InternalHeaderCheck.h"
namespace Eigen {
namespace internal {
// TODO : move this to GivensQR once there's such a thing in Eigen
template <typename Scalar>
void r1mpyq(DenseIndex m, DenseIndex n, Scalar *a, const std::vector<JacobiRotation<Scalar> > &v_givens,
const std::vector<JacobiRotation<Scalar> > &w_givens) {
typedef DenseIndex Index;
/* apply the first set of givens rotations to a. */
for (Index j = n - 2; j >= 0; --j)
for (Index i = 0; i < m; ++i) {
Scalar temp = v_givens[j].c() * a[i + m * j] - v_givens[j].s() * a[i + m * (n - 1)];
a[i + m * (n - 1)] = v_givens[j].s() * a[i + m * j] + v_givens[j].c() * a[i + m * (n - 1)];
a[i + m * j] = temp;
}
/* apply the second set of givens rotations to a. */
for (Index j = 0; j < n - 1; ++j)
for (Index i = 0; i < m; ++i) {
Scalar temp = w_givens[j].c() * a[i + m * j] + w_givens[j].s() * a[i + m * (n - 1)];
a[i + m * (n - 1)] = -w_givens[j].s() * a[i + m * j] + w_givens[j].c() * a[i + m * (n - 1)];
a[i + m * j] = temp;
}
}
} // end namespace internal
} // end namespace Eigen
#endif // EIGEN_NONLINEAROPTIMIZATION_R1MPYQ_H