Updating nonlinear params to allow selection of orderings
parent
103ec596d7
commit
8cd17f6a30
|
@ -12,6 +12,7 @@
|
||||||
/**
|
/**
|
||||||
* @file Ordering.cpp
|
* @file Ordering.cpp
|
||||||
* @author Richard Roberts
|
* @author Richard Roberts
|
||||||
|
* @author Andrew Melim
|
||||||
* @date Sep 2, 2010
|
* @date Sep 2, 2010
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
/**
|
/**
|
||||||
* @file Ordering.h
|
* @file Ordering.h
|
||||||
* @author Richard Roberts
|
* @author Richard Roberts
|
||||||
|
* @author Andrew Melim
|
||||||
* @date Sep 2, 2010
|
* @date Sep 2, 2010
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
/**
|
/**
|
||||||
* @file testOrdering
|
* @file testOrdering
|
||||||
* @author Alex Cunningham
|
* @author Alex Cunningham
|
||||||
|
* @author Andrew Melim
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <gtsam/inference/Symbol.h>
|
#include <gtsam/inference/Symbol.h>
|
||||||
|
|
|
@ -107,10 +107,17 @@ void NonlinearOptimizerParams::print(const std::string& str) const {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ordering)
|
switch (orderingType){
|
||||||
std::cout << " ordering: custom\n";
|
case COLAMD:
|
||||||
else
|
std::cout << " ordering: COLAMD\n";
|
||||||
std::cout << " ordering: COLAMD\n";
|
break;
|
||||||
|
case METIS:
|
||||||
|
std::cout << " ordering: METIS\n";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
std::cout << " ordering: custom\n";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
std::cout.flush();
|
std::cout.flush();
|
||||||
}
|
}
|
||||||
|
@ -155,6 +162,34 @@ NonlinearOptimizerParams::LinearSolverType NonlinearOptimizerParams::linearSolve
|
||||||
throw std::invalid_argument(
|
throw std::invalid_argument(
|
||||||
"Unknown linear solver type in SuccessiveLinearizationOptimizer");
|
"Unknown linear solver type in SuccessiveLinearizationOptimizer");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ************************************************************************* */
|
/* ************************************************************************* */
|
||||||
|
std::string NonlinearOptimizerParams::orderingTypeTranslator(NonlinearOptimizerParams::OrderingType type) const
|
||||||
|
{
|
||||||
|
switch (type) {
|
||||||
|
case METIS:
|
||||||
|
return "METIS";
|
||||||
|
case COLAMD:
|
||||||
|
return "COLAMD";
|
||||||
|
default:
|
||||||
|
if (ordering)
|
||||||
|
return "CUSTOM";
|
||||||
|
else
|
||||||
|
throw std::invalid_argument(
|
||||||
|
"Invalid ordering type: You must provide an ordering for a custom ordering type. See setOrdering");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ************************************************************************* */
|
||||||
|
NonlinearOptimizerParams::OrderingType NonlinearOptimizerParams::orderingTypeTranslator(const std::string& type) const
|
||||||
|
{
|
||||||
|
if (type == "METIS")
|
||||||
|
return METIS;
|
||||||
|
if (type == "COLAMD")
|
||||||
|
return COLAMD;
|
||||||
|
throw std::invalid_argument(
|
||||||
|
"Invalid ordering type: You must provide an ordering for a custom ordering type. See setOrdering");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
|
@ -37,15 +37,21 @@ public:
|
||||||
SILENT, TERMINATION, ERROR, VALUES, DELTA, LINEAR
|
SILENT, TERMINATION, ERROR, VALUES, DELTA, LINEAR
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/** See NonlinearOptimizer::orderingType */
|
||||||
|
enum OrderingType {
|
||||||
|
COLAMD, METIS, CUSTOM
|
||||||
|
};
|
||||||
|
|
||||||
int maxIterations; ///< The maximum iterations to stop iterating (default 100)
|
int maxIterations; ///< The maximum iterations to stop iterating (default 100)
|
||||||
double relativeErrorTol; ///< The maximum relative error decrease to stop iterating (default 1e-5)
|
double relativeErrorTol; ///< The maximum relative error decrease to stop iterating (default 1e-5)
|
||||||
double absoluteErrorTol; ///< The maximum absolute error decrease to stop iterating (default 1e-5)
|
double absoluteErrorTol; ///< The maximum absolute error decrease to stop iterating (default 1e-5)
|
||||||
double errorTol; ///< The maximum total error to stop iterating (default 0.0)
|
double errorTol; ///< The maximum total error to stop iterating (default 0.0)
|
||||||
Verbosity verbosity; ///< The printing verbosity during optimization (default SILENT)
|
Verbosity verbosity; ///< The printing verbosity during optimization (default SILENT)
|
||||||
|
OrderingType orderingType; ///< The method of ordering use during variable elimination (default COLAMD)
|
||||||
|
|
||||||
NonlinearOptimizerParams() :
|
NonlinearOptimizerParams() :
|
||||||
maxIterations(100), relativeErrorTol(1e-5), absoluteErrorTol(1e-5), errorTol(
|
maxIterations(100), relativeErrorTol(1e-5), absoluteErrorTol(1e-5), errorTol(
|
||||||
0.0), verbosity(SILENT), linearSolverType(MULTIFRONTAL_CHOLESKY) {
|
0.0), verbosity(SILENT), linearSolverType(MULTIFRONTAL_CHOLESKY), orderingType(COLAMD) {
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual ~NonlinearOptimizerParams() {
|
virtual ~NonlinearOptimizerParams() {
|
||||||
|
@ -152,12 +158,27 @@ public:
|
||||||
|
|
||||||
void setOrdering(const Ordering& ordering) {
|
void setOrdering(const Ordering& ordering) {
|
||||||
this->ordering = ordering;
|
this->ordering = ordering;
|
||||||
|
this->orderingType = CUSTOM;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string getOrderingType() const {
|
||||||
|
return orderingTypeTranslator(orderingType);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Note that if you want to use a custom ordering, you must set the ordering directly, this will switch to custom type
|
||||||
|
void setOrderingType(const std::string& ordering){
|
||||||
|
orderingType = orderingTypeTranslator(ordering);
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string linearSolverTranslator(LinearSolverType linearSolverType) const;
|
std::string linearSolverTranslator(LinearSolverType linearSolverType) const;
|
||||||
LinearSolverType linearSolverTranslator(
|
|
||||||
const std::string& linearSolverType) const;
|
LinearSolverType linearSolverTranslator(const std::string& linearSolverType) const;
|
||||||
|
|
||||||
|
std::string orderingTypeTranslator(OrderingType type) const;
|
||||||
|
|
||||||
|
OrderingType orderingTypeTranslator(const std::string& type) const;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
// For backward compatibility:
|
// For backward compatibility:
|
||||||
|
|
Loading…
Reference in New Issue