hpp-core  6.0.0
Implement basic classes for canonical path planning for kinematic chains.
continuous-validation.hh
Go to the documentation of this file.
1 //
2 // Copyright (c) 2014, 2015, 2016, 2017, 2018 CNRS
3 // Authors: Florent Lamiraux, Joseph Mirabel, Diane Bury
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_CORE_CONTINUOUS_VALIDATION_HH
31 #define HPP_CORE_CONTINUOUS_VALIDATION_HH
32 
34 #include <hpp/core/fwd.hh>
38 #include <hpp/core/path.hh>
39 #include <hpp/pinocchio/pool.hh>
40 
41 namespace hpp {
42 namespace core {
43 using continuousValidation::IntervalValidation;
47 
97  public ObstacleUserInterface {
98  public:
102  class Initialize {
103  public:
110  virtual void doExecute() const;
111  ContinuousValidation& owner() const { return *owner_; }
112  virtual ~Initialize() {}
113 
114  protected:
116  }; // class Initialize
120  class AddObstacle {
121  public:
127  virtual void doExecute(const CollisionObjectConstPtr_t& object) const;
128  ContinuousValidation& owner() const { return *owner_; }
129  virtual ~AddObstacle() {}
130 
131  protected:
134  }; // class AddObstacle
135 
145  virtual bool validate(const PathPtr_t& path, bool reverse,
146  PathPtr_t& validPart,
147  PathValidationReportPtr_t& report);
151  virtual void addObstacle(const CollisionObjectConstPtr_t& object);
152 
160  const JointPtr_t& joint, const CollisionObjectConstPtr_t& obstacle);
161 
171 
173  virtual void setSecurityMargins(const matrix_t& securityMatrix);
174 
176  virtual void setSecurityMarginBetweenBodies(const std::string& body_a,
177  const std::string& body_b,
178  const value_type& margin);
179 
182 
200  template <class Delegate>
201  void add(const Delegate& delegate);
202 
205  template <class Delegate>
206  void reset();
207 
210  void addIntervalValidation(const IntervalValidationPtr_t& intervalValidation);
212  value_type tolerance() const { return tolerance_; }
213 
216  value_type breakDistance() const { return breakDistance_; }
217 
220  void breakDistance(value_type distance);
221 
222  DevicePtr_t robot() const { return robot_; }
225  void initialize();
226 
228 
229  protected:
231 
232  static void setPath(IntervalValidations_t& intervalValidations,
233  const PathPtr_t& path, bool reverse);
234 
238  ContinuousValidation(const DevicePtr_t& robot, const value_type& tolerance);
239 
250  virtual bool validateConfiguration(IntervalValidations_t& intervalValidations,
251  const Configuration_t& config,
252  const value_type& t, interval_t& interval,
253  PathValidationReportPtr_t& report);
254 
268  IntervalValidations_t& validations, const value_type& t,
269  interval_t& interval, PathValidationReportPtr_t& pathReport,
270  typename IntervalValidations_t::iterator& smallestInterval,
271  pinocchio::DeviceData& data) {
272  typename IntervalValidations_t::iterator itMin = validations.begin();
273  for (IntervalValidations_t::iterator itVal(validations.begin());
274  itVal != validations.end(); ++itVal) {
275  ValidationReportPtr_t report;
276  // the valid interval will not be greater than "interval" so we do not
277  // need to perform validation on a greater interval.
278  interval_t tmpInt = interval;
279  if (!(*itVal)->validateConfiguration(t, tmpInt, report, data)) {
281  pathReport->configurationReport = report;
282  pathReport->parameter = t;
283  return false;
284  } else {
285  if (interval.second > tmpInt.second) {
286  itMin = itVal;
287  smallestInterval = itVal;
288  }
289  interval.first = std::max(interval.first, tmpInt.first);
290  interval.second = std::min(interval.second, tmpInt.second);
291  assert((*itVal)->path()->length() == 0 ||
292  interval.second > interval.first);
293  assert(interval.first <= t);
294  assert(t <= interval.second);
295  }
296  }
297  return true;
298  }
299 
303 
305  void init(ContinuousValidationWkPtr_t weak);
306 
311 
312  pinocchio::Pool<IntervalValidations_t> bodyPairCollisionPool_;
313 
315 
316  private:
317  // Weak pointer to itself
318  ContinuousValidationWkPtr_t weak_;
319 
320  virtual bool validateStraightPath(IntervalValidations_t& intervalValidations,
321  const PathPtr_t& path, bool reverse,
322  PathPtr_t& validPart,
323  PathValidationReportPtr_t& report) = 0;
324 
325  std::vector<Initialize> initialize_;
326  std::vector<AddObstacle> addObstacle_;
327 }; // class ContinuousValidation
329 template <>
330 void ContinuousValidation::add<ContinuousValidation::AddObstacle>(
331  const ContinuousValidation::AddObstacle& delegate);
332 
333 template <>
334 void ContinuousValidation::reset<ContinuousValidation::AddObstacle>();
335 
336 template <>
337 void ContinuousValidation::add<ContinuousValidation::Initialize>(
338  const ContinuousValidation::Initialize& delegate);
339 
340 template <>
341 void ContinuousValidation::reset<ContinuousValidation::Initialize>();
342 
343 template <class Delegate>
344 void ContinuousValidation::add(const Delegate& delegate) {
345  assert(false && "No delegate of this type in class ContinuousValidation.");
346 }
347 template <class Delegate>
349  assert(false && "No delegate of this type in class ContinuousValidation.");
350 }
351 
352 } // namespace core
353 } // namespace hpp
354 #endif // HPP_CORE_CONTINUOUS_VALIDATION_HH
Definition: continuous-validation.hh:120
ContinuousValidation * owner_
Definition: continuous-validation.hh:132
DeviceWkPtr_t robot_
Definition: continuous-validation.hh:133
AddObstacle(ContinuousValidation &owner)
virtual void doExecute(const CollisionObjectConstPtr_t &object) const
virtual ~AddObstacle()
Definition: continuous-validation.hh:129
ContinuousValidation & owner() const
Definition: continuous-validation.hh:128
Definition: continuous-validation.hh:102
virtual ~Initialize()
Definition: continuous-validation.hh:112
ContinuousValidation * owner_
Definition: continuous-validation.hh:115
Initialize(ContinuousValidation &owner)
ContinuousValidation & owner() const
Definition: continuous-validation.hh:111
Definition: continuous-validation.hh:97
void init(ContinuousValidationWkPtr_t weak)
Store weak pointer to itself.
static void setPath(IntervalValidations_t &intervalValidations, const PathPtr_t &path, bool reverse)
virtual bool validate(const PathPtr_t &path, bool reverse, PathPtr_t &validPart, PathValidationReportPtr_t &report)
virtual void addObstacle(const CollisionObjectConstPtr_t &object)
IntervalValidations_t intervalValidations_
All BodyPairValidation to validate.
Definition: continuous-validation.hh:308
continuousValidation::IntervalValidations_t IntervalValidations_t
Definition: continuous-validation.hh:230
void breakDistance(value_type distance)
virtual void setSecurityMargins(const matrix_t &securityMatrix)
bool validateIntervals(IntervalValidations_t &validations, const value_type &t, interval_t &interval, PathValidationReportPtr_t &pathReport, typename IntervalValidations_t::iterator &smallestInterval, pinocchio::DeviceData &data)
Definition: continuous-validation.hh:267
virtual bool validateConfiguration(IntervalValidations_t &intervalValidations, const Configuration_t &config, const value_type &t, interval_t &interval, PathValidationReportPtr_t &report)
ContinuousValidation(const DevicePtr_t &robot, const value_type &tolerance)
pinocchio::Pool< IntervalValidations_t > bodyPairCollisionPool_
Definition: continuous-validation.hh:312
void addIntervalValidation(const IntervalValidationPtr_t &intervalValidation)
void filterCollisionPairs(const RelativeMotion::matrix_type &relMotion)
void reset()
Definition: continuous-validation.hh:348
DevicePtr_t robot() const
Definition: continuous-validation.hh:222
IntervalValidations_t disabledBodyPairCollisions_
BodyPairCollision for which collision is disabled.
Definition: continuous-validation.hh:310
value_type tolerance_
Definition: continuous-validation.hh:301
virtual void setSecurityMarginBetweenBodies(const std::string &body_a, const std::string &body_b, const value_type &margin)
value_type tolerance() const
Get tolerance value.
Definition: continuous-validation.hh:212
value_type breakDistance_
Definition: continuous-validation.hh:302
value_type stepSize_
Definition: continuous-validation.hh:314
value_type breakDistance() const
Definition: continuous-validation.hh:216
DevicePtr_t robot_
Definition: continuous-validation.hh:300
void add(const Delegate &delegate)
Definition: continuous-validation.hh:344
virtual void removeObstacleFromJoint(const JointPtr_t &joint, const CollisionObjectConstPtr_t &obstacle)
Definition: obstacle-user.hh:47
Definition: path-validation.hh:51
#define HPP_CORE_DLLAPI
Definition: config.hh:88
shared_ptr< IntervalValidation > IntervalValidationPtr_t
Definition: fwd.hh:261
std::vector< IntervalValidationPtr_t > IntervalValidations_t
Definition: fwd.hh:262
pinocchio::DeviceWkPtr_t DeviceWkPtr_t
Definition: fwd.hh:135
pinocchio::value_type value_type
Definition: fwd.hh:174
pinocchio::JointPtr_t JointPtr_t
Definition: fwd.hh:151
std::pair< value_type, value_type > interval_t
Definition: fwd.hh:175
shared_ptr< ValidationReport > ValidationReportPtr_t
Definition: fwd.hh:225
pinocchio::Configuration_t Configuration_t
Definition: fwd.hh:107
pinocchio::DevicePtr_t DevicePtr_t
Definition: fwd.hh:134
shared_ptr< Path > PathPtr_t
Definition: fwd.hh:187
shared_ptr< PathValidationReport > PathValidationReportPtr_t
Definition: fwd.hh:317
pinocchio::CollisionObjectConstPtr_t CollisionObjectConstPtr_t
Definition: fwd.hh:100
pinocchio::matrix_t matrix_t
Definition: fwd.hh:162
Definition: bi-rrt-planner.hh:35
Definition: path-validation-report.hh:45
Eigen::Matrix< RelativeMotionType, Eigen::Dynamic, Eigen::Dynamic > matrix_type
Definition: relative-motion.hh:62