Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Pinoxchio
apollo
提交
9a9b996e
A
apollo
项目概览
Pinoxchio
/
apollo
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
A
apollo
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
9a9b996e
编写于
3月 11, 2019
作者:
H
Hongyi
提交者:
Yajia Zhang
3月 11, 2019
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Prediction: look ahead lane sequence start from ego_vehicle
上级
7f874a24
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
41 addition
and
1 deletion
+41
-1
modules/prediction/scenario/prioritization/obstacles_prioritizer.cc
...ediction/scenario/prioritization/obstacles_prioritizer.cc
+41
-1
未找到文件。
modules/prediction/scenario/prioritization/obstacles_prioritizer.cc
浏览文件 @
9a9b996e
...
...
@@ -337,13 +337,53 @@ void ObstaclesPrioritizer::AssignCautionLevelByEgoReferenceLine() {
ADCTrajectoryContainer
*
adc_trajectory_container
=
ContainerManager
::
Instance
()
->
GetContainer
<
ADCTrajectoryContainer
>
(
AdapterConfig
::
PLANNING_TRAJECTORY
);
if
(
adc_trajectory_container
==
nullptr
)
{
AERROR
<<
"adc_trajectory_container is nullptr"
;
return
;
}
const
std
::
vector
<
std
::
string
>&
lane_ids
=
adc_trajectory_container
->
GetADCLaneIDSequence
();
if
(
lane_ids
.
empty
())
{
return
;
}
auto
pose_container
=
ContainerManager
::
Instance
()
->
GetContainer
<
PoseContainer
>
(
AdapterConfig
::
LOCALIZATION
);
if
(
pose_container
==
nullptr
)
{
AERROR
<<
"Pose container pointer is a null pointer."
;
return
;
}
const
PerceptionObstacle
*
pose_obstacle_ptr
=
pose_container
->
ToPerceptionObstacle
();
if
(
pose_obstacle_ptr
==
nullptr
)
{
AERROR
<<
"Pose obstacle pointer is a null pointer."
;
return
;
}
double
pose_x
=
pose_obstacle_ptr
->
position
().
x
();
double
pose_y
=
pose_obstacle_ptr
->
position
().
y
();
double
ego_vehicle_s
=
std
::
numeric_limits
<
double
>::
max
();
double
ego_vehicle_l
=
std
::
numeric_limits
<
double
>::
max
();
double
accumulated_s
=
0.0
;
// first loop of lane_ids to findout ego_vehicle_s
for
(
const
std
::
string
&
lane_id
:
lane_ids
)
{
std
::
shared_ptr
<
const
LaneInfo
>
lane_info_ptr
=
PredictionMap
::
LaneById
(
lane_id
);
if
(
lane_info_ptr
==
nullptr
)
{
AERROR
<<
"Null lane info pointer found."
;
continue
;
}
double
s
,
l
;
PredictionMap
::
GetProjection
({
pose_x
,
pose_y
},
lane_info_ptr
,
&
s
,
&
l
);
if
(
l
<
ego_vehicle_l
)
{
ego_vehicle_s
=
accumulated_s
+
s
;
ego_vehicle_l
=
l
;
}
accumulated_s
+=
lane_info_ptr
->
total_length
();
}
// then loop of lane_ids to AssignCaution
accumulated_s
=
0.0
;
for
(
const
std
::
string
&
lane_id
:
lane_ids
)
{
std
::
shared_ptr
<
const
LaneInfo
>
lane_info_ptr
=
PredictionMap
::
LaneById
(
lane_id
);
...
...
@@ -354,7 +394,7 @@ void ObstaclesPrioritizer::AssignCautionLevelByEgoReferenceLine() {
accumulated_s
+=
lane_info_ptr
->
total_length
();
AssignCautionByMerge
(
lane_info_ptr
);
AssignCautionByOverlap
(
lane_info_ptr
);
if
(
accumulated_s
>
FLAGS_caution_search_distance_ahead
)
{
if
(
accumulated_s
>
FLAGS_caution_search_distance_ahead
+
ego_vehicle_s
)
{
break
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录