Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleClas
提交
2cb3bf66
P
PaddleClas
项目概览
PaddlePaddle
/
PaddleClas
大约 1 年 前同步成功
通知
115
Star
4999
Fork
1114
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
19
列表
看板
标记
里程碑
合并请求
6
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleClas
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
19
Issue
19
列表
看板
标记
里程碑
合并请求
6
合并请求
6
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
2cb3bf66
编写于
8月 08, 2021
作者:
W
weishengyu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update wrap theseus rule
上级
19850755
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
32 addition
and
23 deletion
+32
-23
ppcls/arch/backbone/base/theseus_layer.py
ppcls/arch/backbone/base/theseus_layer.py
+32
-23
未找到文件。
ppcls/arch/backbone/base/theseus_layer.py
浏览文件 @
2cb3bf66
...
@@ -33,21 +33,24 @@ class TheseusLayer(nn.Layer):
...
@@ -33,21 +33,24 @@ class TheseusLayer(nn.Layer):
return
after_stop
return
after_stop
def
update_res
(
self
,
return_patterns
):
def
update_res
(
self
,
return_patterns
):
if
not
return_patterns
:
if
not
return_patterns
or
isinstance
(
self
,
WrapLayer
)
:
return
return
for
layer_i
in
self
.
_sub_layers
:
for
layer_i
in
self
.
_sub_layers
:
if
isinstance
(
self
.
_sub_layers
[
layer_i
],
(
nn
.
Sequential
,
nn
.
LayerList
)):
self
.
_sub_layers
[
layer_i
]
=
wrap_theseus
(
self
.
_sub_layers
[
layer_i
],
return_patterns
)
layer_name
=
self
.
_sub_layers
[
layer_i
].
full_name
()
layer_name
=
self
.
_sub_layers
[
layer_i
].
full_name
()
for
return_pattern
in
return_patterns
:
if
isinstance
(
self
.
_sub_layers
[
layer_i
],
(
nn
.
Sequential
,
nn
.
LayerList
)):
if
re
.
match
(
return_pattern
,
layer_name
):
self
.
_sub_layers
[
layer_i
]
=
wrap_theseus
(
self
.
_sub_layers
[
layer_i
])
if
not
isinstance
(
self
.
_sub_layers
[
layer_i
],
TheseusLayer
)
and
not
isinstance
(
self
,
WrapLayer
):
self
.
_sub_layers
[
layer_i
].
res_dict
=
self
.
res_dict
self
.
_sub_layers
[
layer_i
]
=
wrap_theseus
(
self
.
_sub_layers
[
layer_i
],
return_patterns
)
self
.
_sub_layers
[
layer_i
].
register_forward_post_hook
(
self
.
_sub_layers
[
layer_i
].
_save_sub_res_hook
)
self
.
_sub_layers
[
layer_i
].
res_dict
=
self
.
res_dict
if
isinstance
(
self
.
_sub_layers
[
layer_i
],
TheseusLayer
):
self
.
_sub_layers
[
layer_i
].
update_res
(
return_patterns
)
self
.
_sub_layers
[
layer_i
].
update_res
(
return_patterns
)
else
:
for
return_pattern
in
return_patterns
:
if
re
.
match
(
return_pattern
,
layer_name
):
if
not
isinstance
(
self
.
_sub_layers
[
layer_i
],
TheseusLayer
):
self
.
_sub_layers
[
layer_i
]
=
wrap_theseus
(
self
.
_sub_layers
[
layer_i
])
self
.
_sub_layers
[
layer_i
].
register_forward_post_hook
(
self
.
_sub_layers
[
layer_i
].
_save_sub_res_hook
)
self
.
_sub_layers
[
layer_i
].
res_dict
=
self
.
res_dict
if
isinstance
(
self
.
_sub_layers
[
layer_i
],
TheseusLayer
):
self
.
_sub_layers
[
layer_i
].
update_res
(
return_patterns
)
def
_save_sub_res_hook
(
self
,
layer
,
input
,
output
):
def
_save_sub_res_hook
(
self
,
layer
,
input
,
output
):
if
self
.
res_dict
is
not
None
:
if
self
.
res_dict
is
not
None
:
...
@@ -93,18 +96,24 @@ class WrapLayer(TheseusLayer):
...
@@ -93,18 +96,24 @@ class WrapLayer(TheseusLayer):
def
forward
(
self
,
*
inputs
,
**
kwargs
):
def
forward
(
self
,
*
inputs
,
**
kwargs
):
self
.
sub_layer
(
*
inputs
,
**
kwargs
)
self
.
sub_layer
(
*
inputs
,
**
kwargs
)
def
update_res
(
self
,
return_patterns
):
if
not
return_patterns
or
not
isinstance
(
self
.
sub_layer
,
(
nn
.
Sequential
,
nn
.
LayerList
)):
return
for
layer_i
in
self
.
sub_layer
.
_sub_layers
:
if
isinstance
(
self
.
sub_layer
.
_sub_layers
[
layer_i
],
(
nn
.
Sequential
,
nn
.
LayerList
)):
self
.
sub_layer
.
_sub_layers
[
layer_i
]
=
wrap_theseus
(
self
.
sub_layer
.
_sub_layers
[
layer_i
])
self
.
sub_layer
.
_sub_layers
[
layer_i
].
res_dict
=
self
.
res_dict
self
.
sub_layer
.
_sub_layers
[
layer_i
].
update_res
(
return_patterns
)
layer_name
=
self
.
sub_layer
.
_sub_layers
[
layer_i
].
full_name
()
for
return_pattern
in
return_patterns
:
if
re
.
match
(
return_pattern
,
layer_name
):
self
.
sub_layer
.
_sub_layers
[
layer_i
].
res_dict
=
self
.
res_dict
def
wrap_theseus
(
sub_layer
,
return_patterns
):
if
isinstance
(
self
.
sub_layer
.
_sub_layers
[
layer_i
],
TheseusLayer
):
if
isinstance
(
sub_layer
,
(
nn
.
Sequential
,
nn
.
LayerList
)):
self
.
sub_layer
.
_sub_layers
[
layer_i
].
update_res
(
return_patterns
)
for
layer_i
in
sub_layer
.
_sub_layers
:
if
isinstance
(
sub_layer
.
_sub_layers
[
layer_i
],
TheseusLayer
):
continue
def
wrap_theseus
(
sub_layer
):
elif
isinstance
(
sub_layer
.
_sub_layers
[
layer_i
],
(
nn
.
Sequential
,
nn
.
LayerList
)):
wrap_theseus
(
sub_layer
.
_sub_layers
[
layer_i
],
return_patterns
)
elif
isinstance
(
sub_layer
.
_sub_layers
[
layer_i
],
nn
.
Layer
):
layer_name
=
sub_layer
.
_sub_layers
[
layer_i
].
full_name
()
for
return_pattern
in
return_patterns
:
if
re
.
match
(
return_pattern
,
layer_name
):
wrap_theseus
(
sub_layer
.
_sub_layers
[
layer_i
],
return_patterns
)
wrapped_layer
=
WrapLayer
(
sub_layer
)
wrapped_layer
=
WrapLayer
(
sub_layer
)
return
wrapped_layer
return
wrapped_layer
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录