HybridNonLinearSolver.h
Go to the documentation of this file.
1 // -*- coding: utf-8
2 // vim: set fileencoding=utf-8
3 
4 // This file is part of Eigen, a lightweight C++ template library
5 // for linear algebra.
6 //
7 // Copyright (C) 2009 Thomas Capricelli <orzel@freehackers.org>
8 //
9 // This Source Code Form is subject to the terms of the Mozilla
10 // Public License v. 2.0. If a copy of the MPL was not distributed
11 // with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
12 
13 #ifndef EIGEN_HYBRIDNONLINEARSOLVER_H
14 #define EIGEN_HYBRIDNONLINEARSOLVER_H
15 
16 namespace Eigen {
17 
18 namespace HybridNonLinearSolverSpace {
19  enum Status {
20  Running = -1,
28  };
29 }
30 
42 template<typename FunctorType, typename Scalar=double>
44 {
45 public:
46  typedef DenseIndex Index;
47 
48  HybridNonLinearSolver(FunctorType &_functor)
49  : functor(_functor) { nfev=njev=iter = 0; fnorm= 0.; useExternalScaling=false;}
50 
51  struct Parameters {
53  : factor(Scalar(100.))
54  , maxfev(1000)
55  , xtol(numext::sqrt(NumTraits<Scalar>::epsilon()))
56  , nb_of_subdiagonals(-1)
58  , epsfcn(Scalar(0.)) {}
60  Index maxfev; // maximum number of function evaluation
65  };
68  /* TODO: if eigen provides a triangular storage, use it here */
70 
72  FVectorType &x,
74  );
75 
79 
81  FVectorType &x,
83  );
84 
88 
99 private:
100  FunctorType &functor;
103  bool sing;
106  bool jeval;
114 
116 };
117 
118 
119 
120 template<typename FunctorType, typename Scalar>
123  FVectorType &x,
124  const Scalar tol
125  )
126 {
127  n = x.size();
128 
129  /* check the input parameters for errors. */
130  if (n <= 0 || tol < 0.)
132 
133  resetParameters();
134  parameters.maxfev = 100*(n+1);
135  parameters.xtol = tol;
136  diag.setConstant(n, 1.);
137  useExternalScaling = true;
138  return solve(x);
139 }
140 
141 template<typename FunctorType, typename Scalar>
144 {
145  n = x.size();
146 
147  wa1.resize(n); wa2.resize(n); wa3.resize(n); wa4.resize(n);
148  fvec.resize(n);
149  qtf.resize(n);
150  fjac.resize(n, n);
151  if (!useExternalScaling)
152  diag.resize(n);
153  eigen_assert( (!useExternalScaling || diag.size()==n) && "When useExternalScaling is set, the caller must provide a valid 'diag'");
154 
155  /* Function Body */
156  nfev = 0;
157  njev = 0;
158 
159  /* check the input parameters for errors. */
160  if (n <= 0 || parameters.xtol < 0. || parameters.maxfev <= 0 || parameters.factor <= 0. )
162  if (useExternalScaling)
163  for (Index j = 0; j < n; ++j)
164  if (diag[j] <= 0.)
166 
167  /* evaluate the function at the starting point */
168  /* and calculate its norm. */
169  nfev = 1;
170  if ( functor(x, fvec) < 0)
172  fnorm = fvec.stableNorm();
173 
174  /* initialize iteration counter and monitors. */
175  iter = 1;
176  ncsuc = 0;
177  ncfail = 0;
178  nslow1 = 0;
179  nslow2 = 0;
180 
182 }
183 
184 template<typename FunctorType, typename Scalar>
187 {
188  using std::abs;
189 
190  eigen_assert(x.size()==n); // check the caller is not cheating us
191 
192  Index j;
193  std::vector<JacobiRotation<Scalar> > v_givens(n), w_givens(n);
194 
195  jeval = true;
196 
197  /* calculate the jacobian matrix. */
198  if ( functor.df(x, fjac) < 0)
200  ++njev;
201 
202  wa2 = fjac.colwise().blueNorm();
203 
204  /* on the first iteration and if external scaling is not used, scale according */
205  /* to the norms of the columns of the initial jacobian. */
206  if (iter == 1) {
207  if (!useExternalScaling)
208  for (j = 0; j < n; ++j)
209  diag[j] = (wa2[j]==0.) ? 1. : wa2[j];
210 
211  /* on the first iteration, calculate the norm of the scaled x */
212  /* and initialize the step bound delta. */
213  xnorm = diag.cwiseProduct(x).stableNorm();
214  delta = parameters.factor * xnorm;
215  if (delta == 0.)
216  delta = parameters.factor;
217  }
218 
219  /* compute the qr factorization of the jacobian. */
220  HouseholderQR<JacobianType> qrfac(fjac); // no pivoting:
221 
222  /* copy the triangular factor of the qr factorization into r. */
223  R = qrfac.matrixQR();
224 
225  /* accumulate the orthogonal factor in fjac. */
226  fjac = qrfac.householderQ();
227 
228  /* form (q transpose)*fvec and store in qtf. */
229  qtf = fjac.transpose() * fvec;
230 
231  /* rescale if necessary. */
232  if (!useExternalScaling)
233  diag = diag.cwiseMax(wa2);
234 
235  while (true) {
236  /* determine the direction p. */
237  internal::dogleg<Scalar>(R, diag, qtf, delta, wa1);
238 
239  /* store the direction p and x + p. calculate the norm of p. */
240  wa1 = -wa1;
241  wa2 = x + wa1;
242  pnorm = diag.cwiseProduct(wa1).stableNorm();
243 
244  /* on the first iteration, adjust the initial step bound. */
245  if (iter == 1)
246  delta = (std::min)(delta,pnorm);
247 
248  /* evaluate the function at x + p and calculate its norm. */
249  if ( functor(wa2, wa4) < 0)
251  ++nfev;
252  fnorm1 = wa4.stableNorm();
253 
254  /* compute the scaled actual reduction. */
255  actred = -1.;
256  if (fnorm1 < fnorm) /* Computing 2nd power */
257  actred = 1. - numext::abs2(fnorm1 / fnorm);
258 
259  /* compute the scaled predicted reduction. */
260  wa3 = R.template triangularView<Upper>()*wa1 + qtf;
261  temp = wa3.stableNorm();
262  prered = 0.;
263  if (temp < fnorm) /* Computing 2nd power */
264  prered = 1. - numext::abs2(temp / fnorm);
265 
266  /* compute the ratio of the actual to the predicted reduction. */
267  ratio = 0.;
268  if (prered > 0.)
269  ratio = actred / prered;
270 
271  /* update the step bound. */
272  if (ratio < Scalar(.1)) {
273  ncsuc = 0;
274  ++ncfail;
275  delta = Scalar(.5) * delta;
276  } else {
277  ncfail = 0;
278  ++ncsuc;
279  if (ratio >= Scalar(.5) || ncsuc > 1)
280  delta = (std::max)(delta, pnorm / Scalar(.5));
281  if (abs(ratio - 1.) <= Scalar(.1)) {
282  delta = pnorm / Scalar(.5);
283  }
284  }
285 
286  /* test for successful iteration. */
287  if (ratio >= Scalar(1e-4)) {
288  /* successful iteration. update x, fvec, and their norms. */
289  x = wa2;
290  wa2 = diag.cwiseProduct(x);
291  fvec = wa4;
292  xnorm = wa2.stableNorm();
293  fnorm = fnorm1;
294  ++iter;
295  }
296 
297  /* determine the progress of the iteration. */
298  ++nslow1;
299  if (actred >= Scalar(.001))
300  nslow1 = 0;
301  if (jeval)
302  ++nslow2;
303  if (actred >= Scalar(.1))
304  nslow2 = 0;
305 
306  /* test for convergence. */
307  if (delta <= parameters.xtol * xnorm || fnorm == 0.)
309 
310  /* tests for termination and stringent tolerances. */
311  if (nfev >= parameters.maxfev)
313  if (Scalar(.1) * (std::max)(Scalar(.1) * delta, pnorm) <= NumTraits<Scalar>::epsilon() * xnorm)
315  if (nslow2 == 5)
317  if (nslow1 == 10)
319 
320  /* criterion for recalculating jacobian. */
321  if (ncfail == 2)
322  break; // leave inner loop and go for the next outer loop iteration
323 
324  /* calculate the rank one modification to the jacobian */
325  /* and update qtf if necessary. */
326  wa1 = diag.cwiseProduct( diag.cwiseProduct(wa1)/pnorm );
327  wa2 = fjac.transpose() * wa4;
328  if (ratio >= Scalar(1e-4))
329  qtf = wa2;
330  wa2 = (wa2-wa3)/pnorm;
331 
332  /* compute the qr factorization of the updated jacobian. */
333  internal::r1updt<Scalar>(R, wa1, v_givens, w_givens, wa2, wa3, &sing);
334  internal::r1mpyq<Scalar>(n, n, fjac.data(), v_givens, w_givens);
335  internal::r1mpyq<Scalar>(1, n, qtf.data(), v_givens, w_givens);
336 
337  jeval = false;
338  }
340 }
341 
342 template<typename FunctorType, typename Scalar>
345 {
346  HybridNonLinearSolverSpace::Status status = solveInit(x);
348  return status;
350  status = solveOneStep(x);
351  return status;
352 }
353 
354 
355 
356 template<typename FunctorType, typename Scalar>
359  FVectorType &x,
360  const Scalar tol
361  )
362 {
363  n = x.size();
364 
365  /* check the input parameters for errors. */
366  if (n <= 0 || tol < 0.)
368 
369  resetParameters();
370  parameters.maxfev = 200*(n+1);
371  parameters.xtol = tol;
372 
373  diag.setConstant(n, 1.);
374  useExternalScaling = true;
375  return solveNumericalDiff(x);
376 }
377 
378 template<typename FunctorType, typename Scalar>
381 {
382  n = x.size();
383 
384  if (parameters.nb_of_subdiagonals<0) parameters.nb_of_subdiagonals= n-1;
385  if (parameters.nb_of_superdiagonals<0) parameters.nb_of_superdiagonals= n-1;
386 
387  wa1.resize(n); wa2.resize(n); wa3.resize(n); wa4.resize(n);
388  qtf.resize(n);
389  fjac.resize(n, n);
390  fvec.resize(n);
391  if (!useExternalScaling)
392  diag.resize(n);
393  eigen_assert( (!useExternalScaling || diag.size()==n) && "When useExternalScaling is set, the caller must provide a valid 'diag'");
394 
395  /* Function Body */
396  nfev = 0;
397  njev = 0;
398 
399  /* check the input parameters for errors. */
400  if (n <= 0 || parameters.xtol < 0. || parameters.maxfev <= 0 || parameters.nb_of_subdiagonals< 0 || parameters.nb_of_superdiagonals< 0 || parameters.factor <= 0. )
402  if (useExternalScaling)
403  for (Index j = 0; j < n; ++j)
404  if (diag[j] <= 0.)
406 
407  /* evaluate the function at the starting point */
408  /* and calculate its norm. */
409  nfev = 1;
410  if ( functor(x, fvec) < 0)
412  fnorm = fvec.stableNorm();
413 
414  /* initialize iteration counter and monitors. */
415  iter = 1;
416  ncsuc = 0;
417  ncfail = 0;
418  nslow1 = 0;
419  nslow2 = 0;
420 
422 }
423 
424 template<typename FunctorType, typename Scalar>
427 {
428  using std::sqrt;
429  using std::abs;
430 
431  assert(x.size()==n); // check the caller is not cheating us
432 
433  Index j;
434  std::vector<JacobiRotation<Scalar> > v_givens(n), w_givens(n);
435 
436  jeval = true;
437  if (parameters.nb_of_subdiagonals<0) parameters.nb_of_subdiagonals= n-1;
438  if (parameters.nb_of_superdiagonals<0) parameters.nb_of_superdiagonals= n-1;
439 
440  /* calculate the jacobian matrix. */
441  if (internal::fdjac1(functor, x, fvec, fjac, parameters.nb_of_subdiagonals, parameters.nb_of_superdiagonals, parameters.epsfcn) <0)
443  nfev += (std::min)(parameters.nb_of_subdiagonals+parameters.nb_of_superdiagonals+ 1, n);
444 
445  wa2 = fjac.colwise().blueNorm();
446 
447  /* on the first iteration and if external scaling is not used, scale according */
448  /* to the norms of the columns of the initial jacobian. */
449  if (iter == 1) {
450  if (!useExternalScaling)
451  for (j = 0; j < n; ++j)
452  diag[j] = (wa2[j]==0.) ? 1. : wa2[j];
453 
454  /* on the first iteration, calculate the norm of the scaled x */
455  /* and initialize the step bound delta. */
456  xnorm = diag.cwiseProduct(x).stableNorm();
457  delta = parameters.factor * xnorm;
458  if (delta == 0.)
459  delta = parameters.factor;
460  }
461 
462  /* compute the qr factorization of the jacobian. */
463  HouseholderQR<JacobianType> qrfac(fjac); // no pivoting:
464 
465  /* copy the triangular factor of the qr factorization into r. */
466  R = qrfac.matrixQR();
467 
468  /* accumulate the orthogonal factor in fjac. */
469  fjac = qrfac.householderQ();
470 
471  /* form (q transpose)*fvec and store in qtf. */
472  qtf = fjac.transpose() * fvec;
473 
474  /* rescale if necessary. */
475  if (!useExternalScaling)
476  diag = diag.cwiseMax(wa2);
477 
478  while (true) {
479  /* determine the direction p. */
480  internal::dogleg<Scalar>(R, diag, qtf, delta, wa1);
481 
482  /* store the direction p and x + p. calculate the norm of p. */
483  wa1 = -wa1;
484  wa2 = x + wa1;
485  pnorm = diag.cwiseProduct(wa1).stableNorm();
486 
487  /* on the first iteration, adjust the initial step bound. */
488  if (iter == 1)
489  delta = (std::min)(delta,pnorm);
490 
491  /* evaluate the function at x + p and calculate its norm. */
492  if ( functor(wa2, wa4) < 0)
494  ++nfev;
495  fnorm1 = wa4.stableNorm();
496 
497  /* compute the scaled actual reduction. */
498  actred = -1.;
499  if (fnorm1 < fnorm) /* Computing 2nd power */
500  actred = 1. - numext::abs2(fnorm1 / fnorm);
501 
502  /* compute the scaled predicted reduction. */
503  wa3 = R.template triangularView<Upper>()*wa1 + qtf;
504  temp = wa3.stableNorm();
505  prered = 0.;
506  if (temp < fnorm) /* Computing 2nd power */
507  prered = 1. - numext::abs2(temp / fnorm);
508 
509  /* compute the ratio of the actual to the predicted reduction. */
510  ratio = 0.;
511  if (prered > 0.)
512  ratio = actred / prered;
513 
514  /* update the step bound. */
515  if (ratio < Scalar(.1)) {
516  ncsuc = 0;
517  ++ncfail;
518  delta = Scalar(.5) * delta;
519  } else {
520  ncfail = 0;
521  ++ncsuc;
522  if (ratio >= Scalar(.5) || ncsuc > 1)
523  delta = (std::max)(delta, pnorm / Scalar(.5));
524  if (abs(ratio - 1.) <= Scalar(.1)) {
525  delta = pnorm / Scalar(.5);
526  }
527  }
528 
529  /* test for successful iteration. */
530  if (ratio >= Scalar(1e-4)) {
531  /* successful iteration. update x, fvec, and their norms. */
532  x = wa2;
533  wa2 = diag.cwiseProduct(x);
534  fvec = wa4;
535  xnorm = wa2.stableNorm();
536  fnorm = fnorm1;
537  ++iter;
538  }
539 
540  /* determine the progress of the iteration. */
541  ++nslow1;
542  if (actred >= Scalar(.001))
543  nslow1 = 0;
544  if (jeval)
545  ++nslow2;
546  if (actred >= Scalar(.1))
547  nslow2 = 0;
548 
549  /* test for convergence. */
550  if (delta <= parameters.xtol * xnorm || fnorm == 0.)
552 
553  /* tests for termination and stringent tolerances. */
554  if (nfev >= parameters.maxfev)
556  if (Scalar(.1) * (std::max)(Scalar(.1) * delta, pnorm) <= NumTraits<Scalar>::epsilon() * xnorm)
558  if (nslow2 == 5)
560  if (nslow1 == 10)
562 
563  /* criterion for recalculating jacobian. */
564  if (ncfail == 2)
565  break; // leave inner loop and go for the next outer loop iteration
566 
567  /* calculate the rank one modification to the jacobian */
568  /* and update qtf if necessary. */
569  wa1 = diag.cwiseProduct( diag.cwiseProduct(wa1)/pnorm );
570  wa2 = fjac.transpose() * wa4;
571  if (ratio >= Scalar(1e-4))
572  qtf = wa2;
573  wa2 = (wa2-wa3)/pnorm;
574 
575  /* compute the qr factorization of the updated jacobian. */
576  internal::r1updt<Scalar>(R, wa1, v_givens, w_givens, wa2, wa3, &sing);
577  internal::r1mpyq<Scalar>(n, n, fjac.data(), v_givens, w_givens);
578  internal::r1mpyq<Scalar>(1, n, qtf.data(), v_givens, w_givens);
579 
580  jeval = false;
581  }
583 }
584 
585 template<typename FunctorType, typename Scalar>
588 {
589  HybridNonLinearSolverSpace::Status status = solveNumericalDiffInit(x);
591  return status;
593  status = solveNumericalDiffOneStep(x);
594  return status;
595 }
596 
597 } // end namespace Eigen
598 
599 #endif // EIGEN_HYBRIDNONLINEARSOLVER_H
600 
601 //vim: ai ts=4 sts=4 et sw=4
Eigen
Namespace containing all symbols from the Eigen library.
Definition: jet.h:637
Eigen::HybridNonLinearSolver::resetParameters
void resetParameters(void)
Definition: HybridNonLinearSolver.h:89
Eigen::HybridNonLinearSolver::sum
Scalar sum
Definition: HybridNonLinearSolver.h:102
e
Array< double, 1, 3 > e(1./3., 0.5, 2.)
Eigen::HybridNonLinearSolver::jeval
bool jeval
Definition: HybridNonLinearSolver.h:106
Eigen::HybridNonLinearSolver::solveInit
HybridNonLinearSolverSpace::Status solveInit(FVectorType &x)
Definition: HybridNonLinearSolver.h:143
Eigen::HybridNonLinearSolver::hybrj1
HybridNonLinearSolverSpace::Status hybrj1(FVectorType &x, const Scalar tol=numext::sqrt(NumTraits< Scalar >::epsilon()))
Definition: HybridNonLinearSolver.h:122
Eigen::HybridNonLinearSolver::diag
FVectorType diag
Definition: HybridNonLinearSolver.h:91
Eigen::HybridNonLinearSolver::wa1
FVectorType wa1
Definition: HybridNonLinearSolver.h:113
eigen_assert
#define eigen_assert(x)
Definition: Macros.h:1037
gtsam::diag
Matrix diag(const std::vector< Matrix > &Hs)
Definition: Matrix.cpp:207
x
set noclip points set clip one set noclip two set bar set border lt lw set xdata set ydata set zdata set x2data set y2data set boxwidth set dummy x
Definition: gnuplot_common_settings.hh:12
Eigen::HybridNonLinearSolverSpace::Status
Status
Definition: HybridNonLinearSolver.h:19
Eigen::HybridNonLinearSolver::fnorm
Scalar fnorm
Definition: HybridNonLinearSolver.h:97
Eigen::HybridNonLinearSolverSpace::ImproperInputParameters
@ ImproperInputParameters
Definition: HybridNonLinearSolver.h:21
Eigen::PlainObjectBase::resize
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE void resize(Index rows, Index cols)
Definition: PlainObjectBase.h:271
Eigen::HybridNonLinearSolver::qtf
FVectorType qtf
Definition: HybridNonLinearSolver.h:91
Eigen::HybridNonLinearSolverSpace::Running
@ Running
Definition: HybridNonLinearSolver.h:20
Eigen::HybridNonLinearSolver::Parameters::maxfev
Index maxfev
Definition: HybridNonLinearSolver.h:60
Eigen::HybridNonLinearSolver::HybridNonLinearSolver
HybridNonLinearSolver(FunctorType &_functor)
Definition: HybridNonLinearSolver.h:48
Eigen::HybridNonLinearSolver::pnorm
Scalar pnorm
Definition: HybridNonLinearSolver.h:109
Eigen::HybridNonLinearSolver::njev
Index njev
Definition: HybridNonLinearSolver.h:95
Eigen::HybridNonLinearSolver::Parameters
Definition: HybridNonLinearSolver.h:51
Eigen::HybridNonLinearSolver::fvec
FVectorType fvec
Definition: HybridNonLinearSolver.h:91
Eigen::HybridNonLinearSolver::ncfail
Index ncfail
Definition: HybridNonLinearSolver.h:111
n
int n
Definition: BiCGSTAB_simple.cpp:1
epsilon
static double epsilon
Definition: testRot3.cpp:37
Eigen::PlainObjectBase::setConstant
EIGEN_DEVICE_FUNC Derived & setConstant(Index size, const Scalar &val)
Definition: CwiseNullaryOp.h:361
Eigen::HybridNonLinearSolver::functor
FunctorType & functor
Definition: HybridNonLinearSolver.h:100
Eigen::HouseholderQR::householderQ
HouseholderSequenceType householderQ() const
Definition: HouseholderQR.h:163
gtsam.examples.PlanarManipulatorExample.delta
def delta(g0, g1)
Definition: PlanarManipulatorExample.py:45
j
std::ptrdiff_t j
Definition: tut_arithmetic_redux_minmax.cpp:2
Eigen::HybridNonLinearSolver::FVectorType
Matrix< Scalar, Dynamic, 1 > FVectorType
Definition: HybridNonLinearSolver.h:66
Eigen::HybridNonLinearSolver::solve
HybridNonLinearSolverSpace::Status solve(FVectorType &x)
Definition: HybridNonLinearSolver.h:344
Eigen::HybridNonLinearSolver::solveNumericalDiffOneStep
HybridNonLinearSolverSpace::Status solveNumericalDiffOneStep(FVectorType &x)
Definition: HybridNonLinearSolver.h:426
Eigen::HybridNonLinearSolver::Parameters::nb_of_superdiagonals
Index nb_of_superdiagonals
Definition: HybridNonLinearSolver.h:63
Eigen::HybridNonLinearSolverSpace::UserAsked
@ UserAsked
Definition: HybridNonLinearSolver.h:27
Eigen::internal::fdjac1
DenseIndex fdjac1(const FunctorType &Functor, Matrix< Scalar, Dynamic, 1 > &x, Matrix< Scalar, Dynamic, 1 > &fvec, Matrix< Scalar, Dynamic, Dynamic > &fjac, DenseIndex ml, DenseIndex mu, Scalar epsfcn)
Definition: fdjac1.h:6
parameters
static ConjugateGradientParameters parameters
Definition: testIterative.cpp:33
Eigen::HybridNonLinearSolver::Parameters::factor
Scalar factor
Definition: HybridNonLinearSolver.h:59
Eigen::HybridNonLinearSolverSpace::NotMakingProgressIterations
@ NotMakingProgressIterations
Definition: HybridNonLinearSolver.h:26
Eigen::HouseholderQR::matrixQR
const MatrixType & matrixQR() const
Definition: HouseholderQR.h:172
Eigen::HybridNonLinearSolver::n
Index n
Definition: HybridNonLinearSolver.h:101
Eigen::HybridNonLinearSolver::nslow1
Index nslow1
Definition: HybridNonLinearSolver.h:110
Eigen::HybridNonLinearSolver::wa2
FVectorType wa2
Definition: HybridNonLinearSolver.h:113
Eigen::HybridNonLinearSolverSpace::TolTooSmall
@ TolTooSmall
Definition: HybridNonLinearSolver.h:24
Eigen::HybridNonLinearSolver::solveNumericalDiff
HybridNonLinearSolverSpace::Status solveNumericalDiff(FVectorType &x)
Definition: HybridNonLinearSolver.h:587
Eigen::HybridNonLinearSolver::solveNumericalDiffInit
HybridNonLinearSolverSpace::Status solveNumericalDiffInit(FVectorType &x)
Definition: HybridNonLinearSolver.h:380
anyset::size
size_t size() const
Definition: pytypes.h:2220
Eigen::HybridNonLinearSolver::ncsuc
Index ncsuc
Definition: HybridNonLinearSolver.h:107
Eigen::HybridNonLinearSolver::prered
Scalar prered
Definition: HybridNonLinearSolver.h:112
Eigen::HouseholderSequence::transpose
TransposeReturnType transpose() const
Transpose of the Householder sequence.
Definition: HouseholderSequence.h:236
Eigen::HybridNonLinearSolver::delta
Scalar delta
Definition: HybridNonLinearSolver.h:105
Eigen::HybridNonLinearSolver::sing
bool sing
Definition: HybridNonLinearSolver.h:103
Eigen::HybridNonLinearSolver::ratio
Scalar ratio
Definition: HybridNonLinearSolver.h:108
Eigen::HybridNonLinearSolver::Index
DenseIndex Index
Definition: HybridNonLinearSolver.h:46
Eigen::numext::abs2
EIGEN_DEVICE_FUNC bool abs2(bool x)
Definition: Eigen/src/Core/MathFunctions.h:1294
Eigen::HybridNonLinearSolver::wa3
FVectorType wa3
Definition: HybridNonLinearSolver.h:113
Eigen::HybridNonLinearSolver::useExternalScaling
bool useExternalScaling
Definition: HybridNonLinearSolver.h:98
Eigen::HybridNonLinearSolver::xnorm
Scalar xnorm
Definition: HybridNonLinearSolver.h:109
Eigen::DenseIndex
EIGEN_DEFAULT_DENSE_INDEX_TYPE DenseIndex
Definition: Meta.h:66
Eigen::HybridNonLinearSolver::hybrd1
HybridNonLinearSolverSpace::Status hybrd1(FVectorType &x, const Scalar tol=numext::sqrt(NumTraits< Scalar >::epsilon()))
Definition: HybridNonLinearSolver.h:358
iter
iterator iter(handle obj)
Definition: pytypes.h:2475
Eigen::HybridNonLinearSolver::iter
Index iter
Definition: HybridNonLinearSolver.h:96
ratio
set noclip points set clip one set noclip two set bar set border lt lw set xdata set ydata set zdata set x2data set y2data set boxwidth set dummy y set format x g set format y g set format x2 g set format y2 g set format z g set angles radians set nogrid set key title set key left top Right noreverse box linetype linewidth samplen spacing width set nolabel set noarrow set nologscale set logscale x set set pointsize set encoding default set nopolar set noparametric set set set set surface set nocontour set clabel set mapping cartesian set nohidden3d set cntrparam order set cntrparam linear set cntrparam levels auto set cntrparam points set size ratio
Definition: gnuplot_common_settings.hh:44
min
#define min(a, b)
Definition: datatypes.h:19
Eigen::HybridNonLinearSolver::nslow2
Index nslow2
Definition: HybridNonLinearSolver.h:110
gtsam::tol
const G double tol
Definition: Group.h:79
Eigen::HybridNonLinearSolver::UpperTriangularType
Matrix< Scalar, Dynamic, Dynamic > UpperTriangularType
Definition: HybridNonLinearSolver.h:69
Eigen::HybridNonLinearSolver::nfev
Index nfev
Definition: HybridNonLinearSolver.h:94
Eigen::Matrix< Scalar, Dynamic, 1 >
Eigen::HybridNonLinearSolver::JacobianType
Matrix< Scalar, Dynamic, Dynamic > JacobianType
Definition: HybridNonLinearSolver.h:67
Eigen::HybridNonLinearSolver::temp
Scalar temp
Definition: HybridNonLinearSolver.h:104
abs
#define abs(x)
Definition: datatypes.h:17
Eigen::HybridNonLinearSolverSpace::TooManyFunctionEvaluation
@ TooManyFunctionEvaluation
Definition: HybridNonLinearSolver.h:23
Eigen::HybridNonLinearSolver
Finds a zero of a system of n nonlinear functions in n variables by a modification of the Powell hybr...
Definition: HybridNonLinearSolver.h:43
Eigen::HybridNonLinearSolver::parameters
Parameters parameters
Definition: HybridNonLinearSolver.h:90
Eigen::HybridNonLinearSolver::Parameters::nb_of_subdiagonals
Index nb_of_subdiagonals
Definition: HybridNonLinearSolver.h:62
Eigen::HybridNonLinearSolver::R
UpperTriangularType R
Definition: HybridNonLinearSolver.h:93
Eigen::HybridNonLinearSolver::operator=
HybridNonLinearSolver & operator=(const HybridNonLinearSolver &)
Eigen::HybridNonLinearSolver::actred
Scalar actred
Definition: HybridNonLinearSolver.h:112
Eigen::HybridNonLinearSolver::Parameters::Parameters
Parameters()
Definition: HybridNonLinearSolver.h:52
Eigen::HybridNonLinearSolver::solveOneStep
HybridNonLinearSolverSpace::Status solveOneStep(FVectorType &x)
Definition: HybridNonLinearSolver.h:186
max
#define max(a, b)
Definition: datatypes.h:20
Eigen::numext::sqrt
EIGEN_DEVICE_FUNC EIGEN_ALWAYS_INLINE float sqrt(const float &x)
Definition: Eigen/src/Core/arch/SSE/MathFunctions.h:177
Eigen::HybridNonLinearSolver::Parameters::epsfcn
Scalar epsfcn
Definition: HybridNonLinearSolver.h:64
Eigen::NumTraits
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
Definition: NumTraits.h:232
Eigen::HybridNonLinearSolver::fjac
JacobianType fjac
Definition: HybridNonLinearSolver.h:92
ceres::sqrt
Jet< T, N > sqrt(const Jet< T, N > &f)
Definition: jet.h:418
R
Rot2 R(Rot2::fromAngle(0.1))
Eigen::HybridNonLinearSolverSpace::RelativeErrorTooSmall
@ RelativeErrorTooSmall
Definition: HybridNonLinearSolver.h:22
Scalar
SCALAR Scalar
Definition: bench_gemm.cpp:46
Eigen::HouseholderQR
Householder QR decomposition of a matrix.
Definition: ForwardDeclarations.h:273
Eigen::HybridNonLinearSolver::fnorm1
Scalar fnorm1
Definition: HybridNonLinearSolver.h:109
Eigen::HybridNonLinearSolver::Parameters::xtol
Scalar xtol
Definition: HybridNonLinearSolver.h:61
Eigen::HybridNonLinearSolver::wa4
FVectorType wa4
Definition: HybridNonLinearSolver.h:113
Eigen::HybridNonLinearSolverSpace::NotMakingProgressJacobian
@ NotMakingProgressJacobian
Definition: HybridNonLinearSolver.h:25


gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:02:23