hpp-constraints 6.1.0
Definition of basic geometric constraints for motion planning
 
Loading...
Searching...
No Matches
differentiable-function.hh
Go to the documentation of this file.
1//
2// Copyright (c) 2014 CNRS
3// Authors: Florent Lamiraux
4//
5
6// Redistribution and use in source and binary forms, with or without
7// modification, are permitted provided that the following conditions are
8// met:
9//
10// 1. Redistributions of source code must retain the above copyright
11// notice, this list of conditions and the following disclaimer.
12//
13// 2. Redistributions in binary form must reproduce the above copyright
14// notice, this list of conditions and the following disclaimer in the
15// documentation and/or other materials provided with the distribution.
16//
17// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21// HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
28// DAMAGE.
29
30#ifndef HPP_CONSTRAINTS_DIFFERENTIABLE_FUNCTION_HH
31#define HPP_CONSTRAINTS_DIFFERENTIABLE_FUNCTION_HH
32
36#include <hpp/util/debug.hh>
38
39namespace hpp {
40namespace constraints {
41
44
64 public:
66
71 assert(argument.size() == inputSize());
73 impl_compute(result, argument);
74 return result;
75 }
76
79 void value(LiegroupElementRef result, vectorIn_t argument) const {
80 assert(result.space()->nq() == outputSize());
81 assert(argument.size() == inputSize());
82 impl_compute(result, argument);
83 }
84
88 void jacobian(matrixOut_t jacobian, vectorIn_t argument) const {
89 assert(argument.size() == inputSize());
90 assert(jacobian.rows() == outputDerivativeSize());
91 assert(jacobian.cols() == inputDerivativeSize());
92 impl_jacobian(jacobian, argument);
93 }
94
97 const ArrayXb& activeParameters() const { return activeParameters_; }
98
104
106 size_type inputSize() const { return inputSize_; }
116 size_type outputSize() const { return outputSpace_->nq(); }
122 const std::string& name() const { return name_; }
123
125 virtual std::ostream& print(std::ostream& o) const;
126
127 std::string context() const { return context_; }
128
129 void context(const std::string& c) { context_ = c; }
130
142 value_type eps =
143 std::sqrt(Eigen::NumTraits<value_type>::epsilon())) const;
144
156 value_type eps =
157 std::sqrt(Eigen::NumTraits<value_type>::epsilon())) const;
158
159 bool operator==(DifferentiableFunction const& other) const;
160 bool operator!=(DifferentiableFunction const& b) const;
161
174 virtual std::pair<JointConstPtr_t, JointConstPtr_t> dependsOnRelPoseBetween(
175 DeviceConstPtr_t /*robot*/) const {
176 return std::pair<JointConstPtr_t, JointConstPtr_t>(nullptr, nullptr);
177 };
178
194 DifferentiableFunctionPtr_t original, interval_t interval);
195
196 protected:
203 DifferentiableFunction(size_type sizeInput, size_type sizeInputDerivative,
204 size_type sizeOutput,
205 std::string name = std::string());
206
213 DifferentiableFunction(size_type sizeInput, size_type sizeInputDerivative,
215 std::string name = std::string());
216
218 virtual void impl_compute(LiegroupElementRef result,
219 vectorIn_t argument) const = 0;
220
221 virtual void impl_jacobian(matrixOut_t jacobian, vectorIn_t arg) const = 0;
222
223 virtual bool isEqual(const DifferentiableFunction& other) const {
224 if (name_ != other.name_) return false;
225 if (inputSize_ != other.inputSize_) return false;
226 if (inputDerivativeSize_ != other.inputDerivativeSize_) return false;
227 if (*outputSpace_ != *(other.outputSpace_)) return false;
228
229 return true;
230 }
231
238
247
248 private:
249 std::string name_;
251 std::string context_;
252
254
255 protected:
257
258 private:
260}; // class DifferentiableFunction
261inline std::ostream& operator<<(std::ostream& os,
262 const DifferentiableFunction& f) {
263 return f.print(os);
264}
265
266} // namespace constraints
267} // namespace hpp
268
269/*
270// This will override boost::shared_ptr 's equality operator
271// between 2 DifferentiableFunctionPtr_t
272namespace boost {
273 using namespace hpp::constraints;
274 typedef DifferentiableFunction T;
275 typedef shared_ptr<T> TPtr;
276
277 template<> inline bool operator==<T, T> (TPtr const & a, TPtr const & b)
278BOOST_SP_NOEXCEPT
279 {
280 return *a == *b;
281 }
282
283 template<> inline bool operator!=<T, T> (TPtr const & a, TPtr const & b)
284BOOST_SP_NOEXCEPT
285 {
286 return !(a == b);
287 }
288}
289*/
290
291#endif // HPP_CONSTRAINTS_DIFFERENTIABLE_FUNCTION_HH
Definition differentiable-function.hh:63
LiegroupSpacePtr_t outputSpace_
Dimension of output vector.
Definition differentiable-function.hh:237
DifferentiableFunction(size_type sizeInput, size_type sizeInputDerivative, const LiegroupSpacePtr_t &outputSpace, std::string name=std::string())
Concrete class constructor should call this constructor.
size_type inputDerivativeSize_
Dimension of input derivative.
Definition differentiable-function.hh:235
virtual bool isEqual(const DifferentiableFunction &other) const
Definition differentiable-function.hh:223
bool operator==(DifferentiableFunction const &other) const
friend class DifferentiableFunctionSet
Definition differentiable-function.hh:253
std::string context() const
Definition differentiable-function.hh:127
bool operator!=(DifferentiableFunction const &b) const
const std::string & name() const
Get function name.
Definition differentiable-function.hh:122
size_type inputSize_
Dimension of input vector.
Definition differentiable-function.hh:233
void finiteDifferenceCentral(matrixOut_t jacobian, vectorIn_t arg, DevicePtr_t robot=DevicePtr_t(), value_type eps=std::sqrt(Eigen::NumTraits< value_type >::epsilon())) const
void context(const std::string &c)
Definition differentiable-function.hh:129
virtual ~DifferentiableFunction()
Definition differentiable-function.hh:65
size_type outputSize() const
Get dimension of output vector.
Definition differentiable-function.hh:116
virtual void impl_jacobian(matrixOut_t jacobian, vectorIn_t arg) const =0
DifferentiableFunction(size_type sizeInput, size_type sizeInputDerivative, size_type sizeOutput, std::string name=std::string())
Concrete class constructor should call this constructor.
size_type inputDerivativeSize() const
Definition differentiable-function.hh:112
size_type outputDerivativeSize() const
Get dimension of output derivative vector.
Definition differentiable-function.hh:118
virtual std::pair< JointConstPtr_t, JointConstPtr_t > dependsOnRelPoseBetween(DeviceConstPtr_t) const
Definition differentiable-function.hh:174
const ArrayXb & activeParameters() const
Definition differentiable-function.hh:97
virtual void impl_compute(LiegroupElementRef result, vectorIn_t argument) const =0
User implementation of function evaluation.
size_type inputSize() const
Get dimension of input vector.
Definition differentiable-function.hh:106
virtual std::ostream & print(std::ostream &o) const
Display object in a stream.
ArrayXb activeParameters_
Definition differentiable-function.hh:242
static DifferentiableFunctionPtr_t extract(DifferentiableFunctionPtr_t original, interval_t interval)
LiegroupElement operator()(vectorIn_t argument) const
Definition differentiable-function.hh:70
void jacobian(matrixOut_t jacobian, vectorIn_t argument) const
Definition differentiable-function.hh:88
LiegroupSpacePtr_t outputSpace() const
Get output space.
Definition differentiable-function.hh:114
DifferentiableFunction()
Definition differentiable-function.hh:256
ArrayXb activeDerivativeParameters_
Definition differentiable-function.hh:246
void value(LiegroupElementRef result, vectorIn_t argument) const
Definition differentiable-function.hh:79
const ArrayXb & activeDerivativeParameters() const
Definition differentiable-function.hh:101
void finiteDifferenceForward(matrixOut_t jacobian, vectorIn_t arg, DevicePtr_t robot=DevicePtr_t(), value_type eps=std::sqrt(Eigen::NumTraits< value_type >::epsilon())) const
const LiegroupSpacePtr_t & space() const
#define HPP_CONSTRAINTS_DLLAPI
Definition config.hh:88
Definition active-set-differentiable-function.hh:37
pinocchio::LiegroupElement LiegroupElement
Definition fwd.hh:65
pinocchio::DevicePtr_t DevicePtr_t
Definition fwd.hh:110
pinocchio::DeviceConstPtr_t DeviceConstPtr_t
Definition fwd.hh:111
pinocchio::LiegroupSpacePtr_t LiegroupSpacePtr_t
Definition fwd.hh:69
shared_ptr< DifferentiableFunction > DifferentiableFunctionPtr_t
Definition fwd.hh:114
ComparisonTypes_t operator<<(const ComparisonType &a, const ComparisonType &b)
Definition comparison-types.hh:61
std::pair< value_type, value_type > interval_t
Definition fwd.hh:84
pinocchio::size_type size_type
Definition fwd.hh:47
pinocchio::ArrayXb ArrayXb
Definition fwd.hh:80
pinocchio::value_type value_type
Definition fwd.hh:48
pinocchio::vectorIn_t vectorIn_t
Definition fwd.hh:60
Eigen::Ref< matrix_t > matrixOut_t
Definition fwd.hh:58
pinocchio::LiegroupElementRef LiegroupElementRef
Definition fwd.hh:66
#define HPP_SERIALIZABLE()