Apollo 11.0
自动驾驶开放平台
discretized_trajectory.h
浏览该文件的文档.
1/******************************************************************************
2 * Copyright 2017 The Apollo Authors. All Rights Reserved.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 *****************************************************************************/
16
21#pragma once
22
23#include <vector>
24
25#include "modules/common_msgs/planning_msgs/planning.pb.h"
26
27#include "cyber/common/log.h"
29
30namespace apollo {
31namespace planning {
32
33class DiscretizedTrajectory : public std::vector<common::TrajectoryPoint> {
34 public:
36
40 explicit DiscretizedTrajectory(const ADCTrajectory& trajectory);
41
42 explicit DiscretizedTrajectory(
43 const std::vector<common::TrajectoryPoint>& trajectory_points);
44
46 const std::vector<common::TrajectoryPoint>& trajectory_points);
47
48 virtual ~DiscretizedTrajectory() = default;
49
50 virtual common::TrajectoryPoint StartPoint() const;
51
52 virtual double GetTemporalLength() const;
53
54 virtual double GetSpatialLength() const;
55
56 virtual common::TrajectoryPoint Evaluate(const double relative_time) const;
57
58 virtual size_t QueryLowerBoundPoint(const double relative_time,
59 const double epsilon = 1.0e-5) const;
60
61 virtual size_t QueryNearestPoint(const common::math::Vec2d& position) const;
62
64 const double buffer) const;
65
66 virtual void AppendTrajectoryPoint(
67 const common::TrajectoryPoint& trajectory_point);
68
70 const std::vector<common::TrajectoryPoint>& trajectory_points) {
71 if (!empty() && trajectory_points.size() > 1) {
72 ACHECK(trajectory_points.back().relative_time() <
73 front().relative_time());
74 }
75 insert(begin(), trajectory_points.begin(), trajectory_points.end());
76 }
77
78 const common::TrajectoryPoint& TrajectoryPointAt(const size_t index) const;
79
80 size_t NumOfPoints() const;
81
82 virtual void Clear();
83 bool IsReversed() const { return is_reversed_; }
84 void SetIsReversed(const bool flag) { is_reversed_ = flag; }
85
86 private:
87 bool is_reversed_ = false;
88};
89
90inline size_t DiscretizedTrajectory::NumOfPoints() const { return size(); }
91
92inline void DiscretizedTrajectory::Clear() { clear(); }
93
94} // namespace planning
95} // namespace apollo
Implements a class of 2-dimensional vectors.
Definition vec2d.h:42
size_t QueryNearestPointWithBuffer(const common::math::Vec2d &position, const double buffer) const
void PrependTrajectoryPoints(const std::vector< common::TrajectoryPoint > &trajectory_points)
const common::TrajectoryPoint & TrajectoryPointAt(const size_t index) const
virtual size_t QueryNearestPoint(const common::math::Vec2d &position) const
void SetTrajectoryPoints(const std::vector< common::TrajectoryPoint > &trajectory_points)
virtual size_t QueryLowerBoundPoint(const double relative_time, const double epsilon=1.0e-5) const
virtual common::TrajectoryPoint StartPoint() const
virtual void AppendTrajectoryPoint(const common::TrajectoryPoint &trajectory_point)
virtual common::TrajectoryPoint Evaluate(const double relative_time) const
Planning module main class.
#define ACHECK(cond)
Definition log.h:80
class register implement
Definition arena_queue.h:37
Defines the Vec2d class.