Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
44acc751
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看板
提交
44acc751
编写于
9月 12, 2017
作者:
T
tensor-tang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add python interface for mkldnn_conv
上级
c39b771a
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
17 addition
and
3 deletion
+17
-3
python/paddle/trainer/config_parser.py
python/paddle/trainer/config_parser.py
+17
-3
未找到文件。
python/paddle/trainer/config_parser.py
浏览文件 @
44acc751
...
@@ -2054,20 +2054,29 @@ class ConvLayerBase(LayerBase):
...
@@ -2054,20 +2054,29 @@ class ConvLayerBase(LayerBase):
if
num_filters
is
not
None
:
if
num_filters
is
not
None
:
self
.
config
.
num_filters
=
num_filters
self
.
config
.
num_filters
=
num_filters
use_mkldnn
=
int
(
g_command_config_args
.
get
(
"use_mkldnn"
,
0
))
use_gpu
=
int
(
g_command_config_args
.
get
(
"use_gpu"
,
0
))
use_gpu
=
int
(
g_command_config_args
.
get
(
"use_gpu"
,
0
))
parallel_nn
=
int
(
g_command_config_args
.
get
(
"parallel_nn"
,
0
))
parallel_nn
=
int
(
g_command_config_args
.
get
(
"parallel_nn"
,
0
))
# Automatically select cudnn_type for GPU and exconv for CPU
# Automatically select cudnn_type for GPU, exconv for CPU
# and mkldnn_conv for MKLDNN
# if set type=conv, but still reserve the way user specify
# if set type=conv, but still reserve the way user specify
# exconv or cudnn_conv manually.
# exconv
, mkldnn_conv
or cudnn_conv manually.
if
self
.
layer_type
==
"cudnn_conv"
:
if
self
.
layer_type
==
"cudnn_conv"
:
config_assert
(
use_gpu
,
"cudnn_conv only support GPU"
)
config_assert
(
use_gpu
,
"cudnn_conv only support GPU"
)
if
self
.
layer_type
==
"mkldnn_conv"
:
config_assert
(
use_mkldnn
,
"mkldnn_conv only support MKLDNN"
)
if
(
use_gpu
==
1
and
self
.
layer_type
!=
"exconv"
and
if
(
use_gpu
==
1
and
self
.
layer_type
!=
"exconv"
and
self
.
layer_type
!=
"mkldnn_conv"
and
(
parallel_nn
==
0
or
self
.
config
.
device
>
-
1
)):
(
parallel_nn
==
0
or
self
.
config
.
device
>
-
1
)):
self
.
layer_type
=
"cudnn_conv"
self
.
layer_type
=
"cudnn_conv"
else
:
else
:
self
.
layer_type
=
"exconv"
if
(
use_mkldnn
==
1
):
self
.
layer_type
=
"mkldnn_conv"
else
:
self
.
layer_type
=
"exconv"
# need to specify layer in config
# need to specify layer in config
self
.
config
.
type
=
self
.
layer_type
self
.
config
.
type
=
self
.
layer_type
...
@@ -2099,6 +2108,11 @@ class ConvLayer(ConvLayerBase):
...
@@ -2099,6 +2108,11 @@ class ConvLayer(ConvLayerBase):
layer_type
=
'exconv'
layer_type
=
'exconv'
@
config_layer
(
'mkldnn_conv'
)
class
ConvLayer
(
ConvLayerBase
):
layer_type
=
'mkldnn_conv'
@
config_layer
(
'cudnn_conv'
)
@
config_layer
(
'cudnn_conv'
)
class
ConvLayer
(
ConvLayerBase
):
class
ConvLayer
(
ConvLayerBase
):
layer_type
=
'cudnn_conv'
layer_type
=
'cudnn_conv'
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录