hpp-constraints 6.1.0
Definition of basic geometric constraints for motion planning
by-substitution.hh
Go to the documentation of this file.
1// Copyright (c) 2017, 2018 CNRS
2// Authors: Joseph Mirabel (joseph.mirabel@laas.fr)
3//
4
5// Redistribution and use in source and binary forms, with or without
6// modification, are permitted provided that the following conditions are
7// met:
8//
9// 1. Redistributions of source code must retain the above copyright
10// notice, this list of conditions and the following disclaimer.
11//
12// 2. Redistributions in binary form must reproduce the above copyright
13// notice, this list of conditions and the following disclaimer in the
14// documentation and/or other materials provided with the distribution.
15//
16// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20// HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
27// DAMAGE.
28
29#ifndef HPP_CONSTRAINTS_SOLVER_BY_SUBSTITUTION_HH
30#define HPP_CONSTRAINTS_SOLVER_BY_SUBSTITUTION_HH
31
37#include <vector>
38
39namespace hpp {
40namespace constraints {
41namespace solver {
44
74 public:
77
78 virtual ~BySubstitution() {}
79
85 bool add(const ImplicitPtr_t& numericalConstraint,
86 const std::size_t& priority = 0);
87
97
100 return constraints_;
101 }
102
105
108 return explicit_;
109 }
110
113 return explicitConstraintSet().notOutDers().nbIndices();
114 }
115
118
119 template <typename LineSearchType>
120 Status solve(vectorOut_t arg, LineSearchType ls = LineSearchType()) const {
121 return solve<LineSearchType>(arg, false, ls);
122 }
123
124 template <typename LineSearchType>
125 Status solve(vectorOut_t arg, bool optimize,
126 LineSearchType ls = LineSearchType()) const {
127 // TODO when there are only locked joint explicit constraints,
128 // there is no need for this intricated loop.
129 // if (explicit_.isConstant()) {
130 // explicit_.solve(arg);
131 // iterative_.solve(arg, ls);
132 // } else {
133 return impl_solve(arg, optimize, ls);
134 // }
135 }
136
147 vectorOut_t result) const;
148
160 ConfigurationOut_t result);
161
162 inline Status solve(vectorOut_t arg) const {
163 return solve(arg, DefaultLineSearch());
164 }
165
168
171
175 ConfigurationIn_t config);
176
179 bool rightHandSide(const ImplicitPtr_t& constraint, vectorIn_t rhs);
180
183 bool getRightHandSide(const ImplicitPtr_t& constraint, vectorOut_t rhs) const;
184
187
193
196
198
205 return dimension() + explicit_.outDers().nbIndices();
206 }
207
211 bool isSatisfied(vectorIn_t arg) const {
213 explicit_.isSatisfied(arg);
214 }
215
220 bool isSatisfied(vectorIn_t arg, value_type errorThreshold) const {
221 return solver::HierarchicalIterative::isSatisfied(arg, errorThreshold) &&
222 explicit_.isSatisfied(arg, errorThreshold);
223 }
229 bool isSatisfied(vectorIn_t arg, vectorOut_t error) const {
230 assert(error.size() == dimension() + explicit_.errorSize());
231 bool iterative = solver::HierarchicalIterative::isSatisfied(arg);
232 residualError(error.head(dimension()));
233 bool _explicit =
234 explicit_.isSatisfied(arg, error.tail(explicit_.errorSize()));
235 return iterative && _explicit;
236 }
237
247 bool isConstraintSatisfied(const ImplicitPtr_t& constraint, vectorIn_t arg,
248 vectorOut_t error, bool& constraintFound) const;
249
250 template <typename LineSearchType>
251 bool oneStep(vectorOut_t arg, LineSearchType& lineSearch) const {
252 computeValue<true>(arg);
253 updateJacobian(arg);
254 computeDescentDirection();
255 lineSearch(*this, arg, dq_);
256 explicit_.solve(arg);
258 }
259
262 void updateJacobian(vectorIn_t arg) const;
263
265 void errorThreshold(const value_type& threshold) {
267 explicit_.errorThreshold(threshold);
268 }
272 }
273
278
279 virtual std::ostream& print(std::ostream& os) const;
280
281 bool integrate(vectorIn_t from, vectorIn_t velocity,
282 vectorOut_t result) const {
283 bool res = solver::HierarchicalIterative::integrate(from, velocity, result);
284 explicit_.solve(result);
285 return res;
286 }
287
288 protected:
289 void computeActiveRowsOfJ(std::size_t iStack);
290
291 private:
293
294 template <typename LineSearchType>
295 Status impl_solve(vectorOut_t arg, bool optimize, LineSearchType ls) const;
296
297 ExplicitConstraintSet explicit_;
298 mutable matrix_t Je_, JeExpanded_;
299
300 BySubstitution() {}
302}; // class BySubstitution
304
305} // namespace solver
306} // namespace constraints
307} // namespace hpp
308
309#endif // HPP_CONSTRAINTS_SOLVER_BY_SUBSTITUTION_HH
Definition: explicit-constraint-set.hh:99
Definition: by-substitution.hh:73
void computeActiveRowsOfJ(std::size_t iStack)
BySubstitution(const LiegroupSpacePtr_t &configSpace)
virtual ~BySubstitution()
Definition: by-substitution.hh:78
void explicitConstraintSetHasChanged()
Should be called whenever explicit solver is modified.
Status solve(vectorOut_t arg, bool optimize, LineSearchType ls=LineSearchType()) const
Definition: by-substitution.hh:125
Status solve(vectorOut_t arg) const
Definition: by-substitution.hh:162
bool oneStep(vectorOut_t arg, LineSearchType &lineSearch) const
Definition: by-substitution.hh:251
Status solve(vectorOut_t arg, LineSearchType ls=LineSearchType()) const
Definition: by-substitution.hh:120
value_type errorThreshold() const
Get error threshold.
Definition: by-substitution.hh:270
bool isSatisfied(vectorIn_t arg, vectorOut_t error) const
Definition: by-substitution.hh:229
size_type errorSize() const
Definition: by-substitution.hh:204
bool getRightHandSide(const ImplicitPtr_t &constraint, vectorOut_t rhs) const
virtual std::ostream & print(std::ostream &os) const
void projectVectorOnKernel(ConfigurationIn_t from, vectorIn_t velocity, vectorOut_t result) const
bool rightHandSideFromConfig(const ImplicitPtr_t &constraint, ConfigurationIn_t config)
const NumericalConstraints_t & numericalConstraints() const
Get the numerical constraints implicit and explicit.
Definition: by-substitution.hh:99
ExplicitConstraintSet & explicitConstraintSet()
Get explicit constraint set.
Definition: by-substitution.hh:104
bool isSatisfied(vectorIn_t arg, value_type errorThreshold) const
Definition: by-substitution.hh:220
const ExplicitConstraintSet & explicitConstraintSet() const
Set explicit constraint set.
Definition: by-substitution.hh:107
size_type numberFreeVariables() const
Return the number of free variables.
Definition: by-substitution.hh:112
bool add(const ImplicitPtr_t &numericalConstraint, const std::size_t &priority=0)
virtual void projectOnKernel(ConfigurationIn_t from, ConfigurationIn_t to, ConfigurationOut_t result)
bool integrate(vectorIn_t from, vectorIn_t velocity, vectorOut_t result) const
Definition: by-substitution.hh:281
vector_t rightHandSideFromConfig(ConfigurationIn_t config)
bool isConstraintSatisfied(const ImplicitPtr_t &constraint, vectorIn_t arg, vectorOut_t error, bool &constraintFound) const
bool rightHandSide(const ImplicitPtr_t &constraint, vectorIn_t rhs)
BySubstitution(const BySubstitution &other)
void updateJacobian(vectorIn_t arg) const
BySubstitution extract(interval_t interval)
bool isSatisfied(vectorIn_t arg) const
Definition: by-substitution.hh:211
void errorThreshold(const value_type &threshold)
Set error threshold.
Definition: by-substitution.hh:265
Definition: hierarchical-iterative.hh:240
virtual bool integrate(vectorIn_t from, vectorIn_t velocity, vectorOut_t result) const
Status
Definition: hierarchical-iterative.hh:245
bool isSatisfied(vectorIn_t arg) const
Definition: hierarchical-iterative.hh:338
value_type errorThreshold() const
Get error threshold.
Definition: hierarchical-iterative.hh:413
#define HPP_CONSTRAINTS_DLLAPI
Definition: config.hh:88
assert(d.lhs()._blocks()==d.rhs()._blocks())
pinocchio::LiegroupSpacePtr_t LiegroupSpacePtr_t
Definition: fwd.hh:69
shared_ptr< Implicit > ImplicitPtr_t
Definition: fwd.hh:174
std::pair< value_type, value_type > interval_t
Definition: fwd.hh:84
pinocchio::size_type size_type
Definition: fwd.hh:47
pinocchio::value_type value_type
Definition: fwd.hh:48
pinocchio::vectorIn_t vectorIn_t
Definition: fwd.hh:60
pinocchio::ConfigurationIn_t ConfigurationIn_t
Definition: fwd.hh:107
pinocchio::matrix_t matrix_t
Definition: fwd.hh:56
std::vector< segment_t > segments_t
Definition: fwd.hh:85
pinocchio::vectorOut_t vectorOut_t
Definition: fwd.hh:61
std::vector< constraints::ImplicitPtr_t > NumericalConstraints_t
Definition: fwd.hh:176
pinocchio::vector_t vector_t
Definition: fwd.hh:59
pinocchio::ConfigurationOut_t ConfigurationOut_t
Definition: fwd.hh:108
constexpr int error
#define HPP_SERIALIZABLE_SPLIT()
Definition: hierarchical-iterative.hh:70