hpp-core  6.0.0
Implement basic classes for canonical path planning for kinematic chains.
dichotomy.hh
Go to the documentation of this file.
1 // Copyright (c) 2014, LAAS-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_CORE_PATHPROJECTOR_DICHOTOMY_HH
30 #define HPP_CORE_PATHPROJECTOR_DICHOTOMY_HH
31 
33 
34 #include "hpp/core/problem.hh"
35 
36 namespace hpp {
37 namespace core {
38 namespace pathProjector {
40  public:
43  static DichotomyPtr_t create(const DistancePtr_t& distance,
44  const SteeringMethodPtr_t& steeringMethod,
45  value_type maxPathLength) {
46  return DichotomyPtr_t(
47  new Dichotomy(distance, steeringMethod, maxPathLength));
48  }
49 
50  static DichotomyPtr_t create(const ProblemConstPtr_t& problem,
51  value_type maxPathLength) {
52  return create(problem->distance(), problem->steeringMethod(),
53  maxPathLength);
54  }
55 
56  protected:
57  bool impl_apply(const PathPtr_t& path, PathPtr_t& projection) const;
58 
59  Dichotomy(const DistancePtr_t& distance,
60  const SteeringMethodPtr_t& steeringMethod,
61  value_type maxPathLength);
62 
64  PathPtr_t& projection) const;
65 
66  private:
67  value_type maxPathLength_;
68 };
69 } // namespace pathProjector
70 } // namespace core
71 } // namespace hpp
72 #endif // HPP_CORE_PATHPROJECTOR_DICHOTOMY_HH
This class projects a path using constraints.
Definition: path-projector.hh:38
hpp::core::PathPtr_t PathPtr_t
Definition: path-projector.hh:41
Definition: straight-path.hh:52
Definition: dichotomy.hh:39
hpp::core::StraightPath StraightPath
Definition: dichotomy.hh:41
static DichotomyPtr_t create(const DistancePtr_t &distance, const SteeringMethodPtr_t &steeringMethod, value_type maxPathLength)
Definition: dichotomy.hh:43
Dichotomy(const DistancePtr_t &distance, const SteeringMethodPtr_t &steeringMethod, value_type maxPathLength)
bool applyToStraightPath(const StraightPathPtr_t &path, PathPtr_t &projection) const
static DichotomyPtr_t create(const ProblemConstPtr_t &problem, value_type maxPathLength)
Definition: dichotomy.hh:50
hpp::core::StraightPathPtr_t StraightPathPtr_t
Definition: dichotomy.hh:42
bool impl_apply(const PathPtr_t &path, PathPtr_t &projection) const
Method to be reimplemented by inherited class.
#define HPP_CORE_DLLAPI
Definition: config.hh:88
shared_ptr< Dichotomy > DichotomyPtr_t
Definition: fwd.hh:330
pinocchio::value_type value_type
Definition: fwd.hh:174
shared_ptr< StraightPath > StraightPathPtr_t
Definition: fwd.hh:200
shared_ptr< Distance > DistancePtr_t
Definition: fwd.hh:141
shared_ptr< SteeringMethod > SteeringMethodPtr_t
Definition: fwd.hh:213
shared_ptr< const Problem > ProblemConstPtr_t
Definition: fwd.hh:197
Definition: bi-rrt-planner.hh:35