2014-12-09 19:13:57 +08:00
|
|
|
/* ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
* GTSAM Copyright 2010, Georgia Tech Research Corporation,
|
|
|
|
* Atlanta, Georgia 30332-0415
|
|
|
|
* All Rights Reserved
|
|
|
|
* Authors: Frank Dellaert, et al. (see THANKS for the full author list)
|
|
|
|
|
|
|
|
* See LICENSE for the license information
|
|
|
|
|
|
|
|
* -------------------------------------------------------------------------- */
|
|
|
|
|
2015-02-25 11:09:31 +08:00
|
|
|
/**
|
|
|
|
* @file: QP.h
|
2014-12-09 19:13:57 +08:00
|
|
|
* @brief: Factor graphs of a Quadratic Programming problem
|
|
|
|
* @date: Dec 8, 2014
|
2015-02-25 11:09:31 +08:00
|
|
|
* @author: Duy-Nguyen Ta
|
2014-12-09 19:13:57 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <gtsam/linear/GaussianFactorGraph.h>
|
|
|
|
#include <gtsam_unstable/linear/LinearEqualityFactorGraph.h>
|
|
|
|
#include <gtsam_unstable/linear/LinearInequalityFactorGraph.h>
|
|
|
|
|
|
|
|
namespace gtsam {
|
|
|
|
|
|
|
|
/**
|
2015-02-25 11:09:31 +08:00
|
|
|
* Struct contains factor graphs of a Quadratic Programming problem
|
2014-12-09 19:13:57 +08:00
|
|
|
*/
|
|
|
|
struct QP {
|
|
|
|
GaussianFactorGraph cost; //!< Quadratic cost factors
|
2015-02-25 11:09:31 +08:00
|
|
|
LinearEqualityFactorGraph equalities; //!< linear equality constraints: f(x) = 0
|
|
|
|
LinearInequalityFactorGraph inequalities; //!< linear inequality constraints: g(x) <= 0
|
2014-12-09 19:13:57 +08:00
|
|
|
|
|
|
|
/** default constructor */
|
|
|
|
QP() :
|
|
|
|
cost(), equalities(), inequalities() {
|
|
|
|
}
|
|
|
|
|
|
|
|
/** constructor */
|
|
|
|
QP(const GaussianFactorGraph& _cost,
|
|
|
|
const LinearEqualityFactorGraph& _linearEqualities,
|
|
|
|
const LinearInequalityFactorGraph& _linearInequalities) :
|
|
|
|
cost(_cost), equalities(_linearEqualities), inequalities(
|
|
|
|
_linearInequalities) {
|
|
|
|
}
|
|
|
|
|
|
|
|
/** print */
|
|
|
|
void print(const std::string& s = "") {
|
|
|
|
std::cout << s << std::endl;
|
|
|
|
cost.print("Quadratic cost factors: ");
|
|
|
|
equalities.print("Linear equality factors: ");
|
|
|
|
inequalities.print("Linear inequality factors: ");
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace gtsam
|
|
|
|
|