hpp-core  6.0.0
Implement basic classes for canonical path planning for kinematic chains.
dubins.hh
Go to the documentation of this file.
1 //
2 // Copyright (c) 2017 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_CORE_STEERING_METHOD_DUBINS_HH
31 #define HPP_CORE_STEERING_METHOD_DUBINS_HH
32 
33 #include <hpp/core/config.hh>
34 #include <hpp/core/fwd.hh>
37 #include <hpp/util/debug.hh>
38 #include <hpp/util/pointer.hh>
39 
40 namespace hpp {
41 namespace core {
42 namespace steeringMethod {
45 
48 class HPP_CORE_DLLAPI Dubins : public CarLike {
49  public:
59  Dubins* ptr = new Dubins(problem);
60  DubinsPtr_t shPtr(ptr);
61  ptr->init(shPtr);
62  return shPtr;
63  }
64 
69  const ProblemConstPtr_t& problem, const value_type turningRadius,
70  JointPtr_t xyJoint, JointPtr_t rzJoint,
71  std::vector<JointPtr_t> wheels = std::vector<JointPtr_t>()) {
72  Dubins* ptr = new Dubins(problem, turningRadius, xyJoint, rzJoint, wheels);
73  DubinsPtr_t shPtr(ptr);
74  ptr->init(shPtr);
75  return shPtr;
76  }
77 
79  static DubinsPtr_t createCopy(const DubinsPtr_t& other) {
80  Dubins* ptr = new Dubins(*other);
81  DubinsPtr_t shPtr(ptr);
82  ptr->init(shPtr);
83  return shPtr;
84  }
85 
87  virtual SteeringMethodPtr_t copy() const { return createCopy(weak_.lock()); }
88 
91  ConfigurationIn_t q2) const;
92 
93  protected:
95  Dubins(const ProblemConstPtr_t& problem);
96 
98  Dubins(const ProblemConstPtr_t& problem, const value_type turningRadius,
99  JointPtr_t xyJoint, JointPtr_t rzJoint,
100  std::vector<JointPtr_t> wheels);
101 
103  Dubins(const Dubins& other);
104 
106  void init(DubinsWkPtr_t weak) {
107  CarLike::init(weak);
108  weak_ = weak;
109  }
110 
111  private:
112  DubinsWkPtr_t weak_;
113 }; // Dubins
115 } // namespace steeringMethod
116 } // namespace core
117 } // namespace hpp
118 #endif // HPP_CORE_STEERING_METHOD_DUBINS_HH
Definition: car-like.hh:49
void init(CarLikeWkPtr_t weak)
Store weak pointer to itself.
Definition: car-like.hh:75
Definition: dubins.hh:48
static DubinsPtr_t create(const ProblemConstPtr_t &problem, const value_type turningRadius, JointPtr_t xyJoint, JointPtr_t rzJoint, std::vector< JointPtr_t > wheels=std::vector< JointPtr_t >())
Definition: dubins.hh:68
virtual PathPtr_t impl_compute(ConfigurationIn_t q1, ConfigurationIn_t q2) const
create a path between two configurations
virtual SteeringMethodPtr_t copy() const
Copy instance and return shared pointer.
Definition: dubins.hh:87
void init(DubinsWkPtr_t weak)
Store weak pointer to itself.
Definition: dubins.hh:106
static DubinsPtr_t createWithGuess(const ProblemConstPtr_t &problem)
Definition: dubins.hh:58
Dubins(const Dubins &other)
Copy constructor.
Dubins(const ProblemConstPtr_t &problem, const value_type turningRadius, JointPtr_t xyJoint, JointPtr_t rzJoint, std::vector< JointPtr_t > wheels)
Constructor.
static DubinsPtr_t createCopy(const DubinsPtr_t &other)
Copy instance and return shared pointer.
Definition: dubins.hh:79
Dubins(const ProblemConstPtr_t &problem)
Constructor.
#define HPP_CORE_DLLAPI
Definition: config.hh:88
shared_ptr< Dubins > DubinsPtr_t
Definition: fwd.hh:45
pinocchio::value_type value_type
Definition: fwd.hh:174
shared_ptr< SteeringMethod > SteeringMethodPtr_t
Definition: fwd.hh:213
pinocchio::JointPtr_t JointPtr_t
Definition: fwd.hh:151
pinocchio::ConfigurationIn_t ConfigurationIn_t
Definition: fwd.hh:108
shared_ptr< const Problem > ProblemConstPtr_t
Definition: fwd.hh:197
shared_ptr< Path > PathPtr_t
Definition: fwd.hh:187
Definition: bi-rrt-planner.hh:35