DART 6.7.3
Loading...
Searching...
No Matches
Path.hpp
Go to the documentation of this file.
1/*
2 * Copyright (c) 2011-2019, The DART development contributors
3 * All rights reserved.
4 *
5 * The list of contributors can be found at:
6 * https://github.com/dartsim/dart/blob/master/LICENSE
7 *
8 * This file is provided under the following "BSD-style" License:a
9 * Redistribution and use in source and binary forms, with or
10 * without modification, are permitted provided that the following
11 * conditions are met:
12 * * Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * * Redistributions in binary form must reproduce the above
15 * copyright notice, this list of conditions and the following
16 * disclaimer in the documentation and/or other materials provided
17 * with the distribution.
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
19 * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
20 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
26 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
27 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 * POSSIBILITY OF SUCH DAMAGE.
31 */
32
33// Algorithm details and publications: http://www.golems.org/node/1570
34
35#ifndef DART_PLANNING_PATH_HPP_
36#define DART_PLANNING_PATH_HPP_
37
38#include <list>
39#include <Eigen/Core>
40
41namespace dart {
42namespace planning {
43
45{
46public:
47 PathSegment(double length = 0.0) :
49 {
50 }
51
52 virtual ~PathSegment() {}
53
54 double getLength() const {
55 return length;
56 }
57 virtual Eigen::VectorXd getConfig(double s) const = 0;
58 virtual Eigen::VectorXd getTangent(double s) const = 0;
59 virtual Eigen::VectorXd getCurvature(double s) const = 0;
60 virtual std::list<double> getSwitchingPoints() const = 0;
61 virtual PathSegment* clone() const = 0;
62
63 double position;
64protected:
65 double length;
66};
67
68
69
70class Path
71{
72public:
73 Path(const std::list<Eigen::VectorXd> &path, double maxDeviation = 0.0);
74 Path(const Path &path);
75 ~Path();
76 double getLength() const;
77 Eigen::VectorXd getConfig(double s) const;
78 Eigen::VectorXd getTangent(double s) const;
79 Eigen::VectorXd getCurvature(double s) const;
80 double getNextSwitchingPoint(double s, bool &discontinuity) const;
81 std::list<std::pair<double, bool> > getSwitchingPoints() const;
82private:
83 PathSegment* getPathSegment(double &s) const;
84 double length;
85 std::list<std::pair<double, bool> > switchingPoints;
86 std::list<PathSegment*> pathSegments;
87};
88
89} // namespace planning
90} // namespace dart
91
92#endif // DART_PLANNING_PATH_HPP_
Definition Path.hpp:45
virtual ~PathSegment()
Definition Path.hpp:52
double position
Definition Path.hpp:63
virtual Eigen::VectorXd getCurvature(double s) const =0
virtual Eigen::VectorXd getTangent(double s) const =0
double length
Definition Path.hpp:65
double getLength() const
Definition Path.hpp:54
PathSegment(double length=0.0)
Definition Path.hpp:47
virtual std::list< double > getSwitchingPoints() const =0
virtual PathSegment * clone() const =0
virtual Eigen::VectorXd getConfig(double s) const =0
Definition Path.hpp:71
Eigen::VectorXd getTangent(double s) const
Definition Path.cpp:270
double getNextSwitchingPoint(double s, bool &discontinuity) const
Definition Path.cpp:280
double getLength() const
Definition Path.cpp:249
std::list< std::pair< double, bool > > getSwitchingPoints() const
Definition Path.cpp:295
Path(const std::list< Eigen::VectorXd > &path, double maxDeviation=0.0)
~Path()
Definition Path.cpp:243
Eigen::VectorXd getCurvature(double s) const
Definition Path.cpp:275
std::list< std::pair< double, bool > > switchingPoints
Definition Path.hpp:85
PathSegment * getPathSegment(double &s) const
Definition Path.cpp:253
Eigen::VectorXd getConfig(double s) const
Definition Path.cpp:265
std::list< PathSegment * > pathSegments
Definition Path.hpp:86
double length
Definition Path.hpp:84
Definition BulletCollisionDetector.cpp:63