Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Crayon鑫
Paddle
提交
2cb71c0c
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看板
未验证
提交
2cb71c0c
编写于
11月 16, 2020
作者:
J
joanna.wozna.intel
提交者:
GitHub
11月 16, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add checkpoint to quantize (#28612)
* Add checkpoint to quantize * Change bfloat16 option
上级
804271cf
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
77 addition
and
0 deletion
+77
-0
paddle/fluid/framework/ir/mkldnn/cpu_bfloat16_pass.cc
paddle/fluid/framework/ir/mkldnn/cpu_bfloat16_pass.cc
+6
-0
paddle/fluid/operators/quantize_op.cc
paddle/fluid/operators/quantize_op.cc
+8
-0
python/paddle/fluid/tests/unittests/ir/inference/inference_pass_test.py
...fluid/tests/unittests/ir/inference/inference_pass_test.py
+5
-0
python/paddle/fluid/tests/unittests/ir/inference/test_mkldnn_cpu_bfloat16_pass.py
...s/unittests/ir/inference/test_mkldnn_cpu_bfloat16_pass.py
+58
-0
未找到文件。
paddle/fluid/framework/ir/mkldnn/cpu_bfloat16_pass.cc
浏览文件 @
2cb71c0c
...
@@ -16,6 +16,7 @@ limitations under the License. */
...
@@ -16,6 +16,7 @@ limitations under the License. */
#include <vector>
#include <vector>
#include "paddle/fluid/framework/ir/graph_pattern_detector.h"
#include "paddle/fluid/framework/ir/graph_pattern_detector.h"
#include "paddle/fluid/framework/op_version_registry.h"
#include "paddle/fluid/platform/mkldnn_helper.h"
#include "paddle/fluid/platform/mkldnn_helper.h"
#include "paddle/fluid/string/pretty_log.h"
#include "paddle/fluid/string/pretty_log.h"
...
@@ -157,3 +158,8 @@ void CPUBFloat16Pass::ApplyImpl(ir::Graph* graph) const {
...
@@ -157,3 +158,8 @@ void CPUBFloat16Pass::ApplyImpl(ir::Graph* graph) const {
}
// namespace paddle
}
// namespace paddle
REGISTER_PASS
(
cpu_bfloat16_pass
,
paddle
::
framework
::
ir
::
CPUBFloat16Pass
);
REGISTER_PASS
(
cpu_bfloat16_pass
,
paddle
::
framework
::
ir
::
CPUBFloat16Pass
);
REGISTER_PASS_CAPABILITY
(
cpu_bfloat16_pass
)
.
AddCombination
(
paddle
::
framework
::
compatible
::
OpVersionComparatorCombination
().
GE
(
"quantize"
,
1
));
paddle/fluid/operators/quantize_op.cc
浏览文件 @
2cb71c0c
...
@@ -13,6 +13,7 @@
...
@@ -13,6 +13,7 @@
* limitations under the License. */
* limitations under the License. */
#include "paddle/fluid/operators/quantize_op.h"
#include "paddle/fluid/operators/quantize_op.h"
#include "paddle/fluid/framework/op_version_registry.h"
#ifdef PADDLE_WITH_MKLDNN
#ifdef PADDLE_WITH_MKLDNN
#include "paddle/fluid/platform/mkldnn_helper.h"
#include "paddle/fluid/platform/mkldnn_helper.h"
#endif
#endif
...
@@ -54,3 +55,10 @@ void QuantOpMaker::Make() {
...
@@ -54,3 +55,10 @@ void QuantOpMaker::Make() {
namespace
ops
=
paddle
::
operators
;
namespace
ops
=
paddle
::
operators
;
REGISTER_OPERATOR
(
quantize
,
ops
::
QuantOp
,
ops
::
QuantOpMaker
);
REGISTER_OPERATOR
(
quantize
,
ops
::
QuantOp
,
ops
::
QuantOpMaker
);
REGISTER_OP_VERSION
(
quantize
)
.
AddCheckpoint
(
R"ROC( Add a new attribute [bfloat16])ROC"
,
paddle
::
framework
::
compatible
::
OpVersionDesc
().
NewAttr
(
"bfloat16"
,
"If true, float32 input is converted to bfloat16"
,
false
));
python/paddle/fluid/tests/unittests/ir/inference/inference_pass_test.py
浏览文件 @
2cb71c0c
...
@@ -43,6 +43,7 @@ class InferencePassTest(unittest.TestCase):
...
@@ -43,6 +43,7 @@ class InferencePassTest(unittest.TestCase):
self
.
fetch_list
=
None
self
.
fetch_list
=
None
self
.
enable_mkldnn
=
False
self
.
enable_mkldnn
=
False
self
.
enable_mkldnn_bfloat16
=
False
self
.
enable_trt
=
False
self
.
enable_trt
=
False
self
.
trt_parameters
=
None
self
.
trt_parameters
=
None
self
.
enable_lite
=
False
self
.
enable_lite
=
False
...
@@ -125,6 +126,8 @@ class InferencePassTest(unittest.TestCase):
...
@@ -125,6 +126,8 @@ class InferencePassTest(unittest.TestCase):
self
.
trt_parameters
.
use_calib_mode
)
self
.
trt_parameters
.
use_calib_mode
)
elif
use_mkldnn
:
elif
use_mkldnn
:
config
.
enable_mkldnn
()
config
.
enable_mkldnn
()
if
self
.
enable_mkldnn_bfloat16
:
config
.
enable_mkldnn_bfloat16
()
return
config
return
config
...
@@ -251,6 +254,8 @@ class InferencePassTest(unittest.TestCase):
...
@@ -251,6 +254,8 @@ class InferencePassTest(unittest.TestCase):
len
(
outs
)
==
len
(
mkldnn_outputs
),
len
(
outs
)
==
len
(
mkldnn_outputs
),
"The number of outputs is different between CPU and MKLDNN. "
)
"The number of outputs is different between CPU and MKLDNN. "
)
if
self
.
enable_mkldnn_bfloat16
:
atol
=
0.01
for
out
,
mkldnn_output
in
zip
(
outs
,
mkldnn_outputs
):
for
out
,
mkldnn_output
in
zip
(
outs
,
mkldnn_outputs
):
self
.
assertTrue
(
self
.
assertTrue
(
np
.
allclose
(
np
.
allclose
(
...
...
python/paddle/fluid/tests/unittests/ir/inference/test_mkldnn_cpu_bfloat16_pass.py
0 → 100644
浏览文件 @
2cb71c0c
# Copyright (c) 2020 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.
import
unittest
import
numpy
as
np
from
inference_pass_test
import
InferencePassTest
import
paddle.fluid
as
fluid
from
paddle.fluid.core
import
PassVersionChecker
class
TestMKLDNNCpuBfloat16Pass
(
InferencePassTest
):
def
setUp
(
self
):
self
.
init_data
()
with
fluid
.
program_guard
(
self
.
main_program
,
self
.
startup_program
):
x
=
fluid
.
data
(
name
=
'x'
,
shape
=
[
-
1
]
+
self
.
shape_x
,
dtype
=
self
.
d_type
)
y
=
fluid
.
data
(
name
=
'y'
,
shape
=
[
-
1
]
+
self
.
shape_y
,
dtype
=
self
.
d_type
)
out
=
fluid
.
layers
.
matmul
(
x
,
y
)
out
=
fluid
.
layers
.
transpose
(
out
,
perm
=
[
0
,
1
,
2
,
3
])
out
=
fluid
.
layers
.
reshape
(
out
,
[
0
,
0
,
0
,
0
])
out
=
fluid
.
layers
.
fc
(
out
,
size
=
1
)
self
.
feeds
=
{
"x"
:
np
.
random
.
random
([
self
.
bs
]
+
self
.
shape_x
).
astype
(
self
.
d_type
),
"y"
:
np
.
random
.
random
([
self
.
bs
]
+
self
.
shape_y
).
astype
(
self
.
d_type
)
}
self
.
fetch_list
=
[
out
]
def
init_data
(
self
):
self
.
bs
=
8
self
.
d_type
=
np
.
float32
self
.
shape_x
=
[
12
,
10
,
1
]
self
.
shape_y
=
[
12
,
1
,
64
]
self
.
enable_mkldnn
=
True
self
.
enable_mkldnn_bfloat16
=
True
def
test_check_output
(
self
):
use_gpu
=
False
self
.
check_output_with_option
(
use_gpu
,
flatten
=
True
)
self
.
assertTrue
(
PassVersionChecker
.
IsCompatible
(
'cpu_bfloat16_pass'
))
if
__name__
==
"__main__"
:
unittest
.
main
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录