Apollo 11.0
自动驾驶开放平台
speed_data.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
20#pragma once
21
22#include <string>
23#include <vector>
24
25#include "modules/common_msgs/basic_msgs/pnc_point.pb.h"
26
27namespace apollo {
28namespace planning {
29
30class SpeedData : public std::vector<common::SpeedPoint> {
31 public:
32 SpeedData() = default;
33
34 virtual ~SpeedData() = default;
35
36 explicit SpeedData(std::vector<common::SpeedPoint> speed_points);
37
38 void AppendSpeedPoint(const double s, const double time, const double v,
39 const double a, const double da);
40
41 bool EvaluateByTime(const double time,
42 common::SpeedPoint* const speed_point) const;
43
44 // Assuming spatial traversed distance is monotonous, which is the case for
45 // current usage on city driving scenario
46 bool EvaluateByS(const double s, common::SpeedPoint* const speed_point) const;
47
48 double TotalTime() const;
49
50 // Assuming spatial traversed distance is monotonous
51 double TotalLength() const;
52
53 virtual std::string DebugString() const;
54};
55
56} // namespace planning
57} // namespace apollo
bool EvaluateByS(const double s, common::SpeedPoint *const speed_point) const
void AppendSpeedPoint(const double s, const double time, const double v, const double a, const double da)
Definition speed_data.cc:48
virtual std::string DebugString() const
virtual ~SpeedData()=default
bool EvaluateByTime(const double time, common::SpeedPoint *const speed_point) const
Definition speed_data.cc:60
Planning module main class.
class register implement
Definition arena_queue.h:37