Apollo  6.0
Open source self driving car software
junction_predictor.h
Go to the documentation of this file.
1 /******************************************************************************
2  * Copyright 2018 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 
22 #pragma once
23 
24 #include <string>
25 #include <vector>
26 
29 
30 namespace apollo {
31 namespace prediction {
32 
33 class JunctionPredictor : public Predictor {
34  public:
39 
43  virtual ~JunctionPredictor() = default;
44 
52  bool Predict(const ADCTrajectoryContainer* adc_trajectory_container,
53  Obstacle* obstacle,
54  ObstaclesContainer* obstacles_container) override;
55 
56  private:
57  void DrawJunctionTrajectoryPoints(
58  const Feature& feature, const JunctionExit& junction_exit,
59  const double total_time, const double period,
60  std::vector<apollo::common::TrajectoryPoint>* trajectory_points);
61 
62  std::vector<JunctionExit> MostLikelyJunctions(const Feature& feature);
63 
68  double GetBestTime(const std::array<double, 2>& start_x,
69  const std::array<double, 2>& end_x,
70  const std::array<double, 2>& start_y,
71  const std::array<double, 2>& end_y);
72 
73  double CostFunction(const std::array<double, 4>& x_coeffs,
74  const std::array<double, 4>& y_coeffs,
75  const double time_to_exit);
76 
77  std::vector<double> GenerateCandidateTimes();
78 };
79 
80 } // namespace prediction
81 } // namespace apollo
Define the predictor base class.
Prediction obstacle.
Definition: obstacle.h:52
Definition: obstacles_container.h:39
bool Predict(const ADCTrajectoryContainer *adc_trajectory_container, Obstacle *obstacle, ObstaclesContainer *obstacles_container) override
Make prediction.
PlanningContext is the runtime context in planning. It is persistent across multiple frames...
Definition: atomic_hash_map.h:25
Definition: predictor.h:38
Definition: junction_predictor.h:33
Obstacles container.
virtual ~JunctionPredictor()=default
Destructor.
Definition: adc_trajectory_container.h:37