Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
X2Paddle
提交
de295641
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看板
提交
de295641
编写于
6月 11, 2020
作者:
J
jiangjiajun
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix shufflenet xception and hrnet
上级
d7ab3a27
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
64 addition
and
31 deletion
+64
-31
x2paddle/op_mapper/paddle_op_mapper.py
x2paddle/op_mapper/paddle_op_mapper.py
+64
-31
未找到文件。
x2paddle/op_mapper/paddle_op_mapper.py
浏览文件 @
de295641
...
@@ -13,6 +13,7 @@
...
@@ -13,6 +13,7 @@
# limitations under the License.
# limitations under the License.
import
math
import
math
import
sys
import
x2paddle
import
x2paddle
import
os
import
os
import
numpy
as
np
import
numpy
as
np
...
@@ -261,21 +262,22 @@ class PaddleOpMapper(object):
...
@@ -261,21 +262,22 @@ class PaddleOpMapper(object):
inputs
=
op
.
input
(
'X'
),
inputs
=
op
.
input
(
'X'
),
outputs
=
op
.
output
(
'Out'
),
outputs
=
op
.
output
(
'Out'
),
axis
=
op
.
attr
(
'axis'
))
axis
=
op
.
attr
(
'axis'
))
return
node
def
slice
(
self
,
op
,
block
):
def
slice
(
self
,
op
,
block
):
axes
=
op
.
attr
(
'axes'
)
axes
=
op
.
attr
(
'axes'
)
starts
=
op
.
attr
(
'starts'
)
starts
=
op
.
attr
(
'starts'
)
ends
=
op
.
attr
(
'ends'
)
ends
=
op
.
attr
(
'ends'
)
axes_name
=
get_name
(
op
.
type
,
'axes'
)
axes_name
=
self
.
get_name
(
op
.
type
,
'axes'
)
starts_name
=
get_name
(
op
.
type
,
'starts'
)
starts_name
=
self
.
get_name
(
op
.
type
,
'starts'
)
ends_name
=
get_name
(
op
.
type
,
'ends'
)
ends_name
=
self
.
get_name
(
op
.
type
,
'ends'
)
axes_node
=
make_constant_node
(
axes_name
,
onnx_pb
.
TensorProto
.
INT64
,
axes_node
=
self
.
make_constant_node
(
axes_name
,
axes
)
onnx_pb
.
TensorProto
.
INT64
,
axes
)
starts_node
=
make_constant_node
(
starts_name
,
onnx_pb
.
TensorProto
.
INT64
,
starts_node
=
self
.
make_constant_node
(
starts_name
,
starts
)
onnx_pb
.
TensorProto
.
INT64
,
starts
)
ends_node
=
make_constant_node
(
ends_name
,
onnx_pb
.
TensorProto
.
INT64
,
ends_node
=
self
.
make_constant_node
(
ends_name
,
ends
)
onnx_pb
.
TensorProto
.
INT64
,
ends
)
node
=
helper
.
make_node
(
node
=
helper
.
make_node
(
"Slice"
,
"Slice"
,
inputs
=
[
op
.
input
(
'Input'
)[
0
],
starts_name
,
ends_name
,
axes_name
],
inputs
=
[
op
.
input
(
'Input'
)[
0
],
starts_name
,
ends_name
,
axes_name
],
...
@@ -288,12 +290,14 @@ class PaddleOpMapper(object):
...
@@ -288,12 +290,14 @@ class PaddleOpMapper(object):
dtype
=
op
.
attr
(
'dtype'
)
dtype
=
op
.
attr
(
'dtype'
)
shape
=
op
.
attr
(
'shape'
)
shape
=
op
.
attr
(
'shape'
)
value
=
np
.
ones
(
shape
)
*
value
value
=
np
.
ones
(
shape
)
*
value
if
dtype
==
2
:
value
=
value
.
astype
(
'int32'
)
node
=
helper
.
make_node
(
node
=
helper
.
make_node
(
'Constant'
,
'Constant'
,
inputs
=
[],
inputs
=
[],
outputs
=
op
.
attr
(
'Out'
),
outputs
=
op
.
output
(
'Out'
),
value
=
helper
.
make_tensor
(
value
=
helper
.
make_tensor
(
name
=
op
.
attr
(
'Out'
)
,
name
=
op
.
output
(
'Out'
)[
0
]
,
data_type
=
self
.
paddle_onnx_dtype_map
[
dtype
],
data_type
=
self
.
paddle_onnx_dtype_map
[
dtype
],
dims
=
shape
,
dims
=
shape
,
vals
=
value
.
tolist
()))
vals
=
value
.
tolist
()))
...
@@ -304,28 +308,45 @@ class PaddleOpMapper(object):
...
@@ -304,28 +308,45 @@ class PaddleOpMapper(object):
'Transpose'
,
'Transpose'
,
inputs
=
op
.
input
(
'X'
),
inputs
=
op
.
input
(
'X'
),
outputs
=
op
.
output
(
'Out'
),
outputs
=
op
.
output
(
'Out'
),
perm
=
op
.
attr
(
'
perm
'
))
perm
=
op
.
attr
(
'
axis
'
))
return
node
return
node
def
reshape2
(
self
,
op
,
block
):
def
reshape2
(
self
,
op
,
block
):
input_names
=
op
.
input_names
input_names
=
op
.
input_names
if
'Shape'
in
input_names
and
len
(
op
.
input
(
'Shape'
))
>
0
:
if
len
(
op
.
input
(
'ShapeTensor'
))
>
1
:
cast_shape_nodes
=
list
()
cast_shape_names
=
list
()
for
i
in
range
(
len
(
op
.
input
(
'ShapeTensor'
))):
dim
=
op
.
input
(
'ShapeTensor'
)[
i
]
temp_name
=
self
.
get_name
(
op
.
type
,
'shape.cast'
)
node
=
helper
.
make_node
(
'Cast'
,
inputs
=
[
dim
],
outputs
=
[
temp_name
],
to
=
onnx_pb
.
TensorProto
.
INT64
)
cast_shape_nodes
.
append
(
node
)
cast_shape_names
.
append
(
temp_name
)
temp_name
=
self
.
get_name
(
op
.
type
,
'shape.concat'
)
shape_node
=
helper
.
make_node
(
'Concat'
,
inputs
=
cast_shape_names
,
outputs
=
[
temp_name
],
axis
=-
1
)
node
=
helper
.
make_node
(
node
=
helper
.
make_node
(
'Reshape'
,
'Reshape'
,
inputs
=
[
op
.
input
(
'X'
)[
0
],
inputs
=
[
op
.
input
(
'X'
)[
0
],
temp_name
],
op
.
input
(
'Shape'
)[
0
]],
outputs
=
op
.
output
(
'Out'
))
outputs
=
op
.
output
(
'Out'
))
return
cast_shape_nodes
+
[
shape_node
,
node
]
else
:
else
:
shape
=
op
.
attr
(
'shape'
)
temp_name
=
self
.
get_name
(
op
.
type
,
'shape.cast'
)
shape_name
=
get_name
(
op
.
type
,
'shape'
)
cast_shape_node
=
helper
.
make_node
(
shape_node
=
make_constant_node
(
shape_name
,
'Cast'
,
onnxpb
.
TensorProto
.
INT64
,
shape
)
inputs
=
op
.
input
(
'ShapeTensor'
),
outputs
=
[
temp_name
],
to
=
onnx_pb
.
TensorProto
.
INT64
)
node
=
helper
.
make_node
(
node
=
helper
.
make_node
(
'Reshape'
,
'Reshape'
,
inputs
=
[
op
.
input
(
'X'
)[
0
],
shape
_name
],
inputs
=
[
op
.
input
(
'X'
)[
0
],
temp
_name
],
outputs
=
op
.
output
(
'Out'
))
outputs
=
op
.
output
(
'Out'
))
return
[
shape_node
,
node
]
return
[
cast_shape_node
,
node
]
return
node
def
dropout
(
self
,
op
,
block
):
def
dropout
(
self
,
op
,
block
):
dropout_mode
=
op
.
attr
(
'dropout_implementation'
)
dropout_mode
=
op
.
attr
(
'dropout_implementation'
)
...
@@ -351,24 +372,31 @@ class PaddleOpMapper(object):
...
@@ -351,24 +372,31 @@ class PaddleOpMapper(object):
'ReduceMean'
,
'ReduceMean'
,
inputs
=
op
.
input
(
'X'
),
inputs
=
op
.
input
(
'X'
),
outputs
=
op
.
output
(
'Out'
),
outputs
=
op
.
output
(
'Out'
),
axes
=
op
.
attr
(
'
axes
'
),
axes
=
op
.
attr
(
'
dim
'
),
keepdims
=
op
.
attr
(
'keep_dim'
))
keepdims
=
op
.
attr
(
'keep_dim'
))
return
node
return
node
def
nearest_interp
(
self
,
op
,
block
):
def
nearest_interp
(
self
,
op
,
block
):
input_names
=
op
.
input_names
input_names
=
op
.
input_names
coordinate_transformation_mode
=
'half_pixel'
if
op
.
attr
(
'align_corners'
):
coordinate_transformation_mode
=
'align_corners'
if
'OutSize'
in
input_names
and
len
(
op
.
input
(
'OutSize'
))
>
0
:
if
'OutSize'
in
input_names
and
len
(
op
.
input
(
'OutSize'
))
>
0
:
node
=
helper
.
make_node
(
node
=
helper
.
make_node
(
'Resize'
,
'Resize'
,
inputs
=
[
op
.
input
(
'X'
)[
0
],
''
,
inputs
=
[
op
.
input
(
'X'
)[
0
],
''
,
op
.
input
(
'OutSize'
)[
0
]],
op
.
input
(
'OutSize'
)[
0
]],
outputs
=
op
.
output
(
'Out'
))
outputs
=
op
.
output
(
'Out'
),
mode
=
'nearest'
,
coordinate_transformation_mode
=
coordinate_transformation_mode
)
elif
'Scale'
in
input_names
and
len
(
op
.
input
(
'Scale'
))
>
0
:
elif
'Scale'
in
input_names
and
len
(
op
.
input
(
'Scale'
))
>
0
:
node
=
helper
.
make_node
(
node
=
helper
.
make_node
(
'Resize'
,
'Resize'
,
inputs
=
[
op
.
input
(
'X'
)[
0
],
inputs
=
[
op
.
input
(
'X'
)[
0
],
op
.
input
(
'Scale'
)[
0
]],
op
.
input
(
'Scale'
)[
0
]],
outputs
=
op
.
output
(
'Out'
))
outputs
=
op
.
output
(
'Out'
),
mode
=
'nearest'
,
coordinate_transformation_mode
=
coordinate_transformation_mode
)
else
:
else
:
out_shape
=
[
op
.
attr
(
'out_h'
),
op
.
attr
(
'out_w'
)]
out_shape
=
[
op
.
attr
(
'out_h'
),
op
.
attr
(
'out_w'
)]
scale
=
op
.
attr
(
'scale'
)
scale
=
op
.
attr
(
'scale'
)
...
@@ -384,7 +412,9 @@ class PaddleOpMapper(object):
...
@@ -384,7 +412,9 @@ class PaddleOpMapper(object):
'Resize'
,
'Resize'
,
inputs
=
[
op
.
input
(
'X'
)[
0
],
roi_name
,
scale_name
],
inputs
=
[
op
.
input
(
'X'
)[
0
],
roi_name
,
scale_name
],
outputs
=
op
.
output
(
'Out'
),
outputs
=
op
.
output
(
'Out'
),
mode
=
'nearest'
)
mode
=
'nearest'
,
coordinate_transformation_mode
=
coordinate_transformation_mode
)
return
[
scale_node
,
roi_node
,
node
]
return
[
scale_node
,
roi_node
,
node
]
else
:
else
:
raise
Exception
(
"Unexpected situation happend"
)
raise
Exception
(
"Unexpected situation happend"
)
...
@@ -477,9 +507,12 @@ class PaddleOpMapper(object):
...
@@ -477,9 +507,12 @@ class PaddleOpMapper(object):
unsupported_ops
=
set
()
unsupported_ops
=
set
()
print
(
"Translating PaddlePaddle to ONNX...
\n
"
)
for
block
in
program
.
blocks
:
for
block
in
program
.
blocks
:
for
op
in
block
.
ops
:
for
i
,
op
in
enumerate
(
block
.
ops
):
print
(
'Translating op: {}'
.
format
(
op
.
type
))
sys
.
stdout
.
write
(
"
\r
Total:{}, Current:{} : {} "
.
format
(
len
(
block
.
ops
),
i
+
1
,
op
.
type
))
if
not
hasattr
(
self
,
op
.
type
):
if
not
hasattr
(
self
,
op
.
type
):
unsupported_ops
.
add
(
op
.
type
)
unsupported_ops
.
add
(
op
.
type
)
continue
continue
...
@@ -497,7 +530,7 @@ class PaddleOpMapper(object):
...
@@ -497,7 +530,7 @@ class PaddleOpMapper(object):
op_nodes
.
append
(
node
)
op_nodes
.
append
(
node
)
if
len
(
unsupported_ops
)
>
0
:
if
len
(
unsupported_ops
)
>
0
:
print
(
"There's {} ops are not supported yet"
.
format
(
print
(
"
\n
There's {} ops are not supported yet"
.
format
(
len
(
unsupported_ops
)))
len
(
unsupported_ops
)))
for
op
in
unsupported_ops
:
for
op
in
unsupported_ops
:
print
(
"=========== {} ==========="
.
format
(
op
))
print
(
"=========== {} ==========="
.
format
(
op
))
...
@@ -516,5 +549,5 @@ class PaddleOpMapper(object):
...
@@ -516,5 +549,5 @@ class PaddleOpMapper(object):
os
.
makedirs
(
save_dir
)
os
.
makedirs
(
save_dir
)
with
open
(
os
.
path
.
join
(
save_dir
,
'x2paddle_model.onnx'
),
'wb'
)
as
f
:
with
open
(
os
.
path
.
join
(
save_dir
,
'x2paddle_model.onnx'
),
'wb'
)
as
f
:
f
.
write
(
model
.
SerializeToString
())
f
.
write
(
model
.
SerializeToString
())
print
(
"Translated model saved in {}"
.
format
(
print
(
"
\n
Translated model saved in {}"
.
format
(
os
.
path
.
join
(
save_dir
,
'x2paddle_model.onnx'
)))
os
.
path
.
join
(
save_dir
,
'x2paddle_model.onnx'
)))
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录