LevenbergMarquardt time start ok
parent
e7ee411d39
commit
108df6e8cc
|
@ -175,11 +175,14 @@ void LevenbergMarquardtOptimizer::iterate() {
|
||||||
|
|
||||||
if (!params_.logFile.empty()) {
|
if (!params_.logFile.empty()) {
|
||||||
ofstream os(params_.logFile.c_str(), ios::app);
|
ofstream os(params_.logFile.c_str(), ios::app);
|
||||||
time_t rawtime;
|
|
||||||
time (&rawtime);
|
|
||||||
os << state_.iterations << "," << rawtime << "," << state_.error << "," << state_.lambda << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
timeval rawtime;
|
||||||
|
gettimeofday(&rawtime, NULL);
|
||||||
|
double currentTime = rawtime.tv_sec + rawtime.tv_usec / 1000000.0;
|
||||||
|
|
||||||
|
os << state_.iterations << "," << currentTime-state_.startTime << ","
|
||||||
|
<< state_.error << "," << state_.lambda << endl;
|
||||||
|
}
|
||||||
|
|
||||||
// Increment the iteration counter
|
// Increment the iteration counter
|
||||||
++state_.iterations;
|
++state_.iterations;
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <gtsam/nonlinear/NonlinearOptimizer.h>
|
#include <gtsam/nonlinear/NonlinearOptimizer.h>
|
||||||
|
#include <ctime>
|
||||||
|
|
||||||
namespace gtsam {
|
namespace gtsam {
|
||||||
|
|
||||||
|
@ -29,17 +30,12 @@ class LevenbergMarquardtOptimizer;
|
||||||
* common to all nonlinear optimization algorithms. This class also contains
|
* common to all nonlinear optimization algorithms. This class also contains
|
||||||
* all of those parameters.
|
* all of those parameters.
|
||||||
*/
|
*/
|
||||||
class GTSAM_EXPORT LevenbergMarquardtParams : public NonlinearOptimizerParams {
|
class GTSAM_EXPORT LevenbergMarquardtParams: public NonlinearOptimizerParams {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/** See LevenbergMarquardtParams::lmVerbosity */
|
/** See LevenbergMarquardtParams::lmVerbosity */
|
||||||
enum VerbosityLM {
|
enum VerbosityLM {
|
||||||
SILENT = 0,
|
SILENT = 0, LAMBDA, TRYLAMBDA, TRYCONFIG, TRYDELTA, DAMPED
|
||||||
LAMBDA,
|
|
||||||
TRYLAMBDA,
|
|
||||||
TRYCONFIG,
|
|
||||||
TRYDELTA,
|
|
||||||
DAMPED
|
|
||||||
};
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -54,40 +50,79 @@ public:
|
||||||
VerbosityLM verbosityLM; ///< The verbosity level for Levenberg-Marquardt (default: SILENT), see also NonlinearOptimizerParams::verbosity
|
VerbosityLM verbosityLM; ///< The verbosity level for Levenberg-Marquardt (default: SILENT), see also NonlinearOptimizerParams::verbosity
|
||||||
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]
|
||||||
|
|
||||||
LevenbergMarquardtParams() : lambdaInitial(1e-5), lambdaFactor(10.0), lambdaUpperBound(1e5), verbosityLM(SILENT) {}
|
LevenbergMarquardtParams() :
|
||||||
virtual ~LevenbergMarquardtParams() {}
|
lambdaInitial(1e-5), lambdaFactor(10.0), lambdaUpperBound(1e5), verbosityLM(
|
||||||
|
SILENT) {
|
||||||
|
}
|
||||||
|
virtual ~LevenbergMarquardtParams() {
|
||||||
|
}
|
||||||
|
|
||||||
virtual void print(const std::string& str = "") const;
|
virtual void print(const std::string& str = "") const;
|
||||||
|
|
||||||
inline double getlambdaInitial() const { return lambdaInitial; }
|
inline double getlambdaInitial() const {
|
||||||
inline double getlambdaFactor() const { return lambdaFactor; }
|
return lambdaInitial;
|
||||||
inline double getlambdaUpperBound() const { return lambdaUpperBound; }
|
}
|
||||||
inline std::string getVerbosityLM() const { return verbosityLMTranslator(verbosityLM); }
|
inline double getlambdaFactor() const {
|
||||||
inline std::string getLogFile() const { return logFile; }
|
return lambdaFactor;
|
||||||
|
}
|
||||||
|
inline double getlambdaUpperBound() const {
|
||||||
|
return lambdaUpperBound;
|
||||||
|
}
|
||||||
|
inline std::string getVerbosityLM() const {
|
||||||
|
return verbosityLMTranslator(verbosityLM);
|
||||||
|
}
|
||||||
|
inline std::string getLogFile() const {
|
||||||
|
return logFile;
|
||||||
|
}
|
||||||
|
|
||||||
inline void setlambdaInitial(double value) { lambdaInitial = value; }
|
inline void setlambdaInitial(double value) {
|
||||||
inline void setlambdaFactor(double value) { lambdaFactor = value; }
|
lambdaInitial = value;
|
||||||
inline void setlambdaUpperBound(double value) { lambdaUpperBound = value; }
|
}
|
||||||
inline void setVerbosityLM(const std::string &s) { verbosityLM = verbosityLMTranslator(s); }
|
inline void setlambdaFactor(double value) {
|
||||||
inline void setLogFile(const std::string &s) { logFile = s;}
|
lambdaFactor = value;
|
||||||
|
}
|
||||||
|
inline void setlambdaUpperBound(double value) {
|
||||||
|
lambdaUpperBound = value;
|
||||||
|
}
|
||||||
|
inline void setVerbosityLM(const std::string &s) {
|
||||||
|
verbosityLM = verbosityLMTranslator(s);
|
||||||
|
}
|
||||||
|
inline void setLogFile(const std::string &s) {
|
||||||
|
logFile = s;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* State for LevenbergMarquardtOptimizer
|
* State for LevenbergMarquardtOptimizer
|
||||||
*/
|
*/
|
||||||
class GTSAM_EXPORT LevenbergMarquardtState : public NonlinearOptimizerState {
|
class GTSAM_EXPORT LevenbergMarquardtState: public NonlinearOptimizerState {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
double lambda;
|
double lambda;
|
||||||
int totalNumberInnerIterations; // The total number of inner iterations in the optimization (for each iteration, LM may try multiple iterations with different lambdas)
|
int totalNumberInnerIterations; // The total number of inner iterations in the optimization (for each iteration, LM may try multiple iterations with different lambdas)
|
||||||
|
double startTime;
|
||||||
|
|
||||||
LevenbergMarquardtState() {}
|
LevenbergMarquardtState() {
|
||||||
|
initTime();
|
||||||
|
}
|
||||||
|
|
||||||
virtual ~LevenbergMarquardtState() {}
|
void initTime() {
|
||||||
|
timeval tod;
|
||||||
|
gettimeofday(&tod, NULL);
|
||||||
|
startTime = tod.tv_sec + tod.tv_usec / 1000000.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual ~LevenbergMarquardtState() {
|
||||||
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
LevenbergMarquardtState(const NonlinearFactorGraph& graph, const Values& initialValues, const LevenbergMarquardtParams& params, unsigned int iterations = 0) :
|
LevenbergMarquardtState(const NonlinearFactorGraph& graph,
|
||||||
NonlinearOptimizerState(graph, initialValues, iterations), lambda(params.lambdaInitial), totalNumberInnerIterations(0) {}
|
const Values& initialValues, const LevenbergMarquardtParams& params,
|
||||||
|
unsigned int iterations = 0) :
|
||||||
|
NonlinearOptimizerState(graph, initialValues, iterations), lambda(
|
||||||
|
params.lambdaInitial), totalNumberInnerIterations(0) {
|
||||||
|
initTime();
|
||||||
|
}
|
||||||
|
|
||||||
friend class LevenbergMarquardtOptimizer;
|
friend class LevenbergMarquardtOptimizer;
|
||||||
};
|
};
|
||||||
|
@ -95,12 +130,11 @@ protected:
|
||||||
/**
|
/**
|
||||||
* This class performs Levenberg-Marquardt nonlinear optimization
|
* This class performs Levenberg-Marquardt nonlinear optimization
|
||||||
*/
|
*/
|
||||||
class GTSAM_EXPORT LevenbergMarquardtOptimizer : public NonlinearOptimizer {
|
class GTSAM_EXPORT LevenbergMarquardtOptimizer: public NonlinearOptimizer {
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
LevenbergMarquardtParams params_; ///< LM parameters
|
LevenbergMarquardtParams params_; ///< LM parameters
|
||||||
LevenbergMarquardtState state_; ///< optimization state
|
LevenbergMarquardtState state_; ///< optimization state
|
||||||
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
typedef boost::shared_ptr<LevenbergMarquardtOptimizer> shared_ptr;
|
typedef boost::shared_ptr<LevenbergMarquardtOptimizer> shared_ptr;
|
||||||
|
@ -116,10 +150,12 @@ public:
|
||||||
* @param initialValues The initial variable assignments
|
* @param initialValues The initial variable assignments
|
||||||
* @param params The optimization parameters
|
* @param params The optimization parameters
|
||||||
*/
|
*/
|
||||||
LevenbergMarquardtOptimizer(const NonlinearFactorGraph& graph, const Values& initialValues,
|
LevenbergMarquardtOptimizer(const NonlinearFactorGraph& graph,
|
||||||
const LevenbergMarquardtParams& params = LevenbergMarquardtParams()) :
|
const Values& initialValues, const LevenbergMarquardtParams& params =
|
||||||
NonlinearOptimizer(graph), params_(ensureHasOrdering(params, graph)),
|
LevenbergMarquardtParams()) :
|
||||||
state_(graph, initialValues, params_) {}
|
NonlinearOptimizer(graph), params_(ensureHasOrdering(params, graph)), state_(
|
||||||
|
graph, initialValues, params_) {
|
||||||
|
}
|
||||||
|
|
||||||
/** Standard constructor, requires a nonlinear factor graph, initial
|
/** Standard constructor, requires a nonlinear factor graph, initial
|
||||||
* variable assignments, and optimization parameters. For convenience this
|
* variable assignments, and optimization parameters. For convenience this
|
||||||
|
@ -128,16 +164,22 @@ public:
|
||||||
* @param graph The nonlinear factor graph to optimize
|
* @param graph The nonlinear factor graph to optimize
|
||||||
* @param initialValues The initial variable assignments
|
* @param initialValues The initial variable assignments
|
||||||
*/
|
*/
|
||||||
LevenbergMarquardtOptimizer(const NonlinearFactorGraph& graph, const Values& initialValues, const Ordering& ordering) :
|
LevenbergMarquardtOptimizer(const NonlinearFactorGraph& graph,
|
||||||
NonlinearOptimizer(graph) {
|
const Values& initialValues, const Ordering& ordering) :
|
||||||
|
NonlinearOptimizer(graph) {
|
||||||
params_.ordering = ordering;
|
params_.ordering = ordering;
|
||||||
state_ = LevenbergMarquardtState(graph, initialValues, params_); }
|
state_ = LevenbergMarquardtState(graph, initialValues, params_);
|
||||||
|
}
|
||||||
|
|
||||||
/// Access the current damping value
|
/// Access the current damping value
|
||||||
double lambda() const { return state_.lambda; }
|
double lambda() const {
|
||||||
|
return state_.lambda;
|
||||||
|
}
|
||||||
|
|
||||||
/// Access the current number of inner iterations
|
/// Access the current number of inner iterations
|
||||||
int getInnerIterations() const { return state_.totalNumberInnerIterations; }
|
int getInnerIterations() const {
|
||||||
|
return state_.totalNumberInnerIterations;
|
||||||
|
}
|
||||||
|
|
||||||
/// print
|
/// print
|
||||||
virtual void print(const std::string& str = "") const {
|
virtual void print(const std::string& str = "") const {
|
||||||
|
@ -151,7 +193,8 @@ public:
|
||||||
/// @{
|
/// @{
|
||||||
|
|
||||||
/** Virtual destructor */
|
/** Virtual destructor */
|
||||||
virtual ~LevenbergMarquardtOptimizer() {}
|
virtual ~LevenbergMarquardtOptimizer() {
|
||||||
|
}
|
||||||
|
|
||||||
/** Perform a single iteration, returning a new NonlinearOptimizer class
|
/** Perform a single iteration, returning a new NonlinearOptimizer class
|
||||||
* containing the updated variable assignments, which may be retrieved with
|
* containing the updated variable assignments, which may be retrieved with
|
||||||
|
@ -160,28 +203,41 @@ public:
|
||||||
virtual void iterate();
|
virtual void iterate();
|
||||||
|
|
||||||
/** Read-only access the parameters */
|
/** Read-only access the parameters */
|
||||||
const LevenbergMarquardtParams& params() const { return params_; }
|
const LevenbergMarquardtParams& params() const {
|
||||||
|
return params_;
|
||||||
|
}
|
||||||
|
|
||||||
/** Read/write access the parameters */
|
/** Read/write access the parameters */
|
||||||
LevenbergMarquardtParams& params() { return params_; }
|
LevenbergMarquardtParams& params() {
|
||||||
|
return params_;
|
||||||
|
}
|
||||||
|
|
||||||
/** Read-only access the last state */
|
/** Read-only access the last state */
|
||||||
const LevenbergMarquardtState& state() const { return state_; }
|
const LevenbergMarquardtState& state() const {
|
||||||
|
return state_;
|
||||||
|
}
|
||||||
|
|
||||||
/** Read/write access the last state. When modifying the state, the error, etc. must be consistent before calling iterate() */
|
/** Read/write access the last state. When modifying the state, the error, etc. must be consistent before calling iterate() */
|
||||||
LevenbergMarquardtState& state() { return state_; }
|
LevenbergMarquardtState& state() {
|
||||||
|
return state_;
|
||||||
|
}
|
||||||
|
|
||||||
/// @}
|
/// @}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
/** Access the parameters (base class version) */
|
/** Access the parameters (base class version) */
|
||||||
virtual const NonlinearOptimizerParams& _params() const { return params_; }
|
virtual const NonlinearOptimizerParams& _params() const {
|
||||||
|
return params_;
|
||||||
|
}
|
||||||
|
|
||||||
/** Access the state (base class version) */
|
/** Access the state (base class version) */
|
||||||
virtual const NonlinearOptimizerState& _state() const { return state_; }
|
virtual const NonlinearOptimizerState& _state() const {
|
||||||
|
return state_;
|
||||||
|
}
|
||||||
|
|
||||||
/** Internal function for computing a COLAMD ordering if no ordering is specified */
|
/** Internal function for computing a COLAMD ordering if no ordering is specified */
|
||||||
LevenbergMarquardtParams ensureHasOrdering(LevenbergMarquardtParams params, const NonlinearFactorGraph& graph) const;
|
LevenbergMarquardtParams ensureHasOrdering(LevenbergMarquardtParams params,
|
||||||
|
const NonlinearFactorGraph& graph) const;
|
||||||
|
|
||||||
/** linearize, can be overwritten */
|
/** linearize, can be overwritten */
|
||||||
virtual GaussianFactorGraph::shared_ptr linearize() const;
|
virtual GaussianFactorGraph::shared_ptr linearize() const;
|
||||||
|
|
Loading…
Reference in New Issue