Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Pinoxchio
apollo
提交
3b14c9a3
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,体验更适合开发者的 AI 搜索 >>
提交
3b14c9a3
编写于
3月 12, 2020
作者:
S
sjiang2018
提交者:
Qi Luo
3月 16, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
routing: code clean.
上级
7b1b10d6
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
36 addition
and
43 deletion
+36
-43
modules/routing/routing.cc
modules/routing/routing.cc
+32
-41
modules/routing/routing.h
modules/routing/routing.h
+4
-2
未找到文件。
modules/routing/routing.cc
浏览文件 @
3b14c9a3
...
...
@@ -147,17 +147,45 @@ double Routing::GetRoutingLength(const RoutingResponse& routing_response) {
}
bool
Routing
::
GetParkingID
(
const
PointENU
&
parking_point
,
std
::
string
&
parking_space_id
)
{
std
::
string
*
parking_space_id
)
{
// search current parking space id associated with parking point.
constexpr
double
kDistance
=
0.01
;
// meter
std
::
vector
<
ParkingSpaceInfoConstPtr
>
parking_spaces
;
if
(
!
hdmap_
->
GetParkingSpaces
(
parking_point
,
kDistance
,
&
parking_spaces
))
{
parking_space_id
=
parking_spaces
.
front
()
->
id
().
id
();
if
(
hdmap_
->
GetParkingSpaces
(
parking_point
,
kDistance
,
&
parking_spaces
)
==
0
)
{
*
parking_space_id
=
parking_spaces
.
front
()
->
id
().
id
();
return
true
;
}
return
false
;
}
bool
Routing
::
FillParkingID
(
RoutingResponse
*
routing_response
)
{
const
auto
&
routing_request
=
routing_response
->
routing_request
();
const
bool
has_parking_info
=
routing_request
.
has_parking_info
();
const
bool
has_parking_id
=
has_parking_info
&&
routing_request
.
parking_info
().
has_parking_space_id
();
// return early when has parking_id
if
(
has_parking_id
)
{
return
true
;
}
// set parking space ID when
// has parking info && has parking point && NOT has parking space id && get
// ID successfully
if
(
has_parking_info
&&
routing_request
.
parking_info
().
has_parking_point
())
{
const
PointENU
parking_point
=
routing_request
.
parking_info
().
parking_point
();
std
::
string
parking_space_id
;
if
(
GetParkingID
(
parking_point
,
&
parking_space_id
))
{
routing_response
->
mutable_routing_request
()
->
mutable_parking_info
()
->
set_parking_space_id
(
parking_space_id
);
return
true
;
}
}
ADEBUG
<<
"Failed to fill parking ID"
;
return
false
;
}
bool
Routing
::
Process
(
const
std
::
shared_ptr
<
RoutingRequest
>&
routing_request
,
RoutingResponse
*
const
routing_response
)
{
CHECK_NOTNULL
(
routing_response
);
...
...
@@ -174,44 +202,7 @@ bool Routing::Process(const std::shared_ptr<RoutingRequest>& routing_request,
min_routing_length
=
routing_length
;
}
}
// set parking space ID when
// has parking info && has parking point && NOT has parking space id && get
// ID successfully
// if (routing_response->routing_request().has_parking_info() &&
// routing_response->routing_request()
// .parking_info()
// .has_parking_point() &&
// (!routing_response->routing_request()
// .parking_info()
// .has_parking_space_id())) {
// const PointENU parking_point =
// routing_response->routing_request().parking_info().parking_point();
// std::string parking_space_id;
// if (GetParkingID(parking_point, parking_space_id)) {
// routing_response->mutable_routing_request()
// ->mutable_parking_info()
// ->set_parking_space_id(parking_space_id);
// }
// }
const
auto
&
routing_request
=
routing_response
->
routing_request
();
const
bool
has_parking_info
=
routing_request
.
has_parking_info
();
const
bool
has_parking_point
=
has_parking_info
&&
routing_request
.
parking_info
().
has_parking_point
();
const
bool
has_parking_id
=
has_parking_info
&&
routing_request
.
parking_info
().
has_parking_space_id
();
const
PointENU
parking_point
=
has_parking_point
?
routing_request
.
parking_info
().
parking_point
()
:
PointENU
();
std
::
string
parking_space_id
;
const
bool
ret_get_parking_id
=
GetParkingID
(
parking_point
,
parking_space_id
);
if
(
has_parking_info
&&
has_parking_point
&&
!
has_parking_id
&&
ret_get_parking_id
)
{
routing_response
->
mutable_routing_request
()
->
mutable_parking_info
()
->
set_parking_space_id
(
parking_space_id
);
}
FillParkingID
(
routing_response
);
}
if
(
min_routing_length
<
std
::
numeric_limits
<
double
>::
max
())
{
monitor_logger_buffer_
.
INFO
(
"Routing success!"
);
...
...
modules/routing/routing.h
浏览文件 @
3b14c9a3
...
...
@@ -63,10 +63,12 @@ class Routing {
std
::
vector
<
RoutingRequest
>
FillLaneInfoIfMissing
(
const
RoutingRequest
&
routing_request
);
double
GetRoutingLength
(
const
RoutingResponse
&
routing_response
);
bool
GetParkingID
(
const
apollo
::
common
::
PointENU
&
parking_point
,
std
::
string
&
parking_space_id
);
std
::
string
*
parking_space_id
);
double
GetRoutingLength
(
const
RoutingResponse
&
routing_response
);
bool
FillParkingID
(
RoutingResponse
*
routing_response
);
private:
std
::
unique_ptr
<
Navigator
>
navigator_ptr_
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录