Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
80d3a06f
MegEngine
项目概览
MegEngine 天元
/
MegEngine
1 年多 前同步成功
通知
411
Star
4707
Fork
583
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
MegEngine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
80d3a06f
编写于
3月 27, 2020
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(mge/param_pack): fix param pack with just one param
GitOrigin-RevId: 0d28a12e594c43e42a7486857dace201da2a3dfc
上级
876e799e
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
37 addition
and
1 deletion
+37
-1
python_module/megengine/module/parampack.py
python_module/megengine/module/parampack.py
+1
-1
python_module/test/integration/test_parampack.py
python_module/test/integration/test_parampack.py
+36
-0
未找到文件。
python_module/megengine/module/parampack.py
浏览文件 @
80d3a06f
...
...
@@ -82,7 +82,7 @@ class ParamPack(Module):
group
=
group
[
idx
:]
if
idx
==
1
:
# ignore param packs with only one item
self
.
_packed_params
.
append
(
params
[
0
])
self
.
_packed_params
.
append
(
params
[
0
]
[
'tensor'
]
)
self
.
_grouped_params
.
append
(
params
)
continue
...
...
python_module/test/integration/test_parampack.py
浏览文件 @
80d3a06f
...
...
@@ -110,6 +110,42 @@ def test_static_graph_parampack():
pred
=
infer
(
data
).
numpy
()
assert
calculate_precision
(
data
,
pred
)
>
0.95
,
"Test precision must be high enough"
@
pytest
.
mark
.
slow
def
test_nopack_parampack
():
net
=
XORNet
()
net
=
ParamPack
(
net
,
max_size_per_group
=
0
,
max_nr_params_per_group
=
0
)
opt
=
SGD
(
net
.
parameters
(
requires_grad
=
True
),
lr
=
0.01
,
momentum
=
0.9
,
weight_decay
=
5e-4
)
@
trace
(
symbolic
=
True
)
def
train
(
data
,
label
):
pred
=
net
(
data
)
opt
.
zero_grad
()
loss
=
cross_entropy_with_softmax
(
pred
,
label
)
opt
.
backward
(
loss
)
return
loss
@
trace
(
symbolic
=
True
)
def
infer
(
data
):
return
net
(
data
)
train_dataset
=
minibatch_generator
()
losses
=
[]
for
data
,
label
in
itertools
.
islice
(
train_dataset
,
2000
):
loss
=
train
(
data
,
label
)
loss
=
loss
[
0
][
0
]
opt
.
step
()
losses
.
append
(
loss
.
numpy
())
assert
np
.
mean
(
losses
[
-
100
:])
<
0.1
,
"Final training Loss must be low enough"
data
,
_
=
next
(
train_dataset
)
pred
=
infer
(
data
).
numpy
()
assert
calculate_precision
(
data
,
pred
)
>
0.95
,
"Test precision must be high enough"
@
pytest
.
mark
.
slow
def
test_dynamic_graph_parampack
():
net
=
XORNet
()
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录