LPSolver.h
Go to the documentation of this file.
1 /* ----------------------------------------------------------------------------
2 
3  * GTSAM Copyright 2010, Georgia Tech Research Corporation,
4  * Atlanta, Georgia 30332-0415
5  * All Rights Reserved
6  * Authors: Frank Dellaert, et al. (see THANKS for the full author list)
7 
8  * See LICENSE for the license information
9 
10  * -------------------------------------------------------------------------- */
11 
20 #pragma once
21 
25 
26 #include <limits>
27 #include <algorithm>
28 
29 namespace gtsam {
30 
32 struct LPPolicy {
35  static constexpr double maxAlpha = std::numeric_limits<double>::infinity();
36 
50  const VectorValues& xk) {
52  for (LinearCost::const_iterator it = lp.cost.begin(); it != lp.cost.end();
53  ++it) {
54  size_t dim = lp.cost.getDim(it);
55  Vector b = xk.at(*it) - lp.cost.getA(it).transpose(); // b = xk-g
56  graph.emplace_shared<JacobianFactor>(*it, Matrix::Identity(dim, dim), b);
57  }
58 
59  KeySet allKeys = lp.inequalities.keys();
60  allKeys.merge(lp.equalities.keys());
61  allKeys.merge(KeySet(lp.cost.keys()));
62  // Add corresponding factors for all variables that are not explicitly in
63  // the cost function. Gradients of the cost function wrt to these variables
64  // are zero (g=0), so b=xk
65  if (lp.cost.keys().size() != allKeys.size()) {
66  KeySet difference;
67  std::set_difference(allKeys.begin(), allKeys.end(), lp.cost.begin(),
68  lp.cost.end(),
69  std::inserter(difference, difference.end()));
70  for (Key k : difference) {
71  size_t dim = lp.constrainedKeyDimMap().at(k);
72  graph.emplace_shared<JacobianFactor>(k, Matrix::Identity(dim, dim), xk.at(k));
73  }
74  }
75  return graph;
76  }
77 };
78 
80 
81 }
gtsam::LP
Definition: LP.h:51
gtsam::VectorValues::at
Vector & at(Key j)
Definition: VectorValues.h:144
gtsam::LP::constrainedKeyDimMap
const KeyDimMap & constrainedKeyDimMap() const
Definition: LP.h:80
gtsam::LP::equalities
EqualityFactorGraph equalities
Linear equality constraints: cE(x) = 0.
Definition: LP.h:55
gtsam::JacobianFactor
Definition: JacobianFactor.h:91
gtsam::FastSet::merge
void merge(const FastSet &other)
Definition: FastSet.h:125
gtsam::ActiveSetSolver
Definition: ActiveSetSolver.h:36
gtsam::FastSet< Key >
gtsam::Factor::begin
const_iterator begin() const
Definition: Factor.h:146
gtsam::Vector
Eigen::VectorXd Vector
Definition: Vector.h:39
gtsam::GaussianFactorGraph
Definition: GaussianFactorGraph.h:73
gtsam::LP::cost
LinearCost cost
Linear cost factor.
Definition: LP.h:54
gtsam::JacobianFactor::getDim
DenseIndex getDim(const_iterator variable) const override
Definition: JacobianFactor.h:279
gtsam::KeySet
FastSet< Key > KeySet
Definition: Key.h:96
gtsam::VectorValues
Definition: VectorValues.h:74
gtsam::LPPolicy::maxAlpha
static constexpr double maxAlpha
Definition: LPSolver.h:35
ActiveSetSolver.h
Active set method for solving LP, QP problems.
gtsam::FactorGraph::keys
KeySet keys() const
Definition: FactorGraph-inst.h:85
gtsam::LP::inequalities
InequalityFactorGraph inequalities
Linear inequality constraints: cI(x) <= 0.
Definition: LP.h:56
gtsam::Factor::end
const_iterator end() const
Definition: Factor.h:149
gtsam::b
const G & b
Definition: Group.h:79
gtsam::Factor::const_iterator
KeyVector::const_iterator const_iterator
Const iterator over keys.
Definition: Factor.h:83
gtsam
traits
Definition: SFMdata.h:40
gtsam::JacobianFactor::getA
constABlock getA(const_iterator variable) const
Definition: JacobianFactor.h:303
LPInitSolver.h
This finds a feasible solution for an LP problem.
gtsam::Factor::keys
const KeyVector & keys() const
Access the factor's involved variable keys.
Definition: Factor.h:143
LP.h
Struct used to hold a Linear Programming Problem.
gtsam::LPPolicy
Policy for ActivetSetSolver to solve Linear Programming.
Definition: LPSolver.h:32
graph
NonlinearFactorGraph graph
Definition: doc/Code/OdometryExample.cpp:2
gtsam::Key
std::uint64_t Key
Integer nonlinear key type.
Definition: types.h:97
gtsam::LPPolicy::buildCostFunction
static GaussianFactorGraph buildCostFunction(const LP &lp, const VectorValues &xk)
Definition: LPSolver.h:49


gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:02:40