Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Pinoxchio
apollo
提交
8fa6345e
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,发现更多精彩内容 >>
提交
8fa6345e
编写于
9月 28, 2017
作者:
L
Liangliang Zhang
提交者:
Dong Li
9月 28, 2017
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Planning: added test in piecewise_linear_constraint_test -- AddSecondDerivativeBoundary. (#474)
上级
2f6c2e78
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
57 addition
and
1 deletion
+57
-1
modules/planning/math/smoothing_spline/piecewise_linear_constraint.cc
...ning/math/smoothing_spline/piecewise_linear_constraint.cc
+1
-1
modules/planning/math/smoothing_spline/piecewise_linear_constraint_test.cc
...math/smoothing_spline/piecewise_linear_constraint_test.cc
+56
-0
未找到文件。
modules/planning/math/smoothing_spline/piecewise_linear_constraint.cc
浏览文件 @
8fa6345e
...
...
@@ -169,7 +169,7 @@ bool PiecewiseLinearConstraint::AddSecondDerivativeBoundary(
inequality_matrix
(
2
*
i
,
1
)
=
-
1.0
;
inequality_boundary
(
2
*
i
,
0
)
=
-
upper
*
unit_segment_
*
unit_segment_
;
inequality_matrix
(
2
*
i
+
1
,
0
)
=
2.0
;
inequality_matrix
(
2
*
i
+
1
,
0
)
=
-
2.0
;
inequality_matrix
(
2
*
i
+
1
,
1
)
=
1.0
;
inequality_boundary
(
2
*
i
+
1
,
0
)
=
lower
*
unit_segment_
*
unit_segment_
;
}
else
{
...
...
modules/planning/math/smoothing_spline/piecewise_linear_constraint_test.cc
浏览文件 @
8fa6345e
...
...
@@ -154,5 +154,61 @@ TEST(TestPiecewiseLinearConstraint, add_derivative_boundary) {
EXPECT_EQ
(
bd
,
bd_golden
);
}
TEST
(
TestPiecewiseLinearConstraint
,
add_second_derivative_boundary
)
{
PiecewiseLinearConstraint
constraint
(
10
,
0.1
);
std
::
vector
<
uint32_t
>
index_list
;
std
::
vector
<
double
>
lower_bound
;
std
::
vector
<
double
>
upper_bound
;
for
(
uint32_t
i
=
0
;
i
<
10
;
++
i
)
{
index_list
.
push_back
(
i
);
lower_bound
.
push_back
(
-
4.0
);
upper_bound
.
push_back
(
2.0
);
}
const
double
init_derivative
=
0.1
;
constraint
.
AddSecondDerivativeBoundary
(
init_derivative
,
index_list
,
lower_bound
,
upper_bound
);
const
auto
mat
=
constraint
.
inequality_constraint_matrix
();
const
auto
bd
=
constraint
.
inequality_constraint_boundary
();
std
::
cout
<<
mat
<<
std
::
endl
;
std
::
cout
<<
bd
<<
std
::
endl
;
MatrixXd
mat_golden
(
20
,
10
);
// clang-format off
mat_golden
<<
-
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
2
,
-
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
-
2
,
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
-
1
,
2
,
-
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
-
2
,
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
-
1
,
2
,
-
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
-
2
,
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
-
1
,
2
,
-
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
-
2
,
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
-
1
,
2
,
-
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
-
2
,
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
-
1
,
2
,
-
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
-
2
,
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
-
1
,
2
,
-
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
-
2
,
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
-
1
,
2
,
-
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
-
2
,
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
-
1
,
2
,
-
1
,
0
,
0
,
0
,
0
,
0
,
0
,
0
,
1
,
-
2
,
1
;
// clang-format on
EXPECT_EQ
(
mat
,
mat_golden
);
MatrixXd
bd_golden
(
20
,
1
);
bd_golden
<<
-
0.03
,
-
0.03
,
-
0.02
,
-
0.04
,
-
0.02
,
-
0.04
,
-
0.02
,
-
0.04
,
-
0.02
,
-
0.04
,
-
0.02
,
-
0.04
,
-
0.02
,
-
0.04
,
-
0.02
,
-
0.04
,
-
0.02
,
-
0.04
,
-
0.02
,
-
0.04
;
EXPECT_EQ
(
bd
.
rows
(),
20
);
EXPECT_EQ
(
bd
.
cols
(),
1
);
for
(
uint32_t
i
=
0
;
i
<
bd
.
rows
();
++
i
)
{
EXPECT_DOUBLE_EQ
(
bd
(
i
,
0
),
bd_golden
(
i
,
0
));
}
}
}
// namespace planning
}
// namespace apollo
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录