Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
X2Paddle
提交
aca270bd
X
X2Paddle
项目概览
PaddlePaddle
/
X2Paddle
大约 1 年 前同步成功
通知
328
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看板
未验证
提交
aca270bd
编写于
7月 21, 2020
作者:
J
Jason
提交者:
GitHub
7月 21, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #315 from Channingss/paddle2onnx_pad2d
Paddle2ONNX support OP:pad2d
上级
ac63c094
d900306f
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
49 addition
and
0 deletion
+49
-0
x2paddle/op_mapper/paddle2onnx/opset11/opset.py
x2paddle/op_mapper/paddle2onnx/opset11/opset.py
+27
-0
x2paddle/op_mapper/paddle2onnx/opset9/opset.py
x2paddle/op_mapper/paddle2onnx/opset9/opset.py
+22
-0
未找到文件。
x2paddle/op_mapper/paddle2onnx/opset11/opset.py
浏览文件 @
aca270bd
...
@@ -41,6 +41,33 @@ class OpSet11(OpSet10):
...
@@ -41,6 +41,33 @@ class OpSet11(OpSet10):
outputs
=
op
.
output
(
'Out'
),
)
outputs
=
op
.
output
(
'Out'
),
)
return
[
min_node
,
max_node
,
node
]
return
[
min_node
,
max_node
,
node
]
def
pad2d
(
self
,
op
,
block
):
x_shape
=
block
.
var
(
op
.
input
(
'X'
)[
0
]).
shape
paddings
=
op
.
attr
(
'paddings'
)
onnx_pads
=
[]
#TODO support pads is Variable
if
op
.
attr
(
'data_format'
)
==
'NCHW'
:
pads
=
[
0
,
0
,
paddings
[
0
],
paddings
[
2
],
0
,
0
,
paddings
[
1
],
paddings
[
3
]
]
else
:
pads
=
[
0
,
paddings
[
0
],
paddings
[
2
],
0
,
0
,
paddings
[
1
],
paddings
[
3
],
0
]
pads_name
=
self
.
get_name
(
op
.
type
,
'pads'
)
pads_node
=
self
.
make_constant_node
(
pads_name
,
onnx_pb
.
TensorProto
.
INT64
,
pads
)
constant_value_name
=
self
.
get_name
(
op
.
type
,
'constant_value'
)
constant_value_node
=
self
.
make_constant_node
(
constant_value_name
,
onnx_pb
.
TensorProto
.
FLOAT
,
op
.
attr
(
'pad_value'
))
node
=
helper
.
make_node
(
'Pad'
,
inputs
=
op
.
input
(
'X'
)
+
[
pads_name
,
constant_value_name
],
outputs
=
op
.
output
(
'Out'
),
mode
=
op
.
attr
(
'mode'
))
return
[
pads_node
,
constant_value_node
,
node
]
def
bilinear_interp
(
self
,
op
,
block
):
def
bilinear_interp
(
self
,
op
,
block
):
input_names
=
op
.
input_names
input_names
=
op
.
input_names
coordinate_transformation_mode
=
''
coordinate_transformation_mode
=
''
...
...
x2paddle/op_mapper/paddle2onnx/opset9/opset.py
浏览文件 @
aca270bd
...
@@ -215,6 +215,28 @@ class OpSet9(object):
...
@@ -215,6 +215,28 @@ class OpSet9(object):
pads
=
op
.
attr
(
'paddings'
)
+
op
.
attr
(
'paddings'
))
pads
=
op
.
attr
(
'paddings'
)
+
op
.
attr
(
'paddings'
))
return
node
return
node
def
pad2d
(
self
,
op
,
block
):
x_shape
=
block
.
var
(
op
.
input
(
'X'
)[
0
]).
shape
paddings
=
op
.
attr
(
'paddings'
)
onnx_pads
=
[]
if
op
.
attr
(
'data_format'
)
==
'NCHW'
:
pads
=
[
0
,
0
,
paddings
[
0
],
paddings
[
2
],
0
,
0
,
paddings
[
1
],
paddings
[
3
]
]
else
:
pads
=
[
0
,
paddings
[
0
],
paddings
[
2
],
0
,
0
,
paddings
[
1
],
paddings
[
3
],
0
]
#TODO support pads is Variable
node
=
helper
.
make_node
(
'Pad'
,
inputs
=
op
.
input
(
'X'
),
outputs
=
op
.
output
(
'Out'
),
mode
=
op
.
attr
(
'mode'
),
value
=
op
.
attr
(
'pad_value'
),
pads
=
pads
)
return
node
def
softmax
(
self
,
op
,
block
):
def
softmax
(
self
,
op
,
block
):
axis
=
op
.
attr
(
'axis'
)
axis
=
op
.
attr
(
'axis'
)
shape
=
block
.
var
(
op
.
output
(
'Out'
)[
0
]).
shape
shape
=
block
.
var
(
op
.
output
(
'Out'
)[
0
]).
shape
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录