Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Crayon鑫
Paddle
提交
9a2a4b5f
P
Paddle
项目概览
Crayon鑫
/
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看板
未验证
提交
9a2a4b5f
编写于
10月 14, 2020
作者:
L
Leo Chen
提交者:
GitHub
10月 14, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Support setting xpu place in dygraph mode (#27909)
* support setting xpu place * add ut, test=kunlun
上级
35734138
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
67 addition
and
19 deletion
+67
-19
paddle/fluid/operators/metrics/accuracy_op_xpu.cc
paddle/fluid/operators/metrics/accuracy_op_xpu.cc
+2
-2
paddle/fluid/pybind/pybind.cc
paddle/fluid/pybind/pybind.cc
+4
-0
python/paddle/device.py
python/paddle/device.py
+37
-17
python/paddle/fluid/tests/unittests/test_device.py
python/paddle/fluid/tests/unittests/test_device.py
+24
-0
未找到文件。
paddle/fluid/operators/metrics/accuracy_op_xpu.cc
浏览文件 @
9a2a4b5f
...
...
@@ -81,9 +81,9 @@ class AccuracyXPUKernel : public framework::OpKernel<T> {
memory
::
Copy
(
platform
::
CPUPlace
(),
label_int64_host
,
BOOST_GET_CONST
(
platform
::
XPUPlace
,
ctx
.
GetPlace
()),
label_data
,
label_int64_size
);
for
(
in
t
i
=
0
;
i
<
num_samples
;
++
i
)
{
for
(
size_
t
i
=
0
;
i
<
num_samples
;
++
i
)
{
label_int32_host
[
i
]
=
label_int64_host
[
i
];
for
(
in
t
j
=
0
;
j
<
class_dim
;
++
j
)
{
for
(
size_
t
j
=
0
;
j
<
class_dim
;
++
j
)
{
indices_int32_host
[
i
*
class_dim
+
j
]
=
indices_int64_host
[
i
*
class_dim
+
j
];
}
...
...
paddle/fluid/pybind/pybind.cc
浏览文件 @
9a2a4b5f
...
...
@@ -1468,6 +1468,7 @@ All parameter, weight, gradient are variables in Paddle.
std
::
exit
(
-
1
);
#endif
})
#ifdef PADDLE_WITH_XPU
.
def
(
"_type"
,
&
PlaceIndex
<
platform
::
XPUPlace
>
)
.
def
(
"_equals"
,
&
IsSamePlace
<
platform
::
XPUPlace
,
platform
::
Place
>
)
.
def
(
"_equals"
,
&
IsSamePlace
<
platform
::
XPUPlace
,
platform
::
CUDAPlace
>
)
...
...
@@ -1475,6 +1476,9 @@ All parameter, weight, gradient are variables in Paddle.
.
def
(
"_equals"
,
&
IsSamePlace
<
platform
::
XPUPlace
,
platform
::
XPUPlace
>
)
.
def
(
"_equals"
,
&
IsSamePlace
<
platform
::
XPUPlace
,
platform
::
CUDAPinnedPlace
>
)
.
def
(
"get_device_id"
,
[](
const
platform
::
XPUPlace
&
self
)
{
return
self
.
GetDeviceId
();
})
#endif
.
def
(
"__str__"
,
string
::
to_string
<
const
platform
::
XPUPlace
&>
);
py
::
class_
<
paddle
::
platform
::
CPUPlace
>
(
m
,
"CPUPlace"
,
R"DOC(
...
...
python/paddle/device.py
浏览文件 @
9a2a4b5f
...
...
@@ -103,15 +103,15 @@ def get_cudnn_version():
def
set_device
(
device
):
"""
Paddle supports running calculations on various types of devices, including CPU
and G
PU.
Paddle supports running calculations on various types of devices, including CPU
, GPU and X
PU.
They are represented by string identifiers. This function can specify the global device
which the OP will run.
Parameters:
device(str): This parameter determines the specific running device.
It can be ``cpu``
or ``gpu:0``. When ``device`` is ``cpu``, the
program is running on the cpu. When ``device`` is ``gpu``, the
program is running ont the gpu.
It can be ``cpu``
, ``gpu:x`` and ``xpu:x``, where ``x`` is the
index of the GPUs or XPUs.
Examples:
.. code-block:: python
...
...
@@ -132,20 +132,37 @@ def set_device(device):
"The device should not be 'gpu', "
\
"since PaddlePaddle is not compiled with CUDA"
)
place
=
core
.
CUDAPlace
(
ParallelEnv
().
dev_id
)
elif
lower_device
==
'xpu'
:
if
not
core
.
is_compiled_with_xpu
():
raise
ValueError
(
"The device should not be 'xpu', "
\
"since PaddlePaddle is not compiled with XPU"
)
place
=
core
.
XPUPlace
(
ParallelEnv
().
dev_id
)
else
:
avaliable_device
=
re
.
match
(
r
'gpu:\d+'
,
lower_device
)
if
not
avaliable_device
:
avaliable_gpu_device
=
re
.
match
(
r
'gpu:\d+'
,
lower_device
)
avaliable_xpu_device
=
re
.
match
(
r
'xpu:\d+'
,
lower_device
)
if
not
avaliable_gpu_device
and
not
avaliable_xpu_device
:
raise
ValueError
(
"The device must be a string which is like 'cpu', 'gpu'
or 'gpu:0
'"
"The device must be a string which is like 'cpu', 'gpu'
, 'gpu:x', 'xpu' or 'xpu:x
'"
)
if
avaliable_gpu_device
:
if
not
core
.
is_compiled_with_cuda
():
raise
ValueError
(
"The device should not be {}, since PaddlePaddle is "
\
"not compiled with CUDA"
.
format
(
avaliable
_device
))
"not compiled with CUDA"
.
format
(
avaliable_gpu
_device
))
device_info_list
=
device
.
split
(
':'
,
1
)
device_id
=
device_info_list
[
1
]
device_id
=
int
(
device_id
)
place
=
core
.
CUDAPlace
(
device_id
)
if
avaliable_xpu_device
:
if
not
core
.
is_compiled_with_xpu
():
raise
ValueError
(
"The device should not be {}, since PaddlePaddle is "
\
"not compiled with XPU"
.
format
(
avaliable_xpu_device
))
device_info_list
=
device
.
split
(
':'
,
1
)
device_id
=
device_info_list
[
1
]
device_id
=
int
(
device_id
)
place
=
core
.
XPUPlace
(
device_id
)
framework
.
_set_expected_place
(
place
)
return
place
...
...
@@ -153,8 +170,8 @@ def set_device(device):
def
get_device
():
"""
This funciton can get the current global device of the program is running.
It's a string which is like 'cpu'
and 'gpu:0
'. if the global device is not
set, it will return a string which is 'gpu:
0
' when cuda is avaliable or it
It's a string which is like 'cpu'
, 'gpu:x' and 'xpu:x
'. if the global device is not
set, it will return a string which is 'gpu:
x
' when cuda is avaliable or it
will return a string which is 'cpu' when cuda is not avaliable.
Examples:
...
...
@@ -173,5 +190,8 @@ def get_device():
elif
isinstance
(
place
,
core
.
CUDAPlace
):
device_id
=
place
.
get_device_id
()
device
=
'gpu:'
+
str
(
device_id
)
elif
isinstance
(
place
,
core
.
XPUPlace
):
device_id
=
place
.
get_device_id
()
device
=
'xpu:'
+
str
(
device_id
)
return
device
python/paddle/fluid/tests/unittests/test_device.py
浏览文件 @
9a2a4b5f
...
...
@@ -51,6 +51,19 @@ class TestStaticDeviceManage(unittest.TestCase):
self
.
assertEqual
(
isinstance
(
exe
.
place
,
core
.
CUDAPlace
),
True
)
self
.
assertEqual
(
device
,
"gpu:0"
)
def
test_xpu_device
(
self
):
if
core
.
is_compiled_with_xpu
():
out1
=
paddle
.
zeros
(
shape
=
[
1
,
3
],
dtype
=
'float32'
)
out2
=
paddle
.
ones
(
shape
=
[
1
,
3
],
dtype
=
'float32'
)
out3
=
paddle
.
concat
(
x
=
[
out1
,
out2
],
axis
=
0
)
paddle
.
set_device
(
'xpu:0'
)
exe
=
paddle
.
fluid
.
Executor
()
exe
.
run
(
paddle
.
fluid
.
default_startup_program
())
res
=
exe
.
run
(
fetch_list
=
[
out3
])
device
=
paddle
.
get_device
()
self
.
assertEqual
(
isinstance
(
exe
.
place
,
core
.
XPUPlace
),
True
)
self
.
assertEqual
(
device
,
"xpu:0"
)
class
TestImperativeDeviceManage
(
unittest
.
TestCase
):
def
test_cpu
(
self
):
...
...
@@ -78,6 +91,17 @@ class TestImperativeDeviceManage(unittest.TestCase):
core
.
CUDAPlace
),
True
)
self
.
assertEqual
(
device
,
"gpu:0"
)
def
test_xpu
(
self
):
if
core
.
is_compiled_with_xpu
():
with
fluid
.
dygraph
.
guard
():
out
=
paddle
.
to_tensor
([
1
,
2
])
device
=
paddle
.
get_device
()
self
.
assertEqual
(
isinstance
(
framework
.
_current_expected_place
(),
core
.
XPUPlace
),
True
)
self
.
assertTrue
(
out
.
place
.
is_xpu_place
())
self
.
assertEqual
(
device
,
"xpu:0"
)
if
__name__
==
'__main__'
:
unittest
.
main
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录