Go to the documentation of this file.
25 #ifndef SRC_OPTIMIZATION_INCLUDE_CORBO_OPTIMIZATION_SIMPLE_OPTIMIZATION_PROBLEM_H_
26 #define SRC_OPTIMIZATION_INCLUDE_CORBO_OPTIMIZATION_SIMPLE_OPTIMIZATION_PROBLEM_H_
51 class SimpleOptimizationProblem :
public OptimizationProblemInterface
108 Eigen::VectorXd&
getXRef() {
return _x; }
109 const Eigen::VectorXd&
getX()
const {
return _x; }
322 #endif // SRC_OPTIMIZATION_INCLUDE_CORBO_OPTIMIZATION_SIMPLE_OPTIMIZATION_PROBLEM_H_
Simple optimization problem formulation (callback based configuration)
int getInequalityDimension() override=0
Total dimension of general inequality constraints.
int getEqualityDimension() override=0
Total dimension of equality constraints.
const Eigen::VectorXd & getLowerBounds() const
int getEqualityDimension() override
Total dimension of equality constraints.
bool isLeastSquaresProblem() const override=0
Check if the underlying problem is defined in the least squares form.
void setLowerBound(int idx, double lb) override
Set specific lower bound of a parameter.
bool _warn_if_not_specialized
void setObjectiveFunction(std::function< void(const Eigen::VectorXd &, Eigen::Ref< Eigen::VectorXd >)> obj_fun, int obj_dim, bool lsq_form=false)
Set objective function callback.
Simple optimization problem formulation.
void getBounds(Eigen::Ref< Eigen::VectorXd > lb, Eigen::Ref< Eigen::VectorXd > ub) override
Get lower and upper bound vector.
const Eigen::VectorXd & getUpperBounds() const
std::function< void(const Eigen::VectorXd &, Eigen::Ref< Eigen::VectorXd >)> _eq_fun
double computeValueNonLsqObjective() override=0
bool isLeastSquaresProblem() const override
Check if the underlying problem is defined in the least squares form.
int getNonLsqObjectiveDimension() override
Total dimension of objective function terms.
int getObjectiveDimension() override=0
Get dimension of the objective (should be zero or one, includes Lsq objectives if present)
void computeValuesLsqObjective(Eigen::Ref< Eigen::VectorXd > values) override
Compute the objective function values f(x) for the current parameter set.
void restoreBackupParameters(bool keep_backup) override
Discard last backup (or all)
void setUpperBounds(const Eigen::Ref< const Eigen::VectorXd > &ub)
Eigen::VectorXd & getXRef()
int getObjectiveDimension() override
Get dimension of the objective (should be zero or one, includes Lsq objectives if present)
int getInequalityDimension() override
Total dimension of general inequality constraints.
void setUpperBound(int idx, double ub) override
Set specific upper bound of a parameter.
double getLowerBound(int idx) override
Return specific lower bound value of a parameter.
int getParameterDimension() override
Effictive dimension of the optimization parameter set (changeable, non-fixed part)
void setLowerBounds(const Eigen::Ref< const Eigen::VectorXd > &lb)
const Eigen::VectorXd & getX() const
Eigen::VectorXd & getUpperBoundsRef()
double computeValueNonLsqObjective() override
int getLsqObjectiveDimension() override=0
Total dimension of least-squares objective function terms.
void setParameterValue(int idx, double x) override
Set specific value of the parameter vector.
void computeValuesEquality(Eigen::Ref< Eigen::VectorXd > values) override=0
Compute the equality constraint values ceq(x) for the current parameter set.
std::vector< Eigen::VectorXd > _x_backup
void setX(const Eigen::Ref< const Eigen::VectorXd > &x)
void getParameterVector(Eigen::Ref< Eigen::VectorXd > x) override
Same as getX() but less efficient (overrides interface method, but here x must not be pre-allocated)
void setParameterVector(const Eigen::Ref< const Eigen::VectorXd > &x) override
Same as setX() (overrides interface method)
void computeValuesLsqObjective(Eigen::Ref< Eigen::VectorXd > values) override=0
Compute the objective function values f(x) for the current parameter set.
int getLsqObjectiveDimension() override
Total dimension of least-squares objective function terms.
double getUpperBound(int idx) override
Return specific upper bound of a parameter.
Eigen::VectorXd & getLowerBoundsRef()
void setBounds(const Eigen::Ref< const Eigen::VectorXd > &lb, const Eigen::Ref< const Eigen::VectorXd > &ub) override
Set lower and upper bound vector.
int getNonLsqObjectiveDimension() override=0
Total dimension of objective function terms.
SimpleOptimizationProblemWithCallbacks()
Default constructor (do not forget to initialize the parameter vector dimension manually)
A matrix or vector expression mapping an existing expression.
std::function< void(const Eigen::VectorXd &, Eigen::Ref< Eigen::VectorXd >)> _obj_fun
void applyIncrement(const Eigen::Ref< const Eigen::VectorXd > &increment) override
Apply increment to the current parameter set.
void discardBackupParameters(bool all=false) override
void computeValuesEquality(Eigen::Ref< Eigen::VectorXd > values) override
Compute the equality constraint values ceq(x) for the current parameter set.
void resizeParameterVector(int parameter_dim)
Resize the dimension of the parameter vector.
void setEqualityConstraint(std::function< void(const Eigen::VectorXd &, Eigen::Ref< Eigen::VectorXd >)> eq_fun, int eq_dim)
Set equality constraint callback.
void backupParameters() override
Restore parameter set from the last backup and keep backup if desired.
void computeValuesInequality(Eigen::Ref< Eigen::VectorXd > values) override
Compute the inequality constraint values c(x) for the current parameter set.
SimpleOptimizationProblem()
void computeValuesInequality(Eigen::Ref< Eigen::VectorXd > values) override=0
Compute the inequality constraint values c(x) for the current parameter set.
double getParameterValue(int idx) override
Return specific value of the parameter vector.
void setInequalityConstraint(std::function< void(const Eigen::VectorXd &, Eigen::Ref< Eigen::VectorXd >)> ineq_fun, int ineq_dim)
Set inequality constraint callback.
std::function< void(const Eigen::VectorXd &, Eigen::Ref< Eigen::VectorXd >)> _ineq_fun
control_box_rst
Author(s): Christoph Rösmann
autogenerated on Wed Mar 2 2022 00:06:12