Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
a475a57d
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看板
提交
a475a57d
编写于
8月 10, 2017
作者:
T
tensor-tang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
rename files and classes, use uppercase of Mkldnn and Cpu
上级
b2bd6713
变更
9
显示空白变更内容
内联
并排
Showing
9 changed file
with
83 addition
and
83 deletion
+83
-83
paddle/gserver/CMakeLists.txt
paddle/gserver/CMakeLists.txt
+4
-4
paddle/gserver/layers/MKLDNNBase.h
paddle/gserver/layers/MKLDNNBase.h
+13
-13
paddle/gserver/layers/MKLDNNFcLayer.cpp
paddle/gserver/layers/MKLDNNFcLayer.cpp
+11
-11
paddle/gserver/layers/MKLDNNFcLayer.h
paddle/gserver/layers/MKLDNNFcLayer.h
+6
-6
paddle/gserver/layers/MKLDNNLayer.h
paddle/gserver/layers/MKLDNNLayer.h
+11
-11
paddle/gserver/tests/CMakeLists.txt
paddle/gserver/tests/CMakeLists.txt
+4
-4
paddle/gserver/tests/MKLDNNTester.cpp
paddle/gserver/tests/MKLDNNTester.cpp
+27
-27
paddle/gserver/tests/MKLDNNTester.h
paddle/gserver/tests/MKLDNNTester.h
+4
-4
paddle/gserver/tests/test_MKLDNN.cpp
paddle/gserver/tests/test_MKLDNN.cpp
+3
-3
未找到文件。
paddle/gserver/CMakeLists.txt
浏览文件 @
a475a57d
...
@@ -25,13 +25,13 @@ filter_test(GSERVER_HEADER)
...
@@ -25,13 +25,13 @@ filter_test(GSERVER_HEADER)
filter_test
(
GSERVER_SOURCES
)
filter_test
(
GSERVER_SOURCES
)
if
(
NOT WITH_MKLDNN
)
if
(
NOT WITH_MKLDNN
)
file
(
GLOB_RECURSE DNN_HEADER RELATIVE
"
${
CMAKE_CURRENT_SOURCE_DIR
}
"
"M
kldnn
*.h"
)
file
(
GLOB_RECURSE DNN_HEADER RELATIVE
"
${
CMAKE_CURRENT_SOURCE_DIR
}
"
"M
KLDNN
*.h"
)
file
(
GLOB_RECURSE DNN_SOURCES RELATIVE
"
${
CMAKE_CURRENT_SOURCE_DIR
}
"
"M
kldnn
*.cpp"
)
file
(
GLOB_RECURSE DNN_SOURCES RELATIVE
"
${
CMAKE_CURRENT_SOURCE_DIR
}
"
"M
KLDNN
*.cpp"
)
list
(
REMOVE_ITEM GSERVER_HEADER
${
DNN_HEADER
}
)
list
(
REMOVE_ITEM GSERVER_HEADER
${
DNN_HEADER
}
)
list
(
REMOVE_ITEM GSERVER_SOURCES
${
DNN_SOURCES
}
)
list
(
REMOVE_ITEM GSERVER_SOURCES
${
DNN_SOURCES
}
)
message
(
STATUS
"Skip compiling with M
kldnnlayers and Mkldnn
Activations"
)
message
(
STATUS
"Skip compiling with M
KLDNNLayers and MKLDNN
Activations"
)
else
()
else
()
message
(
STATUS
"Compile with M
kldnnlayers and Mkldnn
Activations"
)
message
(
STATUS
"Compile with M
KLDNNLayers and MKLDNN
Activations"
)
endif
()
endif
()
if
(
NOT WITH_GPU
)
if
(
NOT WITH_GPU
)
...
...
paddle/gserver/layers/M
kldnn
Base.h
→
paddle/gserver/layers/M
KLDNN
Base.h
浏览文件 @
a475a57d
...
@@ -30,26 +30,26 @@ typedef enum {
...
@@ -30,26 +30,26 @@ typedef enum {
* @brief MKLDNN CPU engine.
* @brief MKLDNN CPU engine.
*
*
*/
*/
class
C
pu
Engine
{
class
C
PU
Engine
{
public:
public:
static
C
pu
Engine
&
Instance
()
{
static
C
PU
Engine
&
Instance
()
{
// Thread-safe in C++11.
// Thread-safe in C++11.
static
C
pu
Engine
myInstance
;
static
C
PU
Engine
myInstance
;
return
myInstance
;
return
myInstance
;
}
}
// Disallow copy or move
// Disallow copy or move
C
puEngine
(
const
Cpu
Engine
&
)
=
delete
;
// Copy constructor
C
PUEngine
(
const
CPU
Engine
&
)
=
delete
;
// Copy constructor
C
puEngine
(
Cpu
Engine
&&
)
=
delete
;
// Move constructor
C
PUEngine
(
CPU
Engine
&&
)
=
delete
;
// Move constructor
C
puEngine
&
operator
=
(
const
Cpu
Engine
&
)
=
delete
;
// Copy assignment
C
PUEngine
&
operator
=
(
const
CPU
Engine
&
)
=
delete
;
// Copy assignment
C
puEngine
&
operator
=
(
Cpu
Engine
&&
)
=
delete
;
// Move assignment
C
PUEngine
&
operator
=
(
CPU
Engine
&&
)
=
delete
;
// Move assignment
mkldnn
::
engine
&
getEngine
()
{
return
cpuEngine_
;
}
mkldnn
::
engine
&
getEngine
()
{
return
cpuEngine_
;
}
protected:
protected:
C
pu
Engine
()
:
cpuEngine_
(
mkldnn
::
engine
::
cpu
,
0
)
{}
C
PU
Engine
()
:
cpuEngine_
(
mkldnn
::
engine
::
cpu
,
0
)
{}
// C
pu
Engine() : cpuEngine_(mkldnn::engine::cpu_lazy, 0) {}
// C
PU
Engine() : cpuEngine_(mkldnn::engine::cpu_lazy, 0) {}
~
C
pu
Engine
()
{}
~
C
PU
Engine
()
{}
private:
private:
mkldnn
::
engine
cpuEngine_
;
mkldnn
::
engine
cpuEngine_
;
...
@@ -59,11 +59,11 @@ private:
...
@@ -59,11 +59,11 @@ private:
* @brief MKLDNN Stream.
* @brief MKLDNN Stream.
*
*
*/
*/
class
M
kldnn
Stream
{
class
M
KLDNN
Stream
{
public:
public:
M
kldnn
Stream
()
:
ready_
(
false
)
{
resetState
();
}
M
KLDNN
Stream
()
:
ready_
(
false
)
{
resetState
();
}
virtual
~
M
kldnn
Stream
()
{}
virtual
~
M
KLDNN
Stream
()
{}
/**
/**
* @brief Submit stream
* @brief Submit stream
...
...
paddle/gserver/layers/M
kldnn
FcLayer.cpp
→
paddle/gserver/layers/M
KLDNN
FcLayer.cpp
浏览文件 @
a475a57d
...
@@ -12,7 +12,7 @@ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
...
@@ -12,7 +12,7 @@ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
See the License for the specific language governing permissions and
limitations under the License. */
limitations under the License. */
#include "M
kldnn
FcLayer.h"
#include "M
KLDNN
FcLayer.h"
#include "paddle/utils/Logging.h"
#include "paddle/utils/Logging.h"
#include "paddle/utils/Stat.h"
#include "paddle/utils/Stat.h"
...
@@ -24,11 +24,11 @@ typedef inner_product_backward_data fc_bwdData;
...
@@ -24,11 +24,11 @@ typedef inner_product_backward_data fc_bwdData;
namespace
paddle
{
namespace
paddle
{
REGISTER_LAYER
(
mkldnn_fc
,
M
kldnn
FcLayer
);
REGISTER_LAYER
(
mkldnn_fc
,
M
KLDNN
FcLayer
);
bool
M
kldnn
FcLayer
::
init
(
const
LayerMap
&
layerMap
,
bool
M
KLDNN
FcLayer
::
init
(
const
LayerMap
&
layerMap
,
const
ParameterMap
&
parameterMap
)
{
const
ParameterMap
&
parameterMap
)
{
if
(
!
M
kldnn
Layer
::
init
(
layerMap
,
parameterMap
))
{
if
(
!
M
KLDNN
Layer
::
init
(
layerMap
,
parameterMap
))
{
return
false
;
return
false
;
}
}
...
@@ -56,7 +56,7 @@ bool MkldnnFcLayer::init(const LayerMap& layerMap,
...
@@ -56,7 +56,7 @@ bool MkldnnFcLayer::init(const LayerMap& layerMap,
return
true
;
return
true
;
}
}
void
M
kldnn
FcLayer
::
convertWeightsFromPaddle
()
{
void
M
KLDNN
FcLayer
::
convertWeightsFromPaddle
()
{
if
(
FLAGS_use_mkldnn_wgt
)
{
if
(
FLAGS_use_mkldnn_wgt
)
{
return
;
return
;
}
}
...
@@ -81,7 +81,7 @@ void MkldnnFcLayer::convertWeightsFromPaddle() {
...
@@ -81,7 +81,7 @@ void MkldnnFcLayer::convertWeightsFromPaddle() {
hasInitedWgt_
=
true
;
hasInitedWgt_
=
true
;
}
}
void
M
kldnn
FcLayer
::
convertWeightsToPaddle
()
{
void
M
KLDNN
FcLayer
::
convertWeightsToPaddle
()
{
MatrixPtr
dnnWgt
=
weight_
->
getW
();
MatrixPtr
dnnWgt
=
weight_
->
getW
();
MatrixPtr
paddleWgt
;
MatrixPtr
paddleWgt
;
dnnWgt
->
transpose
(
paddleWgt
,
true
);
dnnWgt
->
transpose
(
paddleWgt
,
true
);
...
@@ -92,7 +92,7 @@ void MkldnnFcLayer::convertWeightsToPaddle() {
...
@@ -92,7 +92,7 @@ void MkldnnFcLayer::convertWeightsToPaddle() {
dnnWgtT
->
copyFrom
(
*
paddleWgt
);
dnnWgtT
->
copyFrom
(
*
paddleWgt
);
}
}
void
M
kldnn
FcLayer
::
reshape
()
{
void
M
KLDNN
FcLayer
::
reshape
()
{
const
Argument
&
input
=
getInput
(
0
);
const
Argument
&
input
=
getInput
(
0
);
int
batchSize
=
input
.
getBatchSize
();
int
batchSize
=
input
.
getBatchSize
();
if
(
bs_
==
batchSize
)
{
if
(
bs_
==
batchSize
)
{
...
@@ -129,7 +129,7 @@ void MkldnnFcLayer::reshape() {
...
@@ -129,7 +129,7 @@ void MkldnnFcLayer::reshape() {
convertWeightsFromPaddle
();
convertWeightsFromPaddle
();
}
}
void
M
kldnn
FcLayer
::
resetFwd
()
{
void
M
KLDNN
FcLayer
::
resetFwd
()
{
bool
hasBias
=
biases_
&&
biases_
->
getW
();
bool
hasBias
=
biases_
&&
biases_
->
getW
();
real
*
iData
=
getInputValue
(
0
)
->
getData
();
real
*
iData
=
getInputValue
(
0
)
->
getData
();
real
*
oData
=
getOutputValue
()
->
getData
();
real
*
oData
=
getOutputValue
()
->
getData
();
...
@@ -166,7 +166,7 @@ void MkldnnFcLayer::resetFwd() {
...
@@ -166,7 +166,7 @@ void MkldnnFcLayer::resetFwd() {
pipelineFwd_
.
push_back
(
*
fwd_
);
pipelineFwd_
.
push_back
(
*
fwd_
);
}
}
void
M
kldnn
FcLayer
::
resetBwd
()
{
void
M
KLDNN
FcLayer
::
resetBwd
()
{
if
(
!
needResetBwd_
)
{
if
(
!
needResetBwd_
)
{
return
;
return
;
}
}
...
@@ -231,7 +231,7 @@ void MkldnnFcLayer::resetBwd() {
...
@@ -231,7 +231,7 @@ void MkldnnFcLayer::resetBwd() {
pipelineBwd_
.
push_back
(
*
bwdData_
);
pipelineBwd_
.
push_back
(
*
bwdData_
);
}
}
void
M
kldnn
FcLayer
::
forward
(
PassType
passType
)
{
void
M
KLDNN
FcLayer
::
forward
(
PassType
passType
)
{
Layer
::
forward
(
passType
);
Layer
::
forward
(
passType
);
reshape
();
reshape
();
...
@@ -253,7 +253,7 @@ void MkldnnFcLayer::forward(PassType passType) {
...
@@ -253,7 +253,7 @@ void MkldnnFcLayer::forward(PassType passType) {
}
}
}
}
void
M
kldnn
FcLayer
::
backward
(
const
UpdateCallback
&
callback
)
{
void
M
KLDNN
FcLayer
::
backward
(
const
UpdateCallback
&
callback
)
{
/* Do derivation */
{
/* Do derivation */
{
REGISTER_TIMER_INFO
(
"BpActTimer"
,
getName
().
c_str
());
REGISTER_TIMER_INFO
(
"BpActTimer"
,
getName
().
c_str
());
backwardActivation
();
backwardActivation
();
...
...
paddle/gserver/layers/M
kldnn
FcLayer.h
→
paddle/gserver/layers/M
KLDNN
FcLayer.h
浏览文件 @
a475a57d
...
@@ -14,17 +14,17 @@ limitations under the License. */
...
@@ -14,17 +14,17 @@ limitations under the License. */
#pragma once
#pragma once
#include "M
kldnn
Layer.h"
#include "M
KLDNN
Layer.h"
#include "mkldnn.hpp"
#include "mkldnn.hpp"
namespace
paddle
{
namespace
paddle
{
/**
/**
* @brief A subclass of M
kldnn
Layer fc layer.
* @brief A subclass of M
KLDNN
Layer fc layer.
*
*
* The config file api is mkldnn_fc
* The config file api is mkldnn_fc
*/
*/
class
M
kldnnFcLayer
:
public
Mkldnn
Layer
{
class
M
KLDNNFcLayer
:
public
MKLDNN
Layer
{
protected:
protected:
// input layer size, can not be change after init
// input layer size, can not be change after init
size_t
iLayerSize_
;
// == ic * ih * iw
size_t
iLayerSize_
;
// == ic * ih * iw
...
@@ -37,10 +37,10 @@ protected:
...
@@ -37,10 +37,10 @@ protected:
std
::
unique_ptr
<
Weight
>
biases_
;
std
::
unique_ptr
<
Weight
>
biases_
;
public:
public:
explicit
M
kldnn
FcLayer
(
const
LayerConfig
&
config
)
explicit
M
KLDNN
FcLayer
(
const
LayerConfig
&
config
)
:
M
kldnn
Layer
(
config
),
hasInitedWgt_
(
false
),
hasSpatial_
(
true
)
{}
:
M
KLDNN
Layer
(
config
),
hasInitedWgt_
(
false
),
hasSpatial_
(
true
)
{}
~
M
kldnn
FcLayer
()
{}
~
M
KLDNN
FcLayer
()
{}
bool
init
(
const
LayerMap
&
layerMap
,
bool
init
(
const
LayerMap
&
layerMap
,
const
ParameterMap
&
parameterMap
)
override
;
const
ParameterMap
&
parameterMap
)
override
;
...
...
paddle/gserver/layers/M
kldnn
Layer.h
→
paddle/gserver/layers/M
KLDNN
Layer.h
浏览文件 @
a475a57d
...
@@ -16,7 +16,7 @@ limitations under the License. */
...
@@ -16,7 +16,7 @@ limitations under the License. */
#include <vector>
#include <vector>
#include "Layer.h"
#include "Layer.h"
#include "M
kldnn
Base.h"
#include "M
KLDNN
Base.h"
#include "mkldnn.hpp"
#include "mkldnn.hpp"
DECLARE_bool
(
use_mkldnn
);
DECLARE_bool
(
use_mkldnn
);
...
@@ -24,14 +24,14 @@ DECLARE_bool(use_mkldnn_wgt);
...
@@ -24,14 +24,14 @@ DECLARE_bool(use_mkldnn_wgt);
namespace
paddle
{
namespace
paddle
{
class
M
kldnn
Layer
;
class
M
KLDNN
Layer
;
typedef
std
::
shared_ptr
<
M
kldnnLayer
>
Mkldnn
LayerPtr
;
typedef
std
::
shared_ptr
<
M
KLDNNLayer
>
MKLDNN
LayerPtr
;
/**
/**
* @brief Base class of M
kldnn
layer.
* @brief Base class of M
KLDNN
layer.
*
*
*/
*/
class
M
kldnn
Layer
:
public
Layer
{
class
M
KLDNN
Layer
:
public
Layer
{
protected:
protected:
// batch size
// batch size
int
bs_
;
int
bs_
;
...
@@ -45,14 +45,14 @@ protected:
...
@@ -45,14 +45,14 @@ protected:
// mkldnn engine, stream and primivtives
// mkldnn engine, stream and primivtives
mkldnn
::
engine
engine_
;
mkldnn
::
engine
engine_
;
std
::
shared_ptr
<
M
kldnn
Stream
>
stream_
;
std
::
shared_ptr
<
M
KLDNN
Stream
>
stream_
;
std
::
shared_ptr
<
mkldnn
::
primitive
>
fwd_
;
std
::
shared_ptr
<
mkldnn
::
primitive
>
fwd_
;
std
::
shared_ptr
<
mkldnn
::
primitive
>
bwdWgt_
;
std
::
shared_ptr
<
mkldnn
::
primitive
>
bwdWgt_
;
std
::
shared_ptr
<
mkldnn
::
primitive
>
bwdData_
;
std
::
shared_ptr
<
mkldnn
::
primitive
>
bwdData_
;
std
::
vector
<
mkldnn
::
primitive
>
pipelineFwd_
;
std
::
vector
<
mkldnn
::
primitive
>
pipelineFwd_
;
std
::
vector
<
mkldnn
::
primitive
>
pipelineBwd_
;
std
::
vector
<
mkldnn
::
primitive
>
pipelineBwd_
;
// TODO(TJ): change below memory as M
kldnn
MatrixPtr type
// TODO(TJ): change below memory as M
KLDNN
MatrixPtr type
std
::
shared_ptr
<
mkldnn
::
memory
>
inVal_
;
std
::
shared_ptr
<
mkldnn
::
memory
>
inVal_
;
std
::
shared_ptr
<
mkldnn
::
memory
>
inGrad_
;
std
::
shared_ptr
<
mkldnn
::
memory
>
inGrad_
;
std
::
shared_ptr
<
mkldnn
::
memory
>
outVal_
;
std
::
shared_ptr
<
mkldnn
::
memory
>
outVal_
;
...
@@ -63,7 +63,7 @@ protected:
...
@@ -63,7 +63,7 @@ protected:
std
::
shared_ptr
<
mkldnn
::
memory
>
biasGrad_
;
std
::
shared_ptr
<
mkldnn
::
memory
>
biasGrad_
;
public:
public:
explicit
M
kldnn
Layer
(
const
LayerConfig
&
config
)
explicit
M
KLDNN
Layer
(
const
LayerConfig
&
config
)
:
Layer
(
config
),
:
Layer
(
config
),
bs_
(
0
),
bs_
(
0
),
ic_
(
0
),
ic_
(
0
),
...
@@ -79,7 +79,7 @@ public:
...
@@ -79,7 +79,7 @@ public:
bwdWgt_
(
nullptr
),
bwdWgt_
(
nullptr
),
bwdData_
(
nullptr
)
{}
bwdData_
(
nullptr
)
{}
~
M
kldnn
Layer
()
{}
~
M
KLDNN
Layer
()
{}
virtual
bool
init
(
const
LayerMap
&
layerMap
,
virtual
bool
init
(
const
LayerMap
&
layerMap
,
const
ParameterMap
&
parameterMap
)
{
const
ParameterMap
&
parameterMap
)
{
...
@@ -90,8 +90,8 @@ public:
...
@@ -90,8 +90,8 @@ public:
CHECK
(
FLAGS_use_mkldnn
)
<<
"MkldnnLayers only support use_mkldnn."
CHECK
(
FLAGS_use_mkldnn
)
<<
"MkldnnLayers only support use_mkldnn."
<<
"Please set WITH_MKLDNN=ON "
<<
"Please set WITH_MKLDNN=ON "
<<
"and set use_mkldnn=True"
;
<<
"and set use_mkldnn=True"
;
stream_
.
reset
(
new
M
kldnn
Stream
());
stream_
.
reset
(
new
M
KLDNN
Stream
());
engine_
=
C
pu
Engine
::
Instance
().
getEngine
();
engine_
=
C
PU
Engine
::
Instance
().
getEngine
();
// TODO(TJ): deivecId
// TODO(TJ): deivecId
return
true
;
return
true
;
...
...
paddle/gserver/tests/CMakeLists.txt
浏览文件 @
a475a57d
...
@@ -20,11 +20,11 @@ add_test(NAME test_LayerGrad
...
@@ -20,11 +20,11 @@ add_test(NAME test_LayerGrad
########## test_Mkldnn layers and activations ##########
########## test_Mkldnn layers and activations ##########
if
(
WITH_MKLDNN
)
if
(
WITH_MKLDNN
)
add_unittest_without_exec
(
test_M
kldnn
add_unittest_without_exec
(
test_M
KLDNN
test_M
kldnn
.cpp
test_M
KLDNN
.cpp
M
kldnn
Tester.cpp
M
KLDNN
Tester.cpp
LayerGradUtil.cpp
)
LayerGradUtil.cpp
)
add_test
(
NAME test_M
kldnn COMMAND test_Mkldnn
)
add_test
(
NAME test_M
KLDNN COMMAND test_MKLDNN
)
endif
()
endif
()
################ test_CRFLayerGrad ####################
################ test_CRFLayerGrad ####################
...
...
paddle/gserver/tests/M
kldnn
Tester.cpp
→
paddle/gserver/tests/M
KLDNN
Tester.cpp
浏览文件 @
a475a57d
...
@@ -12,14 +12,14 @@ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
...
@@ -12,14 +12,14 @@ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
See the License for the specific language governing permissions and
limitations under the License. */
limitations under the License. */
#include "M
kldnn
Tester.h"
#include "M
KLDNN
Tester.h"
#include "paddle/gserver/layers/M
kldnn
Base.h"
#include "paddle/gserver/layers/M
KLDNN
Base.h"
#include "paddle/gserver/layers/M
kldnn
Layer.h"
#include "paddle/gserver/layers/M
KLDNN
Layer.h"
namespace
paddle
{
namespace
paddle
{
// init data layer and test layer of both dnn and reference
// init data layer and test layer of both dnn and reference
void
M
kldnn
Tester
::
reset
(
const
TestConfig
&
dnn
,
void
M
KLDNN
Tester
::
reset
(
const
TestConfig
&
dnn
,
const
TestConfig
&
ref
,
const
TestConfig
&
ref
,
size_t
batchSize
)
{
size_t
batchSize
)
{
const
bool
trans
=
false
;
const
bool
trans
=
false
;
...
@@ -71,7 +71,7 @@ void MkldnnTester::reset(const TestConfig& dnn,
...
@@ -71,7 +71,7 @@ void MkldnnTester::reset(const TestConfig& dnn,
setInputImgSize
();
setInputImgSize
();
}
}
void
M
kldnn
Tester
::
setInputImgSize
()
{
void
M
KLDNN
Tester
::
setInputImgSize
()
{
for
(
size_t
n
=
0
;
n
<
dataLayers_
.
size
();
++
n
)
{
for
(
size_t
n
=
0
;
n
<
dataLayers_
.
size
();
++
n
)
{
for
(
size_t
i
=
0
;
i
<
dataLayers_
[
n
].
size
();
++
i
)
{
for
(
size_t
i
=
0
;
i
<
dataLayers_
[
n
].
size
();
++
i
)
{
// TODO(TJ): fix me when concat and elewise ready
// TODO(TJ): fix me when concat and elewise ready
...
@@ -82,7 +82,7 @@ void MkldnnTester::setInputImgSize() {
...
@@ -82,7 +82,7 @@ void MkldnnTester::setInputImgSize() {
}
}
// init randome parameters of ref, and copy to mkldnn
// init randome parameters of ref, and copy to mkldnn
void
M
kldnn
Tester
::
randomWgtDatas
()
{
void
M
KLDNN
Tester
::
randomWgtDatas
()
{
EXPECT_EQ
(
parameters_
[
DNN
].
size
(),
parameters_
[
REF
].
size
());
EXPECT_EQ
(
parameters_
[
DNN
].
size
(),
parameters_
[
REF
].
size
());
for
(
size_t
i
=
0
;
i
<
parameters_
[
REF
].
size
();
++
i
)
{
for
(
size_t
i
=
0
;
i
<
parameters_
[
REF
].
size
();
++
i
)
{
const
VectorPtr
&
dnnValue
=
parameters_
[
DNN
][
i
]
->
getBuf
(
PARAMETER_VALUE
);
const
VectorPtr
&
dnnValue
=
parameters_
[
DNN
][
i
]
->
getBuf
(
PARAMETER_VALUE
);
...
@@ -96,7 +96,7 @@ void MkldnnTester::randomWgtDatas() {
...
@@ -96,7 +96,7 @@ void MkldnnTester::randomWgtDatas() {
}
}
// random botdata of ref layer and copy same to mkldnn
// random botdata of ref layer and copy same to mkldnn
void
M
kldnn
Tester
::
randomBotDatas
()
{
void
M
KLDNN
Tester
::
randomBotDatas
()
{
CHECK_EQ
(
dataLayers_
.
size
(),
NUM
);
CHECK_EQ
(
dataLayers_
.
size
(),
NUM
);
for
(
size_t
i
=
0
;
i
<
dataLayers_
[
DNN
].
size
();
++
i
)
{
for
(
size_t
i
=
0
;
i
<
dataLayers_
[
DNN
].
size
();
++
i
)
{
dataLayers_
[
REF
][
i
]
->
getOutputValue
()
->
randomizeUniform
();
dataLayers_
[
REF
][
i
]
->
getOutputValue
()
->
randomizeUniform
();
...
@@ -107,14 +107,14 @@ void MkldnnTester::randomBotDatas() {
...
@@ -107,14 +107,14 @@ void MkldnnTester::randomBotDatas() {
}
}
}
}
void
M
kldnn
Tester
::
randomTopDiffs
()
{
void
M
KLDNN
Tester
::
randomTopDiffs
()
{
refLayer_
->
getOutputGrad
()
->
randomizeUniform
();
refLayer_
->
getOutputGrad
()
->
randomizeUniform
();
dnnLayer_
->
getOutputGrad
()
->
copyFrom
(
*
(
refLayer_
->
getOutputGrad
()));
dnnLayer_
->
getOutputGrad
()
->
copyFrom
(
*
(
refLayer_
->
getOutputGrad
()));
VLOG
(
lvl_
)
<<
"Random dom Backward Input, TopDiff: "
;
VLOG
(
lvl_
)
<<
"Random dom Backward Input, TopDiff: "
;
printMatrix
(
refLayer_
->
getOutputGrad
());
printMatrix
(
refLayer_
->
getOutputGrad
());
}
}
void
M
kldnn
Tester
::
checkForward
()
{
void
M
KLDNN
Tester
::
checkForward
()
{
printTopDatas
();
printTopDatas
();
double
delta
=
compareMatrix
(
testLayers_
[
DNN
]
->
getOutputValue
(),
double
delta
=
compareMatrix
(
testLayers_
[
DNN
]
->
getOutputValue
(),
testLayers_
[
REF
]
->
getOutputValue
());
testLayers_
[
REF
]
->
getOutputValue
());
...
@@ -122,7 +122,7 @@ void MkldnnTester::checkForward() {
...
@@ -122,7 +122,7 @@ void MkldnnTester::checkForward() {
EXPECT_LE
(
fabs
(
delta
),
eps_
);
EXPECT_LE
(
fabs
(
delta
),
eps_
);
}
}
void
M
kldnn
Tester
::
checkBackwardData
()
{
void
M
KLDNN
Tester
::
checkBackwardData
()
{
const
bool
isBN
=
dnnLayer_
->
getType
()
==
"mkldnn_batch_norm"
;
const
bool
isBN
=
dnnLayer_
->
getType
()
==
"mkldnn_batch_norm"
;
for
(
size_t
i
=
0
;
i
<
dataLayers_
[
DNN
].
size
();
++
i
)
{
for
(
size_t
i
=
0
;
i
<
dataLayers_
[
DNN
].
size
();
++
i
)
{
const
MatrixPtr
&
dnnDiff
=
dataLayers_
[
DNN
][
i
]
->
getOutputGrad
();
const
MatrixPtr
&
dnnDiff
=
dataLayers_
[
DNN
][
i
]
->
getOutputGrad
();
...
@@ -141,13 +141,13 @@ void MkldnnTester::checkBackwardData() {
...
@@ -141,13 +141,13 @@ void MkldnnTester::checkBackwardData() {
}
}
}
}
void
M
kldnn
Tester
::
checkBackwardWgts
()
{
void
M
KLDNN
Tester
::
checkBackwardWgts
()
{
CHECK_EQ
(
parameters_
[
DNN
].
size
(),
parameters_
[
REF
].
size
());
CHECK_EQ
(
parameters_
[
DNN
].
size
(),
parameters_
[
REF
].
size
());
vector
<
VectorPtr
>
dnnWgts
;
// used to temply save mkldnn weights
vector
<
VectorPtr
>
dnnWgts
;
// used to temply save mkldnn weights
saveWgt
(
parameters_
[
DNN
],
dnnWgts
);
saveWgt
(
parameters_
[
DNN
],
dnnWgts
);
const
M
kldnn
LayerPtr
dnnlayer
=
const
M
KLDNN
LayerPtr
dnnlayer
=
std
::
dynamic_pointer_cast
<
M
kldnn
Layer
>
(
dnnLayer_
);
std
::
dynamic_pointer_cast
<
M
KLDNN
Layer
>
(
dnnLayer_
);
CHECK
(
dnnlayer
);
CHECK
(
dnnlayer
);
dnnlayer
->
convertWeightsToPaddle
();
dnnlayer
->
convertWeightsToPaddle
();
for
(
size_t
i
=
0
;
i
<
parameters_
[
DNN
].
size
();
++
i
)
{
for
(
size_t
i
=
0
;
i
<
parameters_
[
DNN
].
size
();
++
i
)
{
...
@@ -166,7 +166,7 @@ void MkldnnTester::checkBackwardWgts() {
...
@@ -166,7 +166,7 @@ void MkldnnTester::checkBackwardWgts() {
restoreWgt
(
dnnWgts
,
parameters_
[
DNN
]);
restoreWgt
(
dnnWgts
,
parameters_
[
DNN
]);
}
}
void
M
kldnn
Tester
::
saveWgt
(
const
vector
<
ParameterPtr
>&
from
,
void
M
KLDNN
Tester
::
saveWgt
(
const
vector
<
ParameterPtr
>&
from
,
vector
<
VectorPtr
>&
to
)
{
vector
<
VectorPtr
>&
to
)
{
const
bool
useGpu
=
false
;
const
bool
useGpu
=
false
;
to
.
resize
(
from
.
size
());
to
.
resize
(
from
.
size
());
...
@@ -177,7 +177,7 @@ void MkldnnTester::saveWgt(const vector<ParameterPtr>& from,
...
@@ -177,7 +177,7 @@ void MkldnnTester::saveWgt(const vector<ParameterPtr>& from,
}
}
}
}
void
M
kldnn
Tester
::
restoreWgt
(
const
vector
<
VectorPtr
>&
from
,
void
M
KLDNN
Tester
::
restoreWgt
(
const
vector
<
VectorPtr
>&
from
,
vector
<
ParameterPtr
>&
to
)
{
vector
<
ParameterPtr
>&
to
)
{
CHECK_EQ
(
from
.
size
(),
to
.
size
());
CHECK_EQ
(
from
.
size
(),
to
.
size
());
for
(
size_t
i
=
0
;
i
<
from
.
size
();
++
i
)
{
for
(
size_t
i
=
0
;
i
<
from
.
size
();
++
i
)
{
...
@@ -187,7 +187,7 @@ void MkldnnTester::restoreWgt(const vector<VectorPtr>& from,
...
@@ -187,7 +187,7 @@ void MkldnnTester::restoreWgt(const vector<VectorPtr>& from,
}
}
// clear parameters grad
// clear parameters grad
void
M
kldnn
Tester
::
clearWgtDiffs
()
{
void
M
KLDNN
Tester
::
clearWgtDiffs
()
{
for
(
size_t
n
=
0
;
n
<
parameters_
.
size
();
++
n
)
{
for
(
size_t
n
=
0
;
n
<
parameters_
.
size
();
++
n
)
{
for
(
size_t
i
=
0
;
i
<
parameters_
[
n
].
size
();
++
i
)
{
for
(
size_t
i
=
0
;
i
<
parameters_
[
n
].
size
();
++
i
)
{
const
VectorPtr
&
grad
=
parameters_
[
n
][
i
]
->
getBuf
(
PARAMETER_GRADIENT
);
const
VectorPtr
&
grad
=
parameters_
[
n
][
i
]
->
getBuf
(
PARAMETER_GRADIENT
);
...
@@ -198,7 +198,7 @@ void MkldnnTester::clearWgtDiffs() {
...
@@ -198,7 +198,7 @@ void MkldnnTester::clearWgtDiffs() {
}
}
}
}
void
M
kldnn
Tester
::
clearBotDiffs
()
{
void
M
KLDNN
Tester
::
clearBotDiffs
()
{
// dnn and ref
// dnn and ref
for
(
size_t
n
=
0
;
n
<
dataLayers_
.
size
();
++
n
)
{
for
(
size_t
n
=
0
;
n
<
dataLayers_
.
size
();
++
n
)
{
// all inputs layers
// all inputs layers
...
@@ -208,7 +208,7 @@ void MkldnnTester::clearBotDiffs() {
...
@@ -208,7 +208,7 @@ void MkldnnTester::clearBotDiffs() {
}
}
}
}
void
M
kldnn
Tester
::
clearBotDiffs
(
int
n
)
{
void
M
KLDNN
Tester
::
clearBotDiffs
(
int
n
)
{
CHECK_LT
(
n
,
NUM
);
CHECK_LT
(
n
,
NUM
);
// all inputs layers
// all inputs layers
for
(
size_t
i
=
0
;
i
<
dataLayers_
[
n
].
size
();
++
i
)
{
for
(
size_t
i
=
0
;
i
<
dataLayers_
[
n
].
size
();
++
i
)
{
...
@@ -216,13 +216,13 @@ void MkldnnTester::clearBotDiffs(int n) {
...
@@ -216,13 +216,13 @@ void MkldnnTester::clearBotDiffs(int n) {
}
}
}
}
void
M
kldnn
Tester
::
clearTopDatas
()
{
void
M
KLDNN
Tester
::
clearTopDatas
()
{
for
(
size_t
i
=
0
;
i
<
testLayers_
.
size
();
++
i
)
{
for
(
size_t
i
=
0
;
i
<
testLayers_
.
size
();
++
i
)
{
testLayers_
[
i
]
->
getOutputValue
()
->
zeroMem
();
testLayers_
[
i
]
->
getOutputValue
()
->
zeroMem
();
}
}
}
}
void
M
kldnn
Tester
::
printTopDatas
()
{
void
M
KLDNN
Tester
::
printTopDatas
()
{
if
(
!
log_
)
{
if
(
!
log_
)
{
return
;
return
;
}
}
...
@@ -233,7 +233,7 @@ void MkldnnTester::printTopDatas() {
...
@@ -233,7 +233,7 @@ void MkldnnTester::printTopDatas() {
}
}
}
}
void
M
kldnn
Tester
::
printMatrix
(
const
MatrixPtr
&
m
)
{
void
M
KLDNN
Tester
::
printMatrix
(
const
MatrixPtr
&
m
)
{
if
(
!
log_
)
{
if
(
!
log_
)
{
return
;
return
;
}
}
...
@@ -243,7 +243,7 @@ void MkldnnTester::printMatrix(const MatrixPtr& m) {
...
@@ -243,7 +243,7 @@ void MkldnnTester::printMatrix(const MatrixPtr& m) {
VLOG
(
lvl_
)
<<
std
::
endl
<<
ostr
.
str
();
VLOG
(
lvl_
)
<<
std
::
endl
<<
ostr
.
str
();
}
}
void
M
kldnn
Tester
::
printVector
(
const
VectorPtr
&
v
)
{
void
M
KLDNN
Tester
::
printVector
(
const
VectorPtr
&
v
)
{
if
(
!
log_
)
{
if
(
!
log_
)
{
return
;
return
;
}
}
...
@@ -253,7 +253,7 @@ void MkldnnTester::printVector(const VectorPtr& v) {
...
@@ -253,7 +253,7 @@ void MkldnnTester::printVector(const VectorPtr& v) {
VLOG
(
lvl_
)
<<
std
::
endl
<<
ostr
.
str
();
VLOG
(
lvl_
)
<<
std
::
endl
<<
ostr
.
str
();
}
}
double
M
kldnn
Tester
::
getDelta
(
const
real
*
d1
,
double
M
KLDNN
Tester
::
getDelta
(
const
real
*
d1
,
const
real
*
d2
,
const
real
*
d2
,
size_t
len
,
size_t
len
,
const
float
failRate
,
const
float
failRate
,
...
@@ -280,17 +280,17 @@ double MkldnnTester::getDelta(const real* d1,
...
@@ -280,17 +280,17 @@ double MkldnnTester::getDelta(const real* d1,
return
(
failCnt
/
(
float
)
len
)
>
failRate
?
maxOut
:
delta
/
sum
;
return
(
failCnt
/
(
float
)
len
)
>
failRate
?
maxOut
:
delta
/
sum
;
}
}
double
M
kldnn
Tester
::
compareMatrix
(
const
MatrixPtr
&
m1
,
const
MatrixPtr
&
m2
)
{
double
M
KLDNN
Tester
::
compareMatrix
(
const
MatrixPtr
&
m1
,
const
MatrixPtr
&
m2
)
{
CHECK_EQ
(
m1
->
getElementCnt
(),
m2
->
getElementCnt
());
CHECK_EQ
(
m1
->
getElementCnt
(),
m2
->
getElementCnt
());
return
getDelta
(
m1
->
getData
(),
m2
->
getData
(),
m1
->
getElementCnt
());
return
getDelta
(
m1
->
getData
(),
m2
->
getData
(),
m1
->
getElementCnt
());
}
}
double
M
kldnn
Tester
::
compareVector
(
const
VectorPtr
&
v1
,
const
VectorPtr
&
v2
)
{
double
M
KLDNN
Tester
::
compareVector
(
const
VectorPtr
&
v1
,
const
VectorPtr
&
v2
)
{
CHECK_EQ
(
v1
->
getSize
(),
v2
->
getSize
());
CHECK_EQ
(
v1
->
getSize
(),
v2
->
getSize
());
return
getDelta
(
v1
->
getData
(),
v2
->
getData
(),
v1
->
getSize
());
return
getDelta
(
v1
->
getData
(),
v2
->
getData
(),
v1
->
getSize
());
}
}
void
M
kldnn
Tester
::
runOnce
()
{
void
M
KLDNN
Tester
::
runOnce
()
{
// test forward
// test forward
randomBotDatas
();
randomBotDatas
();
dnnLayer_
->
forward
(
PASS_TRAIN
);
dnnLayer_
->
forward
(
PASS_TRAIN
);
...
@@ -310,7 +310,7 @@ void MkldnnTester::runOnce() {
...
@@ -310,7 +310,7 @@ void MkldnnTester::runOnce() {
clearBotDiffs
(
REF
);
clearBotDiffs
(
REF
);
}
}
void
M
kldnn
Tester
::
run
(
const
TestConfig
&
dnn
,
void
M
KLDNN
Tester
::
run
(
const
TestConfig
&
dnn
,
const
TestConfig
&
ref
,
const
TestConfig
&
ref
,
size_t
batchSize
,
size_t
batchSize
,
size_t
inputImgH
,
size_t
inputImgH
,
...
...
paddle/gserver/tests/M
kldnn
Tester.h
→
paddle/gserver/tests/M
KLDNN
Tester.h
浏览文件 @
a475a57d
...
@@ -17,7 +17,7 @@ limitations under the License. */
...
@@ -17,7 +17,7 @@ limitations under the License. */
#include <string>
#include <string>
#include <vector>
#include <vector>
#include "LayerGradUtil.h"
#include "LayerGradUtil.h"
#include "paddle/gserver/layers/M
kldnn
Base.h"
#include "paddle/gserver/layers/M
KLDNN
Base.h"
namespace
paddle
{
namespace
paddle
{
...
@@ -25,7 +25,7 @@ namespace paddle {
...
@@ -25,7 +25,7 @@ namespace paddle {
* @brief test the functionality of Mkldnnlayers
* @brief test the functionality of Mkldnnlayers
* refer to paddle original function
* refer to paddle original function
*/
*/
class
M
kldnn
Tester
{
class
M
KLDNN
Tester
{
enum
{
enum
{
DNN
=
0
,
DNN
=
0
,
REF
=
1
,
REF
=
1
,
...
@@ -54,14 +54,14 @@ protected:
...
@@ -54,14 +54,14 @@ protected:
size_t
ih_
,
iw_
;
size_t
ih_
,
iw_
;
public:
public:
explicit
M
kldnn
Tester
(
size_t
iter
=
3
,
float
epsilon
=
1e-4
)
{
explicit
M
KLDNN
Tester
(
size_t
iter
=
3
,
float
epsilon
=
1e-4
)
{
iter_
=
iter
;
iter_
=
iter
;
eps_
=
epsilon
;
eps_
=
epsilon
;
log_
=
false
;
log_
=
false
;
lvl_
=
MKLDNN_ALL
;
lvl_
=
MKLDNN_ALL
;
}
}
~
M
kldnn
Tester
()
{}
~
M
KLDNN
Tester
()
{}
public:
public:
void
run
(
const
TestConfig
&
dnn
,
void
run
(
const
TestConfig
&
dnn
,
...
...
paddle/gserver/tests/test_M
kldnn
.cpp
→
paddle/gserver/tests/test_M
KLDNN
.cpp
浏览文件 @
a475a57d
...
@@ -15,7 +15,7 @@ limitations under the License. */
...
@@ -15,7 +15,7 @@ limitations under the License. */
#include <gtest/gtest.h>
#include <gtest/gtest.h>
#include <string>
#include <string>
#include <vector>
#include <vector>
#include "M
kldnn
Tester.h"
#include "M
KLDNN
Tester.h"
#include "ModelConfig.pb.h"
#include "ModelConfig.pb.h"
using
namespace
paddle
;
// NOLINT
using
namespace
paddle
;
// NOLINT
...
@@ -43,7 +43,7 @@ void testFcLayer(const testFCDesc& pm) {
...
@@ -43,7 +43,7 @@ void testFcLayer(const testFCDesc& pm) {
/* size of weight= */
size_t
(
pm
.
oc
*
pm
.
ic
*
pm
.
ih
*
pm
.
iw
)});
/* size of weight= */
size_t
(
pm
.
oc
*
pm
.
ic
*
pm
.
ih
*
pm
.
iw
)});
cfg
.
layerConfig
.
add_inputs
();
cfg
.
layerConfig
.
add_inputs
();
M
kldnn
Tester
tester
;
M
KLDNN
Tester
tester
;
for
(
auto
biasSize
:
{
pm
.
oc
,
0
})
{
for
(
auto
biasSize
:
{
pm
.
oc
,
0
})
{
cfg
.
biasSize
=
biasSize
;
cfg
.
biasSize
=
biasSize
;
TestConfig
ref
=
cfg
;
TestConfig
ref
=
cfg
;
...
@@ -54,7 +54,7 @@ void testFcLayer(const testFCDesc& pm) {
...
@@ -54,7 +54,7 @@ void testFcLayer(const testFCDesc& pm) {
}
}
}
}
TEST
(
M
kldnnLayer
,
f
cLayer
)
{
TEST
(
M
KLDNNLayer
,
F
cLayer
)
{
testFcLayer
({
/*bs*/
2
,
/*ic*/
2
,
/*oc*/
3
,
/*ih*/
1
,
/*iw*/
1
});
testFcLayer
({
/*bs*/
2
,
/*ic*/
2
,
/*oc*/
3
,
/*ih*/
1
,
/*iw*/
1
});
testFcLayer
({
/*bs*/
3
,
/*ic*/
7
,
/*oc*/
19
,
/*ih*/
1
,
/*iw*/
1
});
testFcLayer
({
/*bs*/
3
,
/*ic*/
7
,
/*oc*/
19
,
/*ih*/
1
,
/*iw*/
1
});
testFcLayer
({
/*bs*/
8
,
/*ic*/
16
,
/*oc*/
32
,
/*ih*/
13
,
/*iw*/
13
});
testFcLayer
({
/*bs*/
8
,
/*ic*/
16
,
/*oc*/
32
,
/*ih*/
13
,
/*iw*/
13
});
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录