Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
MegEngine 天元
MegEngine
提交
f077a529
MegEngine
项目概览
MegEngine 天元
/
MegEngine
1 年多 前同步成功
通知
404
Star
4705
Fork
582
代码
文件
提交
分支
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看板
提交
f077a529
编写于
4月 03, 2020
作者:
M
Megvii Engine Team
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix(mge/param_pack): release old parameters
GitOrigin-RevId: 40a1f044e9fb43147b4369049167e19196de0047
上级
48822557
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
13 addition
and
5 deletion
+13
-5
python_module/megengine/core/tensor_nn.py
python_module/megengine/core/tensor_nn.py
+5
-1
python_module/megengine/module/parampack.py
python_module/megengine/module/parampack.py
+8
-4
未找到文件。
python_module/megengine/core/tensor_nn.py
浏览文件 @
f077a529
...
...
@@ -35,4 +35,8 @@ class Parameter(Tensor):
def
shape
(
self
):
r
"""Return shape of parameter.
"""
return
self
.
_symvar
.
imm_shape
if
self
.
_Tensor__val
is
not
None
:
return
self
.
_Tensor__val
.
shape
elif
self
.
_Tensor__sym
is
not
None
:
return
self
.
_Tensor__sym
.
imm_shape
return
None
python_module/megengine/module/parampack.py
浏览文件 @
f077a529
...
...
@@ -56,7 +56,7 @@ class ParamPack(Module):
for
param
in
params
:
if
self
.
_nr_ignore_first
>
ignored
:
ignored
+=
1
self
.
_grouped_params
.
append
([{
"
tensor"
:
param
,
"id"
:
param_id
}])
self
.
_grouped_params
.
append
([{
"
shape"
:
param
.
shape
,
"id"
:
param_id
}])
self
.
_packed_params
.
append
(
param
)
else
:
key
=
(
param
.
dtype
,
param
.
device
,
param
.
requires_grad
)
...
...
@@ -96,7 +96,9 @@ class ParamPack(Module):
if
idx
==
1
:
# ignore param packs with only one item
self
.
_packed_params
.
append
(
params
[
0
][
"tensor"
])
self
.
_grouped_params
.
append
(
params
)
self
.
_grouped_params
.
append
(
[{
"shape"
:
params
[
0
][
"tensor"
].
shape
,
"id"
:
params
[
0
][
"id"
]}]
)
continue
packed_value
=
np
.
zeros
((
offset
,),
dtype
=
dtype
)
...
...
@@ -110,7 +112,9 @@ class ParamPack(Module):
requires_grad
=
requires_grad
,
)
self
.
_packed_params
.
append
(
new_param
)
self
.
_grouped_params
.
append
(
params
)
self
.
_grouped_params
.
append
(
[{
"shape"
:
i
[
"tensor"
].
shape
,
"id"
:
i
[
"id"
]}
for
i
in
params
]
)
def
forward
(
self
,
*
args
,
**
kwargs
):
replace_param
=
dict
()
...
...
@@ -120,7 +124,7 @@ class ParamPack(Module):
if
len
(
grouped_params
)
==
1
:
continue
split
=
param_pack_split
(
packed_param
.
_symvar
,
[
i
[
"
tensor"
].
shape
for
i
in
grouped_params
]
packed_param
.
_symvar
,
[
i
[
"
shape"
]
for
i
in
grouped_params
]
)
split
=
[
Parameter
(
Tensor
(
i
,
requires_grad
=
packed_param
.
requires_grad
))
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录