Apollo 10.0
自动驾驶开放平台
apollo::planning::BareIntersectionUnprotectedStageApproach类 参考

#include <stage_approach.h>

类 apollo::planning::BareIntersectionUnprotectedStageApproach 继承关系图:
apollo::planning::BareIntersectionUnprotectedStageApproach 的协作图:

Public 成员函数

StageResult Process (const common::TrajectoryPoint &planning_init_point, Frame *frame) override
 Each stage does its business logic inside Process function.
 
bool CheckClear (const ReferenceLineInfo &reference_line_info, std::vector< std::string > *wait_for_obstacle_ids)
 
StageResult FinishStage (Frame *frame)
 
- Public 成员函数 继承自 apollo::planning::Stage
 Stage ()
 
virtual bool Init (const StagePipeline &config, const std::shared_ptr< DependencyInjector > &injector, const std::string &config_dir, void *context)
 
virtual ~Stage ()=default
 
const std::string & Name () const
 
template<typename T >
T * GetContextAs () const
 
const std::string & NextStage () const
 

额外继承的成员函数

- Protected 成员函数 继承自 apollo::planning::Stage
StageResult ExecuteTaskOnReferenceLine (const common::TrajectoryPoint &planning_start_point, Frame *frame)
 
StageResult ExecuteTaskOnReferenceLineForOnlineLearning (const common::TrajectoryPoint &planning_start_point, Frame *frame)
 
StageResult ExecuteTaskOnOpenSpace (Frame *frame)
 
virtual StageResult FinishScenario ()
 
void RecordDebugInfo (ReferenceLineInfo *reference_line_info, const std::string &name, const double time_diff_ms)
 
- Protected 属性 继承自 apollo::planning::Stage
std::vector< std::shared_ptr< Task > > task_list_
 
std::shared_ptr< Taskfallback_task_
 
std::string next_stage_
 
void * context_
 
std::shared_ptr< DependencyInjectorinjector_
 
StagePipeline pipeline_config_
 

详细描述

在文件 stage_approach.h36 行定义.

成员函数说明

◆ CheckClear()

bool apollo::planning::BareIntersectionUnprotectedStageApproach::CheckClear ( const ReferenceLineInfo reference_line_info,
std::vector< std::string > *  wait_for_obstacle_ids 
)

在文件 stage_approach.cc133 行定义.

135 {
136 // TODO(all): move to conf
137 static constexpr double kConf_min_boundary_t = 6.0; // second
138 static constexpr double kConf_ignore_max_st_min_t = 0.1; // second
139 static constexpr double kConf_ignore_min_st_min_s = 15.0; // meter
140
141 bool all_far_away = true;
142 for (auto* obstacle :
143 reference_line_info.path_decision().obstacles().Items()) {
144 if (obstacle->IsVirtual() || obstacle->IsStatic()) {
145 continue;
146 }
147 if (obstacle->reference_line_st_boundary().min_t() < kConf_min_boundary_t) {
148 const double kepsilon = 1e-6;
149 double obstacle_traveled_s =
150 obstacle->reference_line_st_boundary().bottom_left_point().s() -
151 obstacle->reference_line_st_boundary().bottom_right_point().s();
152 ADEBUG << "obstacle[" << obstacle->Id() << "] obstacle_st_min_t["
153 << obstacle->reference_line_st_boundary().min_t()
154 << "] obstacle_st_min_s["
155 << obstacle->reference_line_st_boundary().min_s()
156 << "] obstacle_traveled_s[" << obstacle_traveled_s << "]";
157
158 // ignore the obstacle which is already on reference line and moving
159 // along the direction of ADC
160 if (obstacle_traveled_s < kepsilon &&
161 obstacle->reference_line_st_boundary().min_t() <
162 kConf_ignore_max_st_min_t &&
163 obstacle->reference_line_st_boundary().min_s() >
164 kConf_ignore_min_st_min_s) {
165 continue;
166 }
167
168 wait_for_obstacle_ids->push_back(obstacle->Id());
169 all_far_away = false;
170 }
171 }
172 return all_far_away;
173}
#define ADEBUG
Definition log.h:41

◆ FinishStage()

StageResult apollo::planning::BareIntersectionUnprotectedStageApproach::FinishStage ( Frame frame)

在文件 stage_approach.cc175 行定义.

176 {
177 next_stage_ = "BARE_INTERSECTION_UNPROTECTED_INTERSECTION_CRUISE";
178
179 // reset cruise_speed
180 auto& reference_line_info = frame->mutable_reference_line_info()->front();
181 reference_line_info.LimitCruiseSpeed(FLAGS_default_cruise_speed);
182
183 return StageResult(StageStatusType::FINISHED);
184}
std::string next_stage_
Definition stage.h:89

◆ Process()

StageResult apollo::planning::BareIntersectionUnprotectedStageApproach::Process ( const common::TrajectoryPoint planning_init_point,
Frame frame 
)
overridevirtual

Each stage does its business logic inside Process function.

If the stage want to transit to a different stage after finish, it should set the type of 'next_stage_'.

实现了 apollo::planning::Stage.

在文件 stage_approach.cc37 行定义.

38 {
39 ADEBUG << "stage: Approach";
40 CHECK_NOTNULL(frame);
41
42 scenario_config_.CopyFrom(
43 GetContextAs<BareIntersectionUnprotectedContext>()->scenario_config);
44
45 StageResult result = ExecuteTaskOnReferenceLine(planning_init_point, frame);
46 if (result.HasError()) {
47 AERROR << "BareIntersectionUnprotectedStageApproach planning error";
48 }
49
50 const auto& reference_line_info = frame->reference_line_info().front();
51
52 const std::string pnc_junction_overlap_id =
53 GetContextAs<BareIntersectionUnprotectedContext>()
54 ->current_pnc_junction_overlap_id;
55 if (pnc_junction_overlap_id.empty()) {
56 return FinishScenario();
57 }
58
59 // get overlap along reference line
60 PathOverlap* current_pnc_junction =
61 reference_line_info.GetOverlapOnReferenceLine(
62 pnc_junction_overlap_id, ReferenceLineInfo::PNC_JUNCTION);
63 if (!current_pnc_junction) {
64 return FinishScenario();
65 }
66
67 static constexpr double kPassStopLineBuffer = 0.3; // unit: m
68 const double adc_front_edge_s = reference_line_info.AdcSlBoundary().end_s();
69 const double distance_adc_to_pnc_junction =
70 current_pnc_junction->start_s - adc_front_edge_s;
71 ADEBUG << "pnc_junction_overlap_id[" << pnc_junction_overlap_id
72 << "] start_s[" << current_pnc_junction->start_s
73 << "] distance_adc_to_pnc_junction[" << distance_adc_to_pnc_junction
74 << "]";
75 if (distance_adc_to_pnc_junction < -kPassStopLineBuffer) {
76 // passed stop line
77 return FinishStage(frame);
78 }
79
80 // set cruise_speed to slow down
81 frame->mutable_reference_line_info()->front().LimitCruiseSpeed(
82 scenario_config_.approach_cruise_speed());
83
84 // set right_of_way_status
85 reference_line_info.SetJunctionRightOfWay(current_pnc_junction->start_s,
86 false);
87
88 result = ExecuteTaskOnReferenceLine(planning_init_point, frame);
89 if (result.HasError()) {
90 AERROR << "BareIntersectionUnprotectedStageApproach planning error";
91 }
92
93 std::vector<std::string> wait_for_obstacle_ids;
94 bool clear = CheckClear(reference_line_info, &wait_for_obstacle_ids);
95
96 if (scenario_config_.enable_explicit_stop()) {
97 bool stop = false;
98 static constexpr double kCheckClearDistance = 5.0; // meter
99 static constexpr double kStartWatchDistance = 2.0; // meter
100 if (distance_adc_to_pnc_junction <= kCheckClearDistance &&
101 distance_adc_to_pnc_junction >= kStartWatchDistance && !clear) {
102 stop = true;
103 } else if (distance_adc_to_pnc_junction < kStartWatchDistance) {
104 // creeping area
105 counter_ = clear ? counter_ + 1 : 0;
106
107 if (counter_ >= 5) {
108 counter_ = 0; // reset
109 } else {
110 stop = true;
111 }
112 }
113
114 if (stop) {
115 // build stop decision
116 ADEBUG << "BuildStopDecision: bare pnc_junction["
117 << pnc_junction_overlap_id << "] start_s["
118 << current_pnc_junction->start_s << "]";
119 const std::string virtual_obstacle_id =
120 "PNC_JUNCTION_" + current_pnc_junction->object_id;
122 virtual_obstacle_id, current_pnc_junction->start_s,
123 scenario_config_.stop_distance(),
124 StopReasonCode::STOP_REASON_STOP_SIGN, wait_for_obstacle_ids,
125 "bare intersection", frame,
126 &(frame->mutable_reference_line_info()->front()));
127 }
128 }
129
130 return result.SetStageStatus(StageStatusType::RUNNING);
131}
bool CheckClear(const ReferenceLineInfo &reference_line_info, std::vector< std::string > *wait_for_obstacle_ids)
virtual StageResult FinishScenario()
Definition stage.cc:258
StageResult ExecuteTaskOnReferenceLine(const common::TrajectoryPoint &planning_start_point, Frame *frame)
Definition stage.cc:101
#define AERROR
Definition log.h:44
int BuildStopDecision(const std::string &stop_wall_id, const double stop_line_s, const double stop_distance, const StopReasonCode &stop_reason_code, const std::vector< std::string > &wait_for_obstacles, const std::string &decision_tag, Frame *const frame, ReferenceLineInfo *const reference_line_info, double stop_wall_width)
Definition common.cc:28

该类的文档由以下文件生成: