14 #ifndef EIGEN_LMONESTEP_H
15 #define EIGEN_LMONESTEP_H
22 template <
typename FunctorType>
28 RealScalar pnorm, xnorm, fnorm1, actred, dirder, prered;
34 Index df_ret = m_functor.df(
x, m_fjac);
43 for (
int j = 0;
j <
x.size(); ++
j) m_wa2(
j) = m_fjac.col(
j).blueNorm();
50 m_rfactor = qrfac.matrixR();
51 m_permutation = (qrfac.colsPermutation());
56 if (!m_useExternalScaling)
57 for (
Index j = 0;
j <
n; ++
j) m_diag[
j] = (m_wa2[
j] == 0.) ? 1. : m_wa2[
j];
61 xnorm = m_diag.cwiseProduct(
x).stableNorm();
62 m_delta = m_factor * xnorm;
63 if (m_delta == 0.) m_delta = m_factor;
69 m_wa4 = qrfac.matrixQ().adjoint() * m_fvec;
70 m_qtf = m_wa4.head(
n);
76 if (m_wa2[m_permutation.indices()[
j]] != 0.)
77 m_gnorm = (
std::max)(m_gnorm,
abs(m_rfactor.col(
j).head(
j + 1).dot(m_qtf.head(
j + 1) / m_fnorm) /
78 m_wa2[m_permutation.indices()[
j]]));
81 if (m_gnorm <= m_gtol) {
87 if (!m_useExternalScaling) m_diag = m_diag.cwiseMax(m_wa2);
96 pnorm = m_diag.cwiseProduct(m_wa1).stableNorm();
99 if (m_iter == 1) m_delta = (
std::min)(m_delta, pnorm);
104 fnorm1 = m_wa4.stableNorm();
112 m_wa3 = m_rfactor.template triangularView<Upper>() * (m_permutation.inverse() * m_wa1);
115 prered = temp1 + temp2 /
Scalar(.5);
116 dirder = -(temp1 + temp2);
121 if (prered != 0.) ratio = actred / prered;
124 if (ratio <=
Scalar(.25)) {
131 }
else if (!(m_par != 0. && ratio <
RealScalar(.75))) {
140 m_wa2 = m_diag.cwiseProduct(
x);
142 xnorm = m_wa2.stableNorm();
148 if (
abs(actred) <= m_ftol && prered <= m_ftol &&
Scalar(.5) * ratio <= 1. && m_delta <= m_xtol * xnorm) {
152 if (
abs(actred) <= m_ftol && prered <= m_ftol &&
Scalar(.5) * ratio <= 1.) {
156 if (m_delta <= m_xtol * xnorm) {
162 if (m_nfev >= m_maxfev) {
167 Scalar(.5) * ratio <= 1.) {
180 }
while (ratio <
Scalar(1
e-4));
AnnoyingScalar abs(const AnnoyingScalar &x)
Definition: AnnoyingScalar.h:135
AnnoyingScalar sqrt(const AnnoyingScalar &x)
Definition: AnnoyingScalar.h:134
const unsigned n
Definition: CG3DPackingUnitTest.cpp:11
Array< double, 1, 3 > e(1./3., 0.5, 2.)
#define eigen_assert(x)
Definition: Macros.h:910
SCALAR Scalar
Definition: bench_gemm.cpp:45
NumTraits< Scalar >::Real RealScalar
Definition: bench_gemm.cpp:46
FunctorType::QRSolver QRSolver
Definition: LevenbergMarquardt/LevenbergMarquardt.h:105
LevenbergMarquardtSpace::Status minimizeOneStep(FVectorType &x)
Definition: LMonestep.h:23
JacobianType::RealScalar RealScalar
Definition: LevenbergMarquardt/LevenbergMarquardt.h:108
DenseIndex Index
Definition: NonLinearOptimization/LevenbergMarquardt.h:60
#define min(a, b)
Definition: datatypes.h:22
#define max(a, b)
Definition: datatypes.h:23
@ NumericalIssue
Definition: Constants.h:442
@ Success
Definition: Constants.h:440
@ NoConvergence
Definition: Constants.h:444
Status
Definition: LevenbergMarquardt/LevenbergMarquardt.h:27
@ RelativeReductionTooSmall
Definition: LevenbergMarquardt/LevenbergMarquardt.h:31
@ GtolTooSmall
Definition: LevenbergMarquardt/LevenbergMarquardt.h:38
@ UserAsked
Definition: LevenbergMarquardt/LevenbergMarquardt.h:39
@ Running
Definition: LevenbergMarquardt/LevenbergMarquardt.h:29
@ FtolTooSmall
Definition: LevenbergMarquardt/LevenbergMarquardt.h:36
@ TooManyFunctionEvaluation
Definition: LevenbergMarquardt/LevenbergMarquardt.h:35
@ XtolTooSmall
Definition: LevenbergMarquardt/LevenbergMarquardt.h:37
@ CosinusTooSmall
Definition: LevenbergMarquardt/LevenbergMarquardt.h:34
@ RelativeErrorTooSmall
Definition: LevenbergMarquardt/LevenbergMarquardt.h:32
@ ImproperInputParameters
Definition: LevenbergMarquardt/LevenbergMarquardt.h:30
@ RelativeErrorAndReductionTooSmall
Definition: LevenbergMarquardt/LevenbergMarquardt.h:33
void lmpar2(const QRSolver &qr, const VectorType &diag, const VectorType &qtb, typename VectorType::Scalar m_delta, typename VectorType::Scalar &par, VectorType &x)
Definition: LMpar.h:23
EIGEN_DEVICE_FUNC bool abs2(bool x)
Definition: MathFunctions.h:1102
Namespace containing all symbols from the Eigen library.
Definition: bench_norm.cpp:70
list x
Definition: plotDoE.py:28
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
Definition: NumTraits.h:217
std::ptrdiff_t j
Definition: tut_arithmetic_redux_minmax.cpp:2