scenario_simulator_v2 C++ API
catmull_rom_subspline.hpp
Go to the documentation of this file.
1 // Copyright 2015 TIER IV.inc. All rights reserved.
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 #ifndef GEOMETRY__SPLINE__CATMULL_ROM_SUBSPLINE_HPP_
16 #define GEOMETRY__SPLINE__CATMULL_ROM_SUBSPLINE_HPP_
17 
18 #include <exception>
22 #include <geometry_msgs/msg/point.hpp>
23 #include <optional>
24 #include <string>
25 #include <utility>
26 #include <vector>
27 
28 namespace math
29 {
30 namespace geometry
31 {
33 {
34 public:
36  std::shared_ptr<math::geometry::CatmullRomSpline> spline, const double start_s,
37  const double end_s)
38  : spline_(spline), start_s_(start_s), end_s_(end_s)
39  {
40  }
41 
42  double getLength() const override;
43 
44  std::optional<double> getCollisionPointIn2D(
45  const std::vector<geometry_msgs::msg::Point> & polygon,
46  const bool search_backward = false) const override;
47 
48 private:
49  std::shared_ptr<math::geometry::CatmullRomSpline> spline_;
50  double start_s_;
51  double end_s_;
52 };
53 } // namespace geometry
54 } // namespace math
55 
56 #endif // GEOMETRY__SPLINE__CATMULL_ROM_SUBSPLINE_HPP_
Definition: catmull_rom_spline_interface.hpp:30
Definition: catmull_rom_subspline.hpp:33
double getLength() const override
Definition: catmull_rom_subspline.cpp:24
CatmullRomSubspline(std::shared_ptr< math::geometry::CatmullRomSpline > spline, const double start_s, const double end_s)
Definition: catmull_rom_subspline.hpp:35
std::optional< double > getCollisionPointIn2D(const std::vector< geometry_msgs::msg::Point > &polygon, const bool search_backward=false) const override
Definition: catmull_rom_subspline.cpp:26
Definition: bounding_box.hpp:32