ultimatepp/uppsrc/plugin/Eigen/Eigen.cpp
koldo e77e856af2 Eigen: Solved CLANG warnings in Linux
git-svn-id: svn://ultimatepp.org/upp/trunk@14588 f0d560ea-af0d-0410-9eb7-867de7ffcac7
2020-06-13 13:17:35 +00:00

33 lines
No EOL
1.2 KiB
C++

#include <Core/Core.h>
#include "Eigen.h"
namespace Upp {
using namespace Eigen;
bool NonLinearOptimization(VectorXd &y, Eigen::Index 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 SolveNonLinearEquations(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;
}
}