ultimatepp/uppsrc/plugin/Eigen/Eigen.cpp
koldo 40833781c7 Eigen: Added simpler nonlinear functions
git-svn-id: svn://ultimatepp.org/upp/trunk@14465 f0d560ea-af0d-0410-9eb7-867de7ffcac7
2020-05-13 12:10:14 +00:00

34 lines
No EOL
1.2 KiB
C++

#include <Core/Core.h>
#include <Eigen.h>
namespace Upp {
using namespace Eigen;
bool NonLinearOptimization(VectorXd &y, int numData, Function <int(const VectorXd &b, VectorXd &residual)> Residual) {
Basic_functor functor(Residual);
functor.unknowns = y.size();
functor.datasetLen = numData;
Eigen::NumericalDiff<Basic_functor> numDiff(functor);
Eigen::LevenbergMarquardt<Eigen::NumericalDiff<Basic_functor> > lm(numDiff);
int ret = lm.minimize(y);
if (ret == Eigen::LevenbergMarquardtSpace::ImproperInputParameters ||
ret == Eigen::LevenbergMarquardtSpace::TooManyFunctionEvaluation)
return false;
return true;
}
bool NonLinearSolver(VectorXd &y, Function <int(const VectorXd &b, VectorXd &residual)> Residual) {
Basic_functor functor(Residual);
HybridNonLinearSolver<Basic_functor> solver(functor);
int ret = solver.solveNumericalDiff(y);
if (ret == HybridNonLinearSolverSpace::ImproperInputParameters ||
ret == HybridNonLinearSolverSpace::TooManyFunctionEvaluation ||
ret == HybridNonLinearSolverSpace::NotMakingProgressJacobian ||
ret == HybridNonLinearSolverSpace::NotMakingProgressIterations)
return false;
return true;
}
}