Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
4f6aba87
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
4f6aba87
编写于
4月 22, 2022
作者:
J
Jacek Czaja
提交者:
GitHub
4月 22, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add UT (#42055)
上级
6ad0f061
变更
7
显示空白变更内容
内联
并排
Showing
7 changed file
with
118 addition
and
8 deletion
+118
-8
paddle/fluid/framework/data_layout_transform.h
paddle/fluid/framework/data_layout_transform.h
+8
-0
paddle/fluid/framework/data_transform.cc
paddle/fluid/framework/data_transform.cc
+1
-1
paddle/fluid/inference/api/details/zero_copy_tensor.cc
paddle/fluid/inference/api/details/zero_copy_tensor.cc
+2
-1
paddle/fluid/platform/mkldnn_helper.h
paddle/fluid/platform/mkldnn_helper.h
+12
-4
paddle/phi/common/layout.h
paddle/phi/common/layout.h
+2
-2
python/paddle/fluid/tests/unittests/ir/inference/CMakeLists.txt
.../paddle/fluid/tests/unittests/ir/inference/CMakeLists.txt
+1
-0
python/paddle/fluid/tests/unittests/ir/inference/test_mkldnn_conv3d_op.py
...uid/tests/unittests/ir/inference/test_mkldnn_conv3d_op.py
+92
-0
未找到文件。
paddle/fluid/framework/data_layout_transform.h
浏览文件 @
4f6aba87
...
@@ -59,6 +59,10 @@ inline MKLDNNMemoryFormat ToMKLDNNFormat(const DataLayout& layout) {
...
@@ -59,6 +59,10 @@ inline MKLDNNMemoryFormat ToMKLDNNFormat(const DataLayout& layout) {
return
MKLDNNMemoryFormat
::
nhwc
;
return
MKLDNNMemoryFormat
::
nhwc
;
case
DataLayout
::
kNCHW
:
case
DataLayout
::
kNCHW
:
return
MKLDNNMemoryFormat
::
nchw
;
return
MKLDNNMemoryFormat
::
nchw
;
case
DataLayout
::
kNCDHW
:
return
MKLDNNMemoryFormat
::
ncdhw
;
case
DataLayout
::
kNDHWC
:
return
MKLDNNMemoryFormat
::
ndhwc
;
default:
default:
PADDLE_THROW
(
platform
::
errors
::
InvalidArgument
(
PADDLE_THROW
(
platform
::
errors
::
InvalidArgument
(
"Fail to convert layout %s to MKLDNN format."
,
"Fail to convert layout %s to MKLDNN format."
,
...
@@ -72,6 +76,10 @@ inline DataLayout ToPaddleLayout(const MKLDNNMemoryFormat& format) {
...
@@ -72,6 +76,10 @@ inline DataLayout ToPaddleLayout(const MKLDNNMemoryFormat& format) {
return
DataLayout
::
kNHWC
;
return
DataLayout
::
kNHWC
;
case
MKLDNNMemoryFormat
::
nchw
:
case
MKLDNNMemoryFormat
::
nchw
:
return
DataLayout
::
kNCHW
;
return
DataLayout
::
kNCHW
;
case
MKLDNNMemoryFormat
::
ncdhw
:
return
DataLayout
::
kNCDHW
;
case
MKLDNNMemoryFormat
::
ndhwc
:
return
DataLayout
::
kNDHWC
;
default:
default:
PADDLE_THROW
(
platform
::
errors
::
InvalidArgument
(
PADDLE_THROW
(
platform
::
errors
::
InvalidArgument
(
"Fail to convert MKLDNN format to paddle layout."
));
"Fail to convert MKLDNN format to paddle layout."
));
...
...
paddle/fluid/framework/data_transform.cc
浏览文件 @
4f6aba87
...
@@ -63,7 +63,7 @@ void TransformData(const OpKernelType &expected_kernel_type,
...
@@ -63,7 +63,7 @@ void TransformData(const OpKernelType &expected_kernel_type,
out
.
ShareDataWith
(
input_tensor
);
out
.
ShareDataWith
(
input_tensor
);
// For NHWC data we need reshape of tensors as MKL-DNN
// For NHWC data we need reshape of tensors as MKL-DNN
// is expecting NHWC dims description order
// is expecting NHWC dims description order
if
(
lin
==
DataLayout
::
kNHWC
)
{
if
(
lin
==
DataLayout
::
kNHWC
||
lin
==
DataLayout
::
kNDHWC
)
{
platform
::
MatchShapeToLayout
(
&
out
,
lin
,
lout
);
platform
::
MatchShapeToLayout
(
&
out
,
lin
,
lout
);
// We register only NHWC assuming that model is consistent e.g. either
// We register only NHWC assuming that model is consistent e.g. either
// NHWC or NCHW
// NHWC or NCHW
...
...
paddle/fluid/inference/api/details/zero_copy_tensor.cc
浏览文件 @
4f6aba87
...
@@ -579,7 +579,8 @@ std::vector<int> Tensor::shape() const {
...
@@ -579,7 +579,8 @@ std::vector<int> Tensor::shape() const {
// be done. Similarly for dim==1 when you have just one possible
// be done. Similarly for dim==1 when you have just one possible
// combination.
// combination.
if
(
tensor
->
dims
().
size
()
<
3
)
return
phi
::
vectorize
<
int
>
(
tensor
->
dims
());
if
(
tensor
->
dims
().
size
()
<
3
)
return
phi
::
vectorize
<
int
>
(
tensor
->
dims
());
if
(
out_layout
==
paddle
::
framework
::
DataLayout
::
kNHWC
)
{
if
(
out_layout
==
paddle
::
framework
::
DataLayout
::
kNHWC
||
out_layout
==
paddle
::
framework
::
DataLayout
::
kNDHWC
)
{
auto
dims
=
phi
::
vectorize
<
int
>
(
tensor
->
dims
());
auto
dims
=
phi
::
vectorize
<
int
>
(
tensor
->
dims
());
std
::
rotate
(
dims
.
begin
()
+
1
,
dims
.
begin
()
+
2
,
dims
.
end
());
std
::
rotate
(
dims
.
begin
()
+
1
,
dims
.
begin
()
+
2
,
dims
.
end
());
return
dims
;
return
dims
;
...
...
paddle/fluid/platform/mkldnn_helper.h
浏览文件 @
4f6aba87
...
@@ -20,6 +20,7 @@ limitations under the License. */
...
@@ -20,6 +20,7 @@ limitations under the License. */
#include <string>
#include <string>
#include <utility>
#include <utility>
#include <vector>
#include <vector>
#include "dnnl.hpp"
#include "dnnl.hpp"
#include "paddle/fluid/framework/operator.h"
#include "paddle/fluid/framework/operator.h"
#include "paddle/fluid/platform/place.h"
#include "paddle/fluid/platform/place.h"
...
@@ -102,20 +103,22 @@ inline void MatchShapeToLayout(framework::Tensor* tensor_in,
...
@@ -102,20 +103,22 @@ inline void MatchShapeToLayout(framework::Tensor* tensor_in,
switch
(
from
)
{
switch
(
from
)
{
case
framework
:
:
DataLayout
::
kMKLDNN
:
case
framework
:
:
DataLayout
::
kMKLDNN
:
if
(
to
==
framework
::
DataLayout
::
kNHWC
)
{
if
((
to
==
framework
::
DataLayout
::
kNHWC
)
||
(
to
==
framework
::
DataLayout
::
kNDHWC
))
{
auto
dims
=
phi
::
vectorize
<
int
>
(
tensor_in
->
dims
());
auto
dims
=
phi
::
vectorize
<
int
>
(
tensor_in
->
dims
());
std
::
rotate
(
dims
.
begin
()
+
1
,
dims
.
begin
()
+
2
,
dims
.
end
());
std
::
rotate
(
dims
.
begin
()
+
1
,
dims
.
begin
()
+
2
,
dims
.
end
());
tensor_in
->
Resize
(
phi
::
make_ddim
(
dims
));
tensor_in
->
Resize
(
phi
::
make_ddim
(
dims
));
VLOG
(
3
)
<<
"Rotating Shape from: kMKLDNN to: kNHWC output_shape"
VLOG
(
3
)
<<
"Rotating Shape from: kMKLDNN to: kNHWC
/kNDHWC
output_shape"
<<
print_dims
(
dims
);
<<
print_dims
(
dims
);
}
}
break
;
break
;
case
framework
:
:
DataLayout
::
kNHWC
:
case
framework
:
:
DataLayout
::
kNHWC
:
case
framework
:
:
DataLayout
::
kNDHWC
:
if
(
to
==
framework
::
DataLayout
::
kMKLDNN
)
{
if
(
to
==
framework
::
DataLayout
::
kMKLDNN
)
{
auto
dims
=
phi
::
vectorize
<
int
>
(
tensor_in
->
dims
());
auto
dims
=
phi
::
vectorize
<
int
>
(
tensor_in
->
dims
());
std
::
rotate
(
dims
.
begin
()
+
1
,
dims
.
end
()
-
1
,
dims
.
end
());
std
::
rotate
(
dims
.
begin
()
+
1
,
dims
.
end
()
-
1
,
dims
.
end
());
tensor_in
->
Resize
(
phi
::
make_ddim
(
dims
));
tensor_in
->
Resize
(
phi
::
make_ddim
(
dims
));
VLOG
(
3
)
<<
"Rotating Shape from: kNHWC to: kMKLDNN output_shape"
VLOG
(
3
)
<<
"Rotating Shape from: kNHWC
/kNDHWC
to: kMKLDNN output_shape"
<<
print_dims
(
dims
);
<<
print_dims
(
dims
);
}
}
break
;
break
;
...
@@ -279,7 +282,12 @@ inline dnnl::memory::format_tag GetMKLDNNFormat(dnnl::memory::desc mem_desc) {
...
@@ -279,7 +282,12 @@ inline dnnl::memory::format_tag GetMKLDNNFormat(dnnl::memory::desc mem_desc) {
return
dnnl
::
memory
::
format_tag
::
acdeb
;
return
dnnl
::
memory
::
format_tag
::
acdeb
;
}
}
}
else
if
(
inner_nblks
==
1
)
{
}
else
if
(
inner_nblks
==
1
)
{
if
(
inner_blks
[
0
]
==
8
&&
inner_idxs
[
0
]
==
0
)
{
if
(
inner_blks
[
0
]
==
4
&&
inner_idxs
[
0
]
==
1
)
{
if
(
strides
[
0
]
>=
strides
[
1
]
&&
strides
[
1
]
>=
strides
[
2
]
&&
strides
[
2
]
>=
strides
[
3
]
&&
strides
[
3
]
>=
strides
[
4
])
{
return
dnnl
::
memory
::
format_tag
::
aBcde4b
;
}
}
else
if
(
inner_blks
[
0
]
==
8
&&
inner_idxs
[
0
]
==
0
)
{
if
(
strides
[
0
]
>=
strides
[
2
]
&&
strides
[
2
]
>=
strides
[
3
]
&&
if
(
strides
[
0
]
>=
strides
[
2
]
&&
strides
[
2
]
>=
strides
[
3
]
&&
strides
[
3
]
>=
strides
[
4
]
&&
strides
[
4
]
>=
strides
[
1
])
{
strides
[
3
]
>=
strides
[
4
]
&&
strides
[
4
]
>=
strides
[
1
])
{
return
dnnl
::
memory
::
format_tag
::
Acdeb8a
;
return
dnnl
::
memory
::
format_tag
::
Acdeb8a
;
...
...
paddle/phi/common/layout.h
浏览文件 @
4f6aba87
...
@@ -26,13 +26,13 @@ enum class DataLayout {
...
@@ -26,13 +26,13 @@ enum class DataLayout {
ANY
=
UNDEFINED
,
ANY
=
UNDEFINED
,
NHWC
,
NHWC
,
NCHW
,
NCHW
,
NCDHW
,
NDHWC
,
MKLDNN
,
MKLDNN
,
SPARSE_COO
,
SPARSE_COO
,
SPARSE_CSR
,
SPARSE_CSR
,
PSTRING_UNION
,
PSTRING_UNION
,
NUM_DATA_LAYOUTS
,
NUM_DATA_LAYOUTS
,
NDHWC
,
NCDHW
,
// See Note [ Why we need ALL in basic kernel key member? ]
// See Note [ Why we need ALL in basic kernel key member? ]
ALL_LAYOUT
=
UNDEFINED
,
ALL_LAYOUT
=
UNDEFINED
,
// Note: Unify phi DataLayout and fluid::framework::DataLayout,
// Note: Unify phi DataLayout and fluid::framework::DataLayout,
...
...
python/paddle/fluid/tests/unittests/ir/inference/CMakeLists.txt
浏览文件 @
4f6aba87
...
@@ -128,6 +128,7 @@ if (WITH_MKLDNN)
...
@@ -128,6 +128,7 @@ if (WITH_MKLDNN)
set_tests_properties
(
test_mkldnn_depthwise_conv_pass PROPERTIES TIMEOUT 120
)
set_tests_properties
(
test_mkldnn_depthwise_conv_pass PROPERTIES TIMEOUT 120
)
set_tests_properties
(
test_mkldnn_reshape_transpose_matmul_fuse_pass PROPERTIES TIMEOUT 100
)
set_tests_properties
(
test_mkldnn_reshape_transpose_matmul_fuse_pass PROPERTIES TIMEOUT 100
)
set_tests_properties
(
test_mkldnn_mish_op PROPERTIES TIMEOUT 300
)
set_tests_properties
(
test_mkldnn_mish_op PROPERTIES TIMEOUT 300
)
set_tests_properties
(
test_mkldnn_conv3d_op PROPERTIES TIMEOUT 300
)
set_tests_properties
(
test_mkldnn_prelu_op PROPERTIES TIMEOUT 300
)
set_tests_properties
(
test_mkldnn_prelu_op PROPERTIES TIMEOUT 300
)
set_tests_properties
(
test_conv_act_mkldnn_fuse_pass PROPERTIES TIMEOUT 120
)
set_tests_properties
(
test_conv_act_mkldnn_fuse_pass PROPERTIES TIMEOUT 120
)
set_tests_properties
(
test_conv_transpose_eltwiseadd_bn_fuse_pass PROPERTIES TIMEOUT 250
)
set_tests_properties
(
test_conv_transpose_eltwiseadd_bn_fuse_pass PROPERTIES TIMEOUT 250
)
...
...
python/paddle/fluid/tests/unittests/ir/inference/test_mkldnn_conv3d_op.py
0 → 100644
浏览文件 @
4f6aba87
# Copyright (c) 2021 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
from
auto_scan_test
import
MkldnnAutoScanTest
,
SkipReasons
from
program_config
import
TensorConfig
,
ProgramConfig
,
OpConfig
import
numpy
as
np
import
paddle.inference
as
paddle_infer
from
functools
import
partial
from
typing
import
Optional
,
List
,
Callable
,
Dict
,
Any
,
Set
import
unittest
import
hypothesis
from
hypothesis
import
given
,
settings
,
seed
,
example
,
assume
import
hypothesis.strategies
as
st
class
TestMkldnnConv3dOp
(
MkldnnAutoScanTest
):
def
is_program_valid
(
self
,
program_config
:
ProgramConfig
)
->
bool
:
return
True
def
sample_program_configs
(
self
,
*
args
,
**
kwargs
):
def
generate_input
(
*
args
,
**
kwargs
):
if
kwargs
[
"data_format"
]
==
"NCDHW"
:
return
np
.
random
.
random
(
[
kwargs
[
"batch_size"
],
48
,
64
,
32
,
64
]).
astype
(
np
.
float32
)
else
:
return
np
.
random
.
random
(
[
kwargs
[
"batch_size"
],
64
,
32
,
64
,
48
]).
astype
(
np
.
float32
)
def
generate_weight
(
*
args
,
**
kwargs
):
return
np
.
random
.
random
(
[
16
,
int
(
48
/
kwargs
[
"groups"
]),
3
,
3
,
3
]).
astype
(
np
.
float32
)
conv3d_op
=
OpConfig
(
type
=
"conv3d"
,
inputs
=
{
"Input"
:
[
"input_data"
],
"Filter"
:
[
"conv_weight"
]},
outputs
=
{
"Output"
:
[
"conv_output"
]},
attrs
=
{
"data_format"
:
kwargs
[
"data_format"
],
"dilations"
:
kwargs
[
"dilations"
],
"padding_algorithm"
:
kwargs
[
"padding_algorithm"
],
"groups"
:
kwargs
[
"groups"
],
"paddings"
:
kwargs
[
"paddings"
],
"strides"
:
kwargs
[
"strides"
],
"is_test"
:
True
})
program_config
=
ProgramConfig
(
ops
=
[
conv3d_op
],
weights
=
{
"conv_weight"
:
TensorConfig
(
data_gen
=
partial
(
generate_weight
,
*
args
,
**
kwargs
))
},
inputs
=
{
"input_data"
:
TensorConfig
(
data_gen
=
partial
(
generate_input
,
*
args
,
**
kwargs
))
},
outputs
=
[
"conv_output"
])
yield
program_config
def
sample_predictor_configs
(
self
,
program_config
):
config
=
self
.
create_inference_config
(
use_mkldnn
=
True
)
yield
config
,
(
1e-5
,
1e-5
)
@
given
(
data_format
=
st
.
sampled_from
([
"NCDHW"
,
"NDHWC"
]),
dilations
=
st
.
sampled_from
([[
1
,
2
,
1
]]),
padding_algorithm
=
st
.
sampled_from
([
"EXPLICIT"
]),
groups
=
st
.
sampled_from
([
2
]),
paddings
=
st
.
sampled_from
([[
0
,
3
,
2
]]),
strides
=
st
.
sampled_from
([[
1
,
2
,
1
]]),
batch_size
=
st
.
integers
(
min_value
=
1
,
max_value
=
4
),
)
def
test
(
self
,
*
args
,
**
kwargs
):
self
.
run_test
(
*
args
,
**
kwargs
)
if
__name__
==
"__main__"
:
unittest
.
main
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录