Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
X2Paddle
提交
d2340215
X
X2Paddle
项目概览
PaddlePaddle
/
X2Paddle
接近 2 年 前同步成功
通知
329
Star
698
Fork
167
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
26
列表
看板
标记
里程碑
合并请求
4
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
X
X2Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
26
Issue
26
列表
看板
标记
里程碑
合并请求
4
合并请求
4
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
d2340215
编写于
8月 04, 2019
作者:
J
jiangjiajun
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add optimizer for tf2fluid
上级
fef5149c
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
147 addition
and
55 deletion
+147
-55
x2paddle/convert.py
x2paddle/convert.py
+7
-0
x2paddle/core/graph.py
x2paddle/core/graph.py
+0
-23
x2paddle/core/op_mapper.py
x2paddle/core/op_mapper.py
+2
-2
x2paddle/decoder/tf_decoder.py
x2paddle/decoder/tf_decoder.py
+47
-13
x2paddle/op_mapper/tf_op_mapper.py
x2paddle/op_mapper/tf_op_mapper.py
+2
-13
x2paddle/optimizer/tf_optimizer.py
x2paddle/optimizer/tf_optimizer.py
+89
-4
未找到文件。
x2paddle/convert.py
浏览文件 @
d2340215
...
@@ -67,10 +67,17 @@ def tf2paddle(model_path, save_dir):
...
@@ -67,10 +67,17 @@ def tf2paddle(model_path, save_dir):
from
x2paddle.decoder.tf_decoder
import
TFDecoder
from
x2paddle.decoder.tf_decoder
import
TFDecoder
from
x2paddle.op_mapper.tf_op_mapper
import
TFOpMapper
from
x2paddle.op_mapper.tf_op_mapper
import
TFOpMapper
from
x2paddle.optimizer.tf_optimizer
import
TFOptimizer
print
(
"Now translating model from tensorflow to paddle."
)
print
(
"Now translating model from tensorflow to paddle."
)
model
=
TFDecoder
(
model_path
)
model
=
TFDecoder
(
model_path
)
mapper
=
TFOpMapper
(
model
)
mapper
=
TFOpMapper
(
model
)
optimizer
=
TFOptimizer
(
mapper
)
# neccesary optimization
optimizer
.
delete_redundance_code
()
# optimizer below is experimental
optimizer
.
merge_activation
()
optimizer
.
merge_bias
()
mapper
.
save_inference_model
(
save_dir
)
mapper
.
save_inference_model
(
save_dir
)
...
...
x2paddle/core/graph.py
浏览文件 @
d2340215
...
@@ -97,29 +97,6 @@ class Graph(object):
...
@@ -97,29 +97,6 @@ class Graph(object):
self
.
node_map
[
dst
].
inputs
.
append
(
src
)
self
.
node_map
[
dst
].
inputs
.
append
(
src
)
self
.
node_map
[
src
].
outputs
.
append
(
dst
)
self
.
node_map
[
src
].
outputs
.
append
(
dst
)
def
remove_node
(
self
,
node_name
):
if
node_name
not
in
self
.
node_map
:
raise
Exception
(
"Node[{}] not in graph"
.
format
(
node_name
))
inputs
=
self
.
node_map
[
node_name
].
inputs
outputs
=
self
.
node_map
[
node_name
].
outputs
for
input
in
inputs
:
idx
=
self
.
node_map
[
input
].
outputs
.
index
(
node_name
)
del
self
.
node_map
[
input
].
outputs
[
idx
]
for
output
in
outputs
:
idx
=
self
.
node_map
[
input
].
inputs
.
index
(
node_name
)
del
self
.
node_map
[
input
].
inputs
[
idx
]
del
self
.
node_map
[
node_name
]
idx
=
self
.
topo_sort
.
index
(
node_name
)
del
self
.
topo_sort
[
idx
]
if
node_name
in
self
.
input_nodes
:
idx
=
self
.
input_nodes
.
index
(
node_name
)
del
self
.
input_nodes
[
idx
]
if
node_name
in
self
.
output_nodes
:
idx
=
self
.
output_nodes
.
index
(
node_name
)
del
self
.
output_nodes
[
idx
]
def
print
(
self
):
def
print
(
self
):
for
i
,
tmp
in
enumerate
(
self
.
topo_sort
):
for
i
,
tmp
in
enumerate
(
self
.
topo_sort
):
print
(
tmp
,
self
.
node_map
[
tmp
].
layer_type
,
self
.
node_map
[
tmp
].
inputs
,
print
(
tmp
,
self
.
node_map
[
tmp
].
layer_type
,
self
.
node_map
[
tmp
].
inputs
,
...
...
x2paddle/core/op_mapper.py
浏览文件 @
d2340215
...
@@ -142,9 +142,9 @@ class OpMapper(object):
...
@@ -142,9 +142,9 @@ class OpMapper(object):
self
.
add_codes
(
"
\n
def x2paddle_net():"
,
0
)
self
.
add_codes
(
"
\n
def x2paddle_net():"
,
0
)
for
i
in
range
(
len
(
self
.
graph
.
topo_sort
)):
for
i
in
range
(
len
(
self
.
graph
.
topo_sort
)):
node_name
=
self
.
graph
.
topo_sort
[
i
]
node_name
=
self
.
graph
.
topo_sort
[
i
]
if
hasattr
(
self
,
"omit_nodes"
)
and
node_name
in
self
.
omit_nodes
:
continue
node
=
self
.
graph
.
get_node
(
node_name
)
node
=
self
.
graph
.
get_node
(
node_name
)
if
len
(
node
.
fluid_code
.
layers
)
==
0
:
continue
self
.
add_codes
(
node
.
fluid_code
.
gen_codes
(),
1
)
self
.
add_codes
(
node
.
fluid_code
.
gen_codes
(),
1
)
self
.
add_codes
(
""
,
0
)
self
.
add_codes
(
""
,
0
)
...
...
x2paddle/decoder/tf_decoder.py
浏览文件 @
d2340215
...
@@ -129,6 +129,26 @@ class TFGraph(Graph):
...
@@ -129,6 +129,26 @@ class TFGraph(Graph):
node
.
index
=
0
node
.
index
=
0
return
node
return
node
def
remove_node
(
self
,
node_name
):
if
node_name
not
in
self
.
node_map
:
raise
Exception
(
"Node[{}] not in graph"
.
format
(
node_name
))
inputs
=
self
.
node_map
[
node_name
].
inputs
outputs
=
self
.
node_map
[
node_name
].
outputs
assert
len
(
inputs
)
==
1
input_node
=
self
.
node_map
[
inputs
[
0
]]
idx
=
input_node
.
outputs
.
index
(
node_name
)
del
input_node
.
outputs
[
idx
]
for
output
in
outputs
:
node
=
self
.
node_map
[
output
]
idx
=
node
.
inputs
.
index
(
node_name
)
node
.
inputs
[
idx
]
=
inputs
[
0
]
input_node
.
outputs
.
append
(
output
)
del
self
.
node_map
[
node_name
]
idx
=
self
.
topo_sort
.
index
(
node_name
)
del
self
.
topo_sort
[
idx
]
def
_remove_isolated_node
(
self
):
def
_remove_isolated_node
(
self
):
# delete isolated nodes
# delete isolated nodes
isolated_nodes
=
list
()
isolated_nodes
=
list
()
...
@@ -138,7 +158,15 @@ class TFGraph(Graph):
...
@@ -138,7 +158,15 @@ class TFGraph(Graph):
isolated_nodes
.
append
(
node_name
)
isolated_nodes
.
append
(
node_name
)
for
node_name
in
isolated_nodes
:
for
node_name
in
isolated_nodes
:
self
.
remove_node
(
node_name
)
del
self
.
node_map
[
node_name
]
if
node_name
in
self
.
input_nodes
:
idx
=
self
.
input_nodes
.
index
(
node_name
)
del
self
.
input_nodes
[
idx
]
if
node_name
in
self
.
output_nodes
:
idx
=
self
.
output_nodes
.
index
(
node_name
)
del
self
.
output_nodes
[
idx
]
idx
=
self
.
topo_sort
.
index
(
node_name
)
del
self
.
topo_sort
[
idx
]
def
_remove_identity_node
(
self
):
def
_remove_identity_node
(
self
):
identity_node
=
list
()
identity_node
=
list
()
...
@@ -148,22 +176,28 @@ class TFGraph(Graph):
...
@@ -148,22 +176,28 @@ class TFGraph(Graph):
for
node_name
in
identity_node
:
for
node_name
in
identity_node
:
node
=
self
.
get_node
(
node_name
)
node
=
self
.
get_node
(
node_name
)
# Remind: Only 1 input for Identity node
input_node
=
self
.
get_node
(
node
.
inputs
[
0
])
input_node
=
self
.
get_node
(
node
.
inputs
[
0
])
self
.
remove_node
(
node_name
)
# remove identity node from graph
self
.
identity_map
[
node_name
]
=
input_node
.
layer_name
self
.
identity_map
[
node_name
]
=
input_node
.
layer_name
idx
=
input_node
.
outputs
.
index
(
node_name
)
del
input_node
.
outputs
[
idx
]
output_names
=
node
.
outputs
for
output_name
in
output_names
:
output_node
=
self
.
get_node
(
output_name
)
idx
=
output_node
.
inputs
.
index
(
node_name
)
output_node
.
inputs
[
idx
]
=
input_node
.
layer_name
idx
=
self
.
topo_sort
.
index
(
node_name
)
# node = self.get_node(node_name)
del
self
.
topo_sort
[
idx
]
# # Remind: Only 1 input for Identity node
# input_node = self.get_node(node.inputs[0])
#
# # remove identity node from graph
# self.identity_map[node_name] = input_node.layer_name
# idx = input_node.outputs.index(node_name)
# del input_node.outputs[idx]
#
# output_names = node.outputs
# for output_name in output_names:
# output_node = self.get_node(output_name)
# idx = output_node.inputs.index(node_name)
# output_node.inputs[idx] = input_node.layer_name
#
# idx = self.topo_sort.index(node_name)
# del self.topo_sort[idx]
if
node_name
in
self
.
output_nodes
:
if
node_name
in
self
.
output_nodes
:
idx
=
self
.
output_nodes
.
index
(
node_name
)
idx
=
self
.
output_nodes
.
index
(
node_name
)
...
...
x2paddle/op_mapper/tf_op_mapper.py
浏览文件 @
d2340215
...
@@ -55,7 +55,8 @@ class TFOpMapper(OpMapper):
...
@@ -55,7 +55,8 @@ class TFOpMapper(OpMapper):
'Abs'
:
[
'abs'
],
'Abs'
:
[
'abs'
],
'Sigmoid'
:
[
'sigmoid'
],
'Sigmoid'
:
[
'sigmoid'
],
'Exp'
:
[
'exp'
],
'Exp'
:
[
'exp'
],
'Rsqrt'
:
[
'rsqrt'
]
'Rsqrt'
:
[
'rsqrt'
],
'swish_f32'
:
[
'swish'
]
}
}
elementwise_ops
=
{
elementwise_ops
=
{
'Add'
:
'elementwise_add'
,
'Add'
:
'elementwise_add'
,
...
@@ -692,18 +693,6 @@ class TFOpMapper(OpMapper):
...
@@ -692,18 +693,6 @@ class TFOpMapper(OpMapper):
output
=
node
,
output
=
node
,
param_attr
=
None
)
param_attr
=
None
)
def
swish_f32
(
self
,
node
):
input
=
self
.
graph
.
get_node
(
node
.
layer
.
input
[
0
],
copy
=
True
)
node
.
fluid_code
.
add_layer
(
"sigmoid"
,
inputs
=
input
,
output
=
node
,
param_attr
=
None
)
inputs
=
{
"x"
:
input
,
"y"
:
node
}
node
.
fluid_code
.
add_layer
(
"elementwise_mul"
,
inputs
=
inputs
,
output
=
node
,
param_attr
=
None
)
def
Mean
(
self
,
node
):
def
Mean
(
self
,
node
):
input
=
self
.
graph
.
get_node
(
node
.
layer
.
input
[
0
],
copy
=
True
)
input
=
self
.
graph
.
get_node
(
node
.
layer
.
input
[
0
],
copy
=
True
)
reduce_idx
=
self
.
graph
.
get_node
(
node
.
layer
.
input
[
1
],
copy
=
True
)
reduce_idx
=
self
.
graph
.
get_node
(
node
.
layer
.
input
[
1
],
copy
=
True
)
...
...
x2paddle/optimizer/tf_optimizer.py
浏览文件 @
d2340215
...
@@ -13,10 +13,95 @@
...
@@ -13,10 +13,95 @@
# limitations under the License.
# limitations under the License.
# TODO useless node remove
# TODO useless node remove
from
x2paddle.decoder.tf_decoder
import
TFGraph
from
x2paddle.op_mapper.tf_op_mapper
import
TFOpMapper
from
x2paddle.core.util
import
*
# TODO bn merge
# TODO activation merge
class
TFOptimizer
(
object
):
activation_ops
=
{
'Relu'
:
'relu'
,
'Sigmoid'
:
'sigmoid'
,
'Relu6'
:
'relu6'
,
'swish_f32'
:
'swish'
}
layers_with_act
=
[
'Conv2D'
,
'BiasAdd'
,
'DepthwiseConv2dNative'
,
'Conv2DBackpropInput'
,
'FusedBatchNorm'
]
layers_with_bias
=
[
'Conv2D'
,
'DepthwiseConv2dNative'
,
'Conv2DBackpropInput'
]
# TODO biasadd merge
def
__init__
(
self
,
op_mapper
):
self
.
op_mapper
=
op_mapper
self
.
graph
=
op_mapper
.
graph
def
delete_redundance_code
(
self
):
for
node_name
in
self
.
graph
.
topo_sort
:
if
node_name
in
self
.
op_mapper
.
omit_nodes
:
node
=
self
.
graph
.
get_node
(
node_name
)
omit_freq
=
self
.
op_mapper
.
omit_nodes
.
count
(
node_name
)
if
len
(
node
.
outputs
)
<=
omit_freq
:
node
.
fluid_code
.
clear
()
# TODO activation merge
def
merge_activation
(
self
):
act_nodes
=
list
()
for
node_name
in
self
.
graph
.
topo_sort
:
node
=
self
.
graph
.
get_node
(
node_name
)
if
node
.
layer_type
in
self
.
activation_ops
:
act_nodes
.
append
(
node_name
)
for
act_node_name
in
act_nodes
:
node
=
self
.
graph
.
get_node
(
act_node_name
)
input
=
self
.
graph
.
get_node
(
node
.
inputs
[
0
])
if
input
.
layer_type
not
in
self
.
layers_with_act
:
continue
if
len
(
input
.
fluid_code
.
layers
)
==
0
:
continue
if
'act'
in
input
.
fluid_code
.
layers
[
-
1
].
param_attr
and
input
.
fluid_code
.
layers
[
-
1
].
param_attr
[
'act'
]
is
not
None
:
continue
if
len
(
input
.
outputs
)
!=
1
:
continue
input
.
fluid_code
.
layers
[
-
1
].
param_attr
[
'act'
]
=
string
(
self
.
activation_ops
[
node
.
layer_type
])
input
.
fluid_code
.
layers
[
-
1
].
output
=
node
.
fluid_code
.
layers
[
0
].
output
self
.
graph
.
remove_node
(
act_node_name
)
# TODO bias merge
def
merge_bias
(
self
):
for
node_name
in
self
.
graph
.
topo_sort
:
node
=
self
.
graph
.
get_node
(
node_name
)
if
node
.
layer_type
==
"BiasAdd"
:
input
=
self
.
graph
.
get_node
(
node
.
inputs
[
0
])
if
input
.
layer_type
not
in
self
.
layers_with_bias
:
continue
if
len
(
input
.
outputs
)
!=
1
:
continue
if
len
(
input
.
fluid_code
.
layers
)
==
0
:
continue
bias_with_act
=
False
if
'act'
in
node
.
fluid_code
.
layers
[
-
1
].
param_attr
:
bias_with_act
=
True
layer_with_act
=
False
if
'act'
in
input
.
fluid_code
.
layers
[
-
1
].
param_attr
and
input
.
fluid_code
.
layers
[
-
1
].
param_attr
[
'act'
]
is
not
None
:
layer_with_act
=
True
if
bias_with_act
and
layer_with_act
:
continue
if
not
input
.
fluid_code
.
layers
[
-
1
].
param_attr
[
'bias_attr'
]:
bias_name
=
node
.
inputs
[
1
]
input
.
fluid_code
.
layers
[
-
1
].
param_attr
[
'bias_attr'
]
=
string
(
bias_name
)
input
.
fluid_code
.
layers
[
-
1
].
output
=
node
.
fluid_code
.
layers
[
0
].
output
if
bias_with_act
:
input
.
fluid_code
.
layers
[
-
1
].
param_attr
[
'act'
]
=
node
.
fluid_code
.
layers
[
-
1
].
param_attr
[
'act'
]
node
.
fluid_code
.
clear
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录