reorganized verbosity and included the new lambda policy from CERES
parent
06c5186fa2
commit
98e32a1e6d
|
@ -82,12 +82,28 @@ GaussianFactorGraph::shared_ptr LevenbergMarquardtOptimizer::linearize() const {
|
||||||
|
|
||||||
/* ************************************************************************* */
|
/* ************************************************************************* */
|
||||||
void LevenbergMarquardtOptimizer::increaseLambda(double stepQuality){
|
void LevenbergMarquardtOptimizer::increaseLambda(double stepQuality){
|
||||||
state_.lambda *= params_.lambdaFactor;
|
if(params_.useFixedLambdaFactor_){
|
||||||
|
state_.lambda *= params_.lambdaFactor;
|
||||||
|
}else{
|
||||||
|
state_.lambda *= params_.lambdaFactor;
|
||||||
|
params_.lambdaFactor *= 2.0;
|
||||||
|
// reuse_diagonal_ = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ************************************************************************* */
|
/* ************************************************************************* */
|
||||||
void LevenbergMarquardtOptimizer::decreaseLambda(double stepQuality){
|
void LevenbergMarquardtOptimizer::decreaseLambda(double stepQuality){
|
||||||
state_.lambda /= params_.lambdaFactor;
|
|
||||||
|
if(params_.useFixedLambdaFactor_){
|
||||||
|
state_.lambda /= params_.lambdaFactor;
|
||||||
|
}else{
|
||||||
|
// CHECK_GT(step_quality, 0.0);
|
||||||
|
state_.lambda *= std::max(1.0 / 3.0, 1.0 - pow(2.0 * stepQuality - 1.0, 3));
|
||||||
|
state_.lambda = std::max(params_.lambdaLowerBound, state_.lambda);
|
||||||
|
params_.lambdaFactor = 2.0;
|
||||||
|
// reuse_diagonal_ = false;
|
||||||
|
}
|
||||||
|
std::cout << " state_.lambda " << state_.lambda << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ************************************************************************* */
|
/* ************************************************************************* */
|
||||||
|
@ -143,8 +159,7 @@ void LevenbergMarquardtOptimizer::iterate() {
|
||||||
const LevenbergMarquardtParams::VerbosityLM lmVerbosity = params_.verbosityLM;
|
const LevenbergMarquardtParams::VerbosityLM lmVerbosity = params_.verbosityLM;
|
||||||
|
|
||||||
// Linearize graph
|
// Linearize graph
|
||||||
if(lmVerbosity >= LevenbergMarquardtParams::DAMPED)
|
if(lmVerbosity >= LevenbergMarquardtParams::DAMPED) cout << "linearizing = " << endl;
|
||||||
cout << "linearizing = " << endl;
|
|
||||||
GaussianFactorGraph::shared_ptr linear = linearize();
|
GaussianFactorGraph::shared_ptr linear = linearize();
|
||||||
|
|
||||||
double modelFidelity = 0.0;
|
double modelFidelity = 0.0;
|
||||||
|
@ -153,8 +168,7 @@ void LevenbergMarquardtOptimizer::iterate() {
|
||||||
while (true) {
|
while (true) {
|
||||||
++state_.totalNumberInnerIterations;
|
++state_.totalNumberInnerIterations;
|
||||||
|
|
||||||
if (lmVerbosity >= LevenbergMarquardtParams::TRYLAMBDA)
|
if (lmVerbosity >= LevenbergMarquardtParams::TRYLAMBDA) cout << "trying lambda = " << state_.lambda << endl;
|
||||||
cout << "trying lambda = " << state_.lambda << endl;
|
|
||||||
|
|
||||||
// Build damped system for this lambda (adds prior factors that make it like gradient descent)
|
// Build damped system for this lambda (adds prior factors that make it like gradient descent)
|
||||||
GaussianFactorGraph dampedSystem = buildDampedSystem(*linear);
|
GaussianFactorGraph dampedSystem = buildDampedSystem(*linear);
|
||||||
|
@ -184,27 +198,28 @@ void LevenbergMarquardtOptimizer::iterate() {
|
||||||
|
|
||||||
// create new optimization state with more adventurous lambda
|
// create new optimization state with more adventurous lambda
|
||||||
gttic (compute_error);
|
gttic (compute_error);
|
||||||
|
|
||||||
if(lmVerbosity >= LevenbergMarquardtParams::TRYLAMBDA) cout << "calculating error" << endl;
|
if(lmVerbosity >= LevenbergMarquardtParams::TRYLAMBDA) cout << "calculating error" << endl;
|
||||||
double error = graph_.error(newValues);
|
double error = graph_.error(newValues);
|
||||||
gttoc(compute_error);
|
gttoc(compute_error);
|
||||||
|
|
||||||
if (lmVerbosity >= LevenbergMarquardtParams::TRYLAMBDA) cout << "next error = " << error << endl;
|
|
||||||
|
|
||||||
// cost change in the original, possibly nonlinear system (old - new)
|
// cost change in the original, possibly nonlinear system (old - new)
|
||||||
double costChange = state_.error - error;
|
double costChange = state_.error - error;
|
||||||
|
|
||||||
// cost change in the linearized system (old - new)
|
// cost change in the linearized system (old - new)
|
||||||
double linearizedCostChange = state_.error - linear->error(delta);
|
double newlinearizedError = linear->error(delta);
|
||||||
|
double linearizedCostChange = state_.error - newlinearizedError;
|
||||||
|
|
||||||
// checking similarity between change in original and linearized cost
|
// checking similarity between change in original and linearized cost
|
||||||
modelFidelity = costChange / linearizedCostChange;
|
modelFidelity = costChange / linearizedCostChange;
|
||||||
|
|
||||||
// cout << "current error " << state_.error << endl;
|
if (lmVerbosity >= LevenbergMarquardtParams::TRYLAMBDA){
|
||||||
// cout << "new error " << error << endl;
|
cout << "current error " << state_.error << endl;
|
||||||
// cout << "costChange " << costChange << endl;
|
cout << "new error " << error << endl;
|
||||||
// cout << "linearizedCostChange " << linearizedCostChange << endl;
|
cout << "costChange " << costChange << endl;
|
||||||
// cout << "modelFidelity " << modelFidelity << endl;
|
cout << "new error in linearized model " << newlinearizedError << endl;
|
||||||
|
cout << "linearizedCostChange " << linearizedCostChange << endl;
|
||||||
|
cout << "modelFidelity " << modelFidelity << endl;
|
||||||
|
}
|
||||||
|
|
||||||
if (error < state_.error) {
|
if (error < state_.error) {
|
||||||
state_.values.swap(newValues);
|
state_.values.swap(newValues);
|
||||||
|
@ -230,8 +245,8 @@ void LevenbergMarquardtOptimizer::iterate() {
|
||||||
|
|
||||||
increaseLambda(modelFidelity);
|
increaseLambda(modelFidelity);
|
||||||
}
|
}
|
||||||
// bool converged = checkConvergence(_params().relativeErrorTol, _params().absoluteErrorTol, _params().errorTol, state_.error, error);
|
// bool converged = checkConvergence(_params().relativeErrorTol, _params().absoluteErrorTol, _params().errorTol, state_.error, error);
|
||||||
// cout << " Inner iteration - converged " << converged << endl;
|
// cout << " Inner iteration - converged " << converged << endl;
|
||||||
}
|
}
|
||||||
} catch (IndeterminantLinearSystemException& e) {
|
} catch (IndeterminantLinearSystemException& e) {
|
||||||
(void) e; // Prevent unused variable warning
|
(void) e; // Prevent unused variable warning
|
||||||
|
@ -239,8 +254,7 @@ void LevenbergMarquardtOptimizer::iterate() {
|
||||||
cout << "Negative matrix, increasing lambda" << endl;
|
cout << "Negative matrix, increasing lambda" << endl;
|
||||||
|
|
||||||
// Either we're not cautious, or the same lambda was worse than the current error.
|
// Either we're not cautious, or the same lambda was worse than the current error.
|
||||||
// The more adventurous lambda was worse too, so make lambda more conservative
|
// The more adventurous lambda was worse too, so make lambda more conservative and keep the same values.
|
||||||
// and keep the same values.
|
|
||||||
if(state_.lambda >= params_.lambdaUpperBound) {
|
if(state_.lambda >= params_.lambdaUpperBound) {
|
||||||
if(nloVerbosity >= NonlinearOptimizerParams::TERMINATION)
|
if(nloVerbosity >= NonlinearOptimizerParams::TERMINATION)
|
||||||
cout << "Warning: Levenberg-Marquardt giving up because cannot decrease error with maximum lambda" << endl;
|
cout << "Warning: Levenberg-Marquardt giving up because cannot decrease error with maximum lambda" << endl;
|
||||||
|
|
|
@ -56,11 +56,12 @@ public:
|
||||||
std::string logFile; ///< an optional CSV log file, with [iteration, time, error, labda]
|
std::string logFile; ///< an optional CSV log file, with [iteration, time, error, labda]
|
||||||
bool diagonalDamping; ///< if true, use diagonal of Hessian
|
bool diagonalDamping; ///< if true, use diagonal of Hessian
|
||||||
bool reuse_diagonal_; //an additional option in Ceres for diagonalDamping (related to efficiency)
|
bool reuse_diagonal_; //an additional option in Ceres for diagonalDamping (related to efficiency)
|
||||||
|
bool useFixedLambdaFactor_; // if true applies constant increase (or decrease) to lambda according to lambdaFactor
|
||||||
|
|
||||||
LevenbergMarquardtParams() :
|
LevenbergMarquardtParams() :
|
||||||
lambdaInitial(1e-5), lambdaFactor(10.0), lambdaUpperBound(1e5), lambdaLowerBound(
|
lambdaInitial(1e-5), lambdaFactor(10.0), lambdaUpperBound(1e5), lambdaLowerBound(
|
||||||
0.0), verbosityLM(SILENT), disableInnerIterations(false), minModelFidelity(
|
0.0), verbosityLM(SILENT), disableInnerIterations(false), minModelFidelity(
|
||||||
1e-3), diagonalDamping(false), reuse_diagonal_(false) {
|
1e-3), diagonalDamping(false), reuse_diagonal_(false), useFixedLambdaFactor_(true) {
|
||||||
}
|
}
|
||||||
virtual ~LevenbergMarquardtParams() {
|
virtual ~LevenbergMarquardtParams() {
|
||||||
}
|
}
|
||||||
|
@ -110,6 +111,10 @@ public:
|
||||||
inline void setDiagonalDamping(bool flag) {
|
inline void setDiagonalDamping(bool flag) {
|
||||||
diagonalDamping = flag;
|
diagonalDamping = flag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline void setUseFixedLambdaFactor(bool flag) {
|
||||||
|
useFixedLambdaFactor_ = flag;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -196,10 +201,10 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
// Apply policy to increase lambda if the current update was successful (stepQuality not used in the naive policy)
|
// Apply policy to increase lambda if the current update was successful (stepQuality not used in the naive policy)
|
||||||
virtual void increaseLambda(double stepQuality);
|
void increaseLambda(double stepQuality);
|
||||||
|
|
||||||
// Apply policy to decrease lambda if the current update was NOT successful (stepQuality not used in the naive policy)
|
// Apply policy to decrease lambda if the current update was NOT successful (stepQuality not used in the naive policy)
|
||||||
virtual void decreaseLambda(double stepQuality);
|
void decreaseLambda(double stepQuality);
|
||||||
|
|
||||||
/// Access the current number of inner iterations
|
/// Access the current number of inner iterations
|
||||||
int getInnerIterations() const {
|
int getInnerIterations() const {
|
||||||
|
|
Loading…
Reference in New Issue