Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Crayon鑫
Paddle
提交
5f7e4a21
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看板
未验证
提交
5f7e4a21
编写于
12月 27, 2021
作者:
S
sneaxiy
提交者:
GitHub
12月 27, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refine CUDA Graph (#38401)
上级
89d38f55
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
37 addition
and
52 deletion
+37
-52
python/paddle/device/cuda/graphs.py
python/paddle/device/cuda/graphs.py
+37
-52
未找到文件。
python/paddle/device/cuda/graphs.py
浏览文件 @
5f7e4a21
...
...
@@ -17,56 +17,41 @@ from paddle.fluid.core import is_compiled_with_cuda, is_compiled_with_rocm, CUDA
if
is_compiled_with_cuda
()
and
not
is_compiled_with_rocm
():
from
paddle.fluid.core
import
CUDAGraph
as
CoreCUDAGraph
class
CUDAGraph
:
def
__init__
(
self
,
place
=
None
,
mode
=
"thread_local"
):
ALL_MODES
=
[
"global"
,
"thread_local"
,
"relaxed"
]
self
.
_graph
=
None
if
place
is
None
:
device_id
=
int
(
os
.
environ
.
get
(
'FLAGS_selected_gpus'
,
0
))
place
=
CUDAPlace
(
device_id
)
self
.
_place
=
place
assert
mode
in
ALL_MODES
self
.
_mode
=
ALL_MODES
.
index
(
mode
)
def
capture_begin
(
self
):
CoreCUDAGraph
.
begin_capture
(
self
.
_place
,
self
.
_mode
)
def
capture_end
(
self
):
self
.
_graph
=
CoreCUDAGraph
.
end_capture
()
def
replay
(
self
):
self
.
_graph
.
replay
()
def
reset
(
self
):
self
.
_graph
.
reset
()
def
print_to_dot_files
(
self
,
dirname
,
flags
=
None
):
if
not
isinstance
(
dirname
,
(
str
,
bytes
)):
dirname
=
dirname
.
name
os
.
makedirs
(
name
=
dirname
,
exist_ok
=
True
)
assert
os
.
path
.
isdir
(
dirname
),
"The dirname {} should be a directory"
.
format
(
dirname
)
if
flags
is
None
:
flags
=
2047
# only all information. It can be any integer inside [1, 2048)
self
.
_graph
.
print_to_dot_files
(
dirname
,
flags
)
else
:
class
CUDAGraph
:
def
__init__
(
self
,
place
=
None
,
mode
=
"thread_local"
):
raise
NotImplementedError
()
def
capture_begin
(
self
):
raise
NotImplementedError
()
def
capture_end
(
self
):
raise
NotImplementedError
()
def
replay
(
self
):
raise
NotImplementedError
()
def
reset
(
self
):
raise
NotImplementedError
()
def
print_to_dot_files
(
self
,
dirname
,
flags
=
None
):
raise
NotImplementedError
()
CoreCUDAGraph
=
None
class
CUDAGraph
:
def
__init__
(
self
,
place
=
None
,
mode
=
"thread_local"
):
assert
CoreCUDAGraph
is
not
None
,
"CUDA Graph is only supported on PaddlePaddle compiled with NVIDIA GPU."
ALL_MODES
=
[
"global"
,
"thread_local"
,
"relaxed"
]
self
.
_graph
=
None
if
place
is
None
:
device_id
=
int
(
os
.
environ
.
get
(
'FLAGS_selected_gpus'
,
0
))
place
=
CUDAPlace
(
device_id
)
self
.
_place
=
place
assert
mode
in
ALL_MODES
self
.
_mode
=
ALL_MODES
.
index
(
mode
)
def
capture_begin
(
self
):
CoreCUDAGraph
.
begin_capture
(
self
.
_place
,
self
.
_mode
)
def
capture_end
(
self
):
self
.
_graph
=
CoreCUDAGraph
.
end_capture
()
def
replay
(
self
):
self
.
_graph
.
replay
()
def
reset
(
self
):
self
.
_graph
.
reset
()
def
print_to_dot_files
(
self
,
dirname
,
flags
=
None
):
if
not
isinstance
(
dirname
,
(
str
,
bytes
)):
dirname
=
dirname
.
name
os
.
makedirs
(
name
=
dirname
,
exist_ok
=
True
)
assert
os
.
path
.
isdir
(
dirname
),
"The dirname {} should be a directory"
.
format
(
dirname
)
if
flags
is
None
:
flags
=
2047
# only all information. It can be any integer inside [1, 2048)
self
.
_graph
.
print_to_dot_files
(
dirname
,
flags
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录