Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
f49b0cb9
P
Paddle
项目概览
BaiXuePrincess
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
f49b0cb9
编写于
7月 27, 2022
作者:
Q
qipengh
提交者:
GitHub
7月 27, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[MLU]fix sync_batch_norm and concat_grad op (#44586)
上级
84d595fa
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
42 addition
and
10 deletion
+42
-10
paddle/fluid/operators/concat_op_mlu.cc
paddle/fluid/operators/concat_op_mlu.cc
+7
-2
paddle/fluid/operators/sync_batch_norm_op_mlu.cc
paddle/fluid/operators/sync_batch_norm_op_mlu.cc
+8
-1
python/paddle/fluid/tests/unittests/mlu/sync_batch_norm_op_mlu.py
...addle/fluid/tests/unittests/mlu/sync_batch_norm_op_mlu.py
+2
-2
python/paddle/fluid/tests/unittests/mlu/test_sync_batch_norm_base_mlu.py
...luid/tests/unittests/mlu/test_sync_batch_norm_base_mlu.py
+2
-2
python/paddle/fluid/tests/unittests/mlu/test_sync_batch_norm_op_mlu.sh
.../fluid/tests/unittests/mlu/test_sync_batch_norm_op_mlu.sh
+19
-0
python/paddle/fluid/tests/unittests/mlu/test_sync_batch_norm_op_mlu_baseline.py
...sts/unittests/mlu/test_sync_batch_norm_op_mlu_baseline.py
+1
-1
python/paddle/fluid/tests/unittests/mlu/test_sync_batch_norm_op_mlu_extra.py
.../tests/unittests/mlu/test_sync_batch_norm_op_mlu_extra.py
+3
-2
未找到文件。
paddle/fluid/operators/concat_op_mlu.cc
浏览文件 @
f49b0cb9
...
@@ -121,6 +121,7 @@ class ConcatGradMLUKernel : public framework::OpKernel<T> {
...
@@ -121,6 +121,7 @@ class ConcatGradMLUKernel : public framework::OpKernel<T> {
out_grad
->
dims
().
size
()));
out_grad
->
dims
().
size
()));
// get output tensor that the name is not kEmptyVarName
// get output tensor that the name is not kEmptyVarName
std
::
vector
<
void
*>
outputs_vec
;
std
::
vector
<
void
*>
outputs_vec
;
std
::
vector
<
Tensor
>
tmp_outputs_vec
;
std
::
vector
<
MLUCnnlTensorDesc
>
output_descs
;
std
::
vector
<
MLUCnnlTensorDesc
>
output_descs
;
std
::
vector
<
cnnlTensorDescriptor_t
>
descs_vec
;
std
::
vector
<
cnnlTensorDescriptor_t
>
descs_vec
;
for
(
size_t
j
=
0
;
j
<
outs
.
size
();
++
j
)
{
for
(
size_t
j
=
0
;
j
<
outs
.
size
();
++
j
)
{
...
@@ -128,11 +129,15 @@ class ConcatGradMLUKernel : public framework::OpKernel<T> {
...
@@ -128,11 +129,15 @@ class ConcatGradMLUKernel : public framework::OpKernel<T> {
outs
[
j
]
->
numel
()
!=
0UL
)
{
outs
[
j
]
->
numel
()
!=
0UL
)
{
outs
[
j
]
->
mutable_data
<
T
>
(
ctx
.
GetPlace
());
outs
[
j
]
->
mutable_data
<
T
>
(
ctx
.
GetPlace
());
output_descs
.
emplace_back
(
MLUCnnlTensorDesc
(
*
outs
[
j
]));
output_descs
.
emplace_back
(
MLUCnnlTensorDesc
(
*
outs
[
j
]));
descs_vec
.
push_back
(
output_descs
.
back
().
get
());
outputs_vec
.
push_back
(
GetBasePtr
(
outs
[
j
]));
outputs_vec
.
push_back
(
GetBasePtr
(
outs
[
j
]));
}
else
{
}
else
{
outputs_vec
.
push_back
(
nullptr
);
Tensor
tmp_tensor
;
tmp_tensor
.
mutable_data
<
T
>
(
ins
[
j
]
->
dims
(),
ctx
.
GetPlace
());
tmp_outputs_vec
.
push_back
(
tmp_tensor
);
output_descs
.
emplace_back
(
MLUCnnlTensorDesc
(
*
ins
[
j
]));
outputs_vec
.
push_back
(
GetBasePtr
(
&
(
tmp_outputs_vec
.
back
())));
}
}
descs_vec
.
push_back
(
output_descs
.
back
().
get
());
}
}
MLUCnnlTensorDesc
out_grad_desc
(
*
out_grad
);
MLUCnnlTensorDesc
out_grad_desc
(
*
out_grad
);
...
...
paddle/fluid/operators/sync_batch_norm_op_mlu.cc
浏览文件 @
f49b0cb9
...
@@ -23,7 +23,9 @@ limitations under the Licnse. */
...
@@ -23,7 +23,9 @@ limitations under the Licnse. */
namespace
paddle
{
namespace
paddle
{
namespace
operators
{
namespace
operators
{
#define NO_USE_CNCL 0
#define GET_LAYOUT_OFFSET 2
#define GET_LAYOUT_OFFSET 2
using
Tensor
=
framework
::
Tensor
;
using
Tensor
=
framework
::
Tensor
;
static
std
::
vector
<
cnnlTensorLayout_t
>
supported_input_layout
=
{
static
std
::
vector
<
cnnlTensorLayout_t
>
supported_input_layout
=
{
CNNL_LAYOUT_NC
,
CNNL_LAYOUT_NLC
,
CNNL_LAYOUT_NHWC
,
CNNL_LAYOUT_NDHWC
};
CNNL_LAYOUT_NC
,
CNNL_LAYOUT_NLC
,
CNNL_LAYOUT_NHWC
,
CNNL_LAYOUT_NDHWC
};
...
@@ -165,6 +167,7 @@ class SyncBatchNormMLUKernel : public framework::OpKernel<T> {
...
@@ -165,6 +167,7 @@ class SyncBatchNormMLUKernel : public framework::OpKernel<T> {
Tensor
mean_all
(
mean
->
dtype
());
Tensor
mean_all
(
mean
->
dtype
());
Tensor
invstd_all
(
variance
->
dtype
());
Tensor
invstd_all
(
variance
->
dtype
());
#ifdef PADDLE_WITH_CNCL
auto
&
dev_ctx
=
auto
&
dev_ctx
=
ctx
.
template
device_context
<
paddle
::
platform
::
MLUDeviceContext
>();
ctx
.
template
device_context
<
paddle
::
platform
::
MLUDeviceContext
>();
auto
stream
=
dev_ctx
.
stream
();
auto
stream
=
dev_ctx
.
stream
();
...
@@ -205,7 +208,9 @@ class SyncBatchNormMLUKernel : public framework::OpKernel<T> {
...
@@ -205,7 +208,9 @@ class SyncBatchNormMLUKernel : public framework::OpKernel<T> {
cncl_dtype
,
cncl_dtype
,
comm
,
comm
,
stream
));
stream
));
#else
if
(
NO_USE_CNCL
)
{
#endif
}
else
{
}
else
{
count_all
=
input_count
;
count_all
=
input_count
;
mean_all
.
ShareDataWith
(
local_mean
);
mean_all
.
ShareDataWith
(
local_mean
);
...
@@ -404,6 +409,7 @@ class SyncBatchNormMLUGradKernel : public framework::OpKernel<T> {
...
@@ -404,6 +409,7 @@ class SyncBatchNormMLUGradKernel : public framework::OpKernel<T> {
FillMLUTensorWithHostValue
<
int32_t
>
(
FillMLUTensorWithHostValue
<
int32_t
>
(
ctx
,
static_cast
<
int32_t
>
(
x
->
numel
()
/
C
),
&
numel_count
);
ctx
,
static_cast
<
int32_t
>
(
x
->
numel
()
/
C
),
&
numel_count
);
#ifdef PADDLE_WITH_CNCL
auto
&
dev_ctx
=
auto
&
dev_ctx
=
ctx
.
template
device_context
<
paddle
::
platform
::
MLUDeviceContext
>();
ctx
.
template
device_context
<
paddle
::
platform
::
MLUDeviceContext
>();
auto
stream
=
dev_ctx
.
stream
();
auto
stream
=
dev_ctx
.
stream
();
...
@@ -440,6 +446,7 @@ class SyncBatchNormMLUGradKernel : public framework::OpKernel<T> {
...
@@ -440,6 +446,7 @@ class SyncBatchNormMLUGradKernel : public framework::OpKernel<T> {
comm
,
comm
,
stream
));
stream
));
}
}
#endif
if
(
d_x
)
{
if
(
d_x
)
{
MLUCnnlTensorDesc
desc_count
(
numel_count
);
MLUCnnlTensorDesc
desc_count
(
numel_count
);
...
...
python/paddle/fluid/tests/unittests/mlu/sync_batch_norm_op_mlu.py
浏览文件 @
f49b0cb9
...
@@ -35,9 +35,9 @@ from multiprocessing import Process
...
@@ -35,9 +35,9 @@ from multiprocessing import Process
import
paddle.fluid.layers
as
layers
import
paddle.fluid.layers
as
layers
from
functools
import
reduce
from
functools
import
reduce
from
test_sync_batch_norm_base_mlu
import
TestSyncBatchNormRunnerBase
,
runtime_main
from
test_sync_batch_norm_base_mlu
import
TestSyncBatchNormRunnerBase
,
runtime_main
from
paddle.fluid.tests.unittests.
op_test
import
OpTest
,
_set_use_system_allocator
from
op_test
import
OpTest
,
_set_use_system_allocator
from
paddle.fluid.tests.unittests.
test_sync_batch_norm_op
import
create_or_get_tensor
from
test_sync_batch_norm_op
import
create_or_get_tensor
_set_use_system_allocator
(
False
)
_set_use_system_allocator
(
False
)
paddle
.
enable_static
()
paddle
.
enable_static
()
...
...
python/paddle/fluid/tests/unittests/mlu/test_sync_batch_norm_base_mlu.py
浏览文件 @
f49b0cb9
...
@@ -33,9 +33,9 @@ from paddle.fluid import core
...
@@ -33,9 +33,9 @@ from paddle.fluid import core
from
six
import
string_types
from
six
import
string_types
import
paddle
import
paddle
from
paddle.fluid.tests.unittests.
op_test
import
OpTest
,
_set_use_system_allocator
from
op_test
import
OpTest
,
_set_use_system_allocator
from
paddle.fluid.tests.unittests.
test_sync_batch_norm_op
import
create_or_get_tensor
from
test_sync_batch_norm_op
import
create_or_get_tensor
_set_use_system_allocator
(
False
)
_set_use_system_allocator
(
False
)
paddle
.
enable_static
()
paddle
.
enable_static
()
...
...
python/paddle/fluid/tests/unittests/mlu/test_sync_batch_norm_op_mlu.sh
0 → 100644
浏览文件 @
f49b0cb9
#!/bin/bash
# Copyright (c) 2022 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.
set
-e
MLU_VISIBLE_DEVICES
=
0,1 python
-m
paddle.distributed.launch test_sync_batch_norm_op_mlu_baseline.py
python/paddle/fluid/tests/unittests/mlu/test_sync_batch_norm_op_mlu_baseline.py
浏览文件 @
f49b0cb9
...
@@ -20,7 +20,7 @@ import os
...
@@ -20,7 +20,7 @@ import os
import
sys
import
sys
sys
.
path
.
append
(
".."
)
sys
.
path
.
append
(
".."
)
from
paddle.fluid.tests.unittests.
op_test
import
OpTest
,
_set_use_system_allocator
from
op_test
import
OpTest
,
_set_use_system_allocator
from
test_sync_batch_norm_base_mlu
import
TestDistBase
from
test_sync_batch_norm_base_mlu
import
TestDistBase
...
...
python/paddle/fluid/tests/unittests/mlu/test_sync_batch_norm_op_mlu_extra.py
浏览文件 @
f49b0cb9
...
@@ -29,8 +29,9 @@ import paddle.fluid as fluid
...
@@ -29,8 +29,9 @@ import paddle.fluid as fluid
import
paddle.nn
as
nn
import
paddle.nn
as
nn
from
paddle.fluid
import
Program
,
program_guard
from
paddle.fluid
import
Program
,
program_guard
from
paddle.fluid.tests.unittests.op_test
import
OpTest
,
_set_use_system_allocator
sys
.
path
.
append
(
".."
)
from
paddle.fluid.tests.unittests.test_dist_base
import
TestDistBase
from
op_test
import
OpTest
,
_set_use_system_allocator
from
test_dist_base
import
TestDistBase
paddle
.
enable_static
()
paddle
.
enable_static
()
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录