Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
s920243400
PaddleOCR
提交
e634afe7
P
PaddleOCR
项目概览
s920243400
/
PaddleOCR
与 Fork 源项目一致
Fork自
PaddlePaddle / PaddleOCR
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleOCR
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
e634afe7
编写于
9月 25, 2020
作者:
D
Double_V
提交者:
GitHub
9月 25, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #839 from baiyfbupt/qat_issue
fix quant module
上级
815f20b5
3ec7d48c
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
140 addition
and
32 deletion
+140
-32
deploy/slim/prune/pruning_and_finetune.py
deploy/slim/prune/pruning_and_finetune.py
+1
-1
deploy/slim/quantization/quant.py
deploy/slim/quantization/quant.py
+6
-5
tools/program.py
tools/program.py
+133
-26
未找到文件。
deploy/slim/prune/pruning_and_finetune.py
浏览文件 @
e634afe7
...
...
@@ -135,7 +135,7 @@ def main():
if
alg
in
[
'EAST'
,
'DB'
]:
program
.
train_eval_det_run
(
config
,
exe
,
train_info_dict
,
eval_info_dict
,
is_
pruning
=
True
)
config
,
exe
,
train_info_dict
,
eval_info_dict
,
is_
slim
=
"prune"
)
else
:
program
.
train_eval_rec_run
(
config
,
exe
,
train_info_dict
,
eval_info_dict
)
...
...
deploy/slim/quantization/quant.py
浏览文件 @
e634afe7
...
...
@@ -155,14 +155,13 @@ def main():
act_preprocess_func
=
act_preprocess_func
,
optimizer_func
=
optimizer_func
,
executor
=
executor
,
for_test
=
False
,
return_program
=
True
)
for_test
=
False
)
# compile program for multi-devices
train_compile_program
=
program
.
create_multi_devices_program
(
quant_train_program
,
train_opt_loss_name
,
for_quant
=
True
)
init_model
(
config
,
quant_
train_program
,
exe
)
init_model
(
config
,
train_program
,
exe
)
train_info_dict
=
{
'compile_program'
:
train_compile_program
,
\
'train_program'
:
quant_train_program
,
\
...
...
@@ -177,9 +176,11 @@ def main():
'fetch_varname_list'
:
eval_fetch_varname_list
}
if
train_alg_type
==
'det'
:
program
.
train_eval_det_run
(
config
,
exe
,
train_info_dict
,
eval_info_dict
)
program
.
train_eval_det_run
(
config
,
exe
,
train_info_dict
,
eval_info_dict
,
is_slim
=
"quant"
)
else
:
program
.
train_eval_rec_run
(
config
,
exe
,
train_info_dict
,
eval_info_dict
)
program
.
train_eval_rec_run
(
config
,
exe
,
train_info_dict
,
eval_info_dict
,
is_slim
=
"quant"
)
if
__name__
==
'__main__'
:
...
...
tools/program.py
浏览文件 @
e634afe7
...
...
@@ -241,9 +241,11 @@ def create_multi_devices_program(program, loss_var_name, for_quant=False):
build_strategy
.
enable_inplace
=
True
if
for_quant
:
build_strategy
.
fuse_all_reduce_ops
=
False
else
:
program
=
fluid
.
CompiledProgram
(
program
)
exec_strategy
=
fluid
.
ExecutionStrategy
()
exec_strategy
.
num_iteration_per_drop_scope
=
1
compile_program
=
fluid
.
CompiledProgram
(
program
)
.
with_data_parallel
(
compile_program
=
program
.
with_data_parallel
(
loss_name
=
loss_var_name
,
build_strategy
=
build_strategy
,
exec_strategy
=
exec_strategy
)
...
...
@@ -254,7 +256,7 @@ def train_eval_det_run(config,
exe
,
train_info_dict
,
eval_info_dict
,
is_
pruning
=
Fals
e
):
is_
slim
=
Non
e
):
'''
main program of evaluation for detection
'''
...
...
@@ -313,14 +315,21 @@ def train_eval_det_run(config,
best_batch_id
=
train_batch_id
best_epoch
=
epoch
save_path
=
save_model_dir
+
"/best_accuracy"
if
is_pruning
:
import
paddleslim
as
slim
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
else
:
if
is_slim
is
None
:
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
else
:
import
paddleslim
as
slim
if
is_slim
==
"prune"
:
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
elif
is_slim
==
"quant"
:
save_model
(
eval_info_dict
[
'program'
],
save_path
)
else
:
raise
ValueError
(
"Only quant and prune are supported currently. But received {}"
.
format
(
is_slim
))
strs
=
'Test iter: {}, metrics:{}, best_hmean:{:.6f}, best_epoch:{}, best_batch_id:{}'
.
format
(
train_batch_id
,
metrics
,
best_eval_hmean
,
best_epoch
,
best_batch_id
)
...
...
@@ -331,24 +340,42 @@ def train_eval_det_run(config,
train_loader
.
reset
()
if
epoch
==
0
and
save_epoch_step
==
1
:
save_path
=
save_model_dir
+
"/iter_epoch_0"
if
is_pruning
:
import
paddleslim
as
slim
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
else
:
if
is_slim
is
None
:
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
else
:
import
paddleslim
as
slim
if
is_slim
==
"prune"
:
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
elif
is_slim
==
"quant"
:
save_model
(
eval_info_dict
[
'program'
],
save_path
)
else
:
raise
ValueError
(
"Only quant and prune are supported currently. But received {}"
.
format
(
is_slim
))
if
epoch
>
0
and
epoch
%
save_epoch_step
==
0
:
save_path
=
save_model_dir
+
"/iter_epoch_%d"
%
(
epoch
)
if
is_pruning
:
import
paddleslim
as
slim
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
else
:
if
is_slim
is
None
:
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
else
:
import
paddleslim
as
slim
if
is_slim
==
"prune"
:
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
elif
is_slim
==
"quant"
:
save_model
(
eval_info_dict
[
'program'
],
save_path
)
else
:
raise
ValueError
(
"Only quant and prune are supported currently. But received {}"
.
format
(
is_slim
))
return
def
train_eval_rec_run
(
config
,
exe
,
train_info_dict
,
eval_info_dict
):
def
train_eval_rec_run
(
config
,
exe
,
train_info_dict
,
eval_info_dict
,
is_slim
=
None
):
'''
main program of evaluation for recognition
'''
...
...
@@ -428,7 +455,21 @@ def train_eval_rec_run(config, exe, train_info_dict, eval_info_dict):
best_batch_id
=
train_batch_id
best_epoch
=
epoch
save_path
=
save_model_dir
+
"/best_accuracy"
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
if
is_slim
is
None
:
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
else
:
import
paddleslim
as
slim
if
is_slim
==
"prune"
:
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
elif
is_slim
==
"quant"
:
save_model
(
eval_info_dict
[
'program'
],
save_path
)
else
:
raise
ValueError
(
"Only quant and prune are supported currently. But received {}"
.
format
(
is_slim
))
strs
=
'Test iter: {}, acc:{:.6f}, best_acc:{:.6f}, best_epoch:{}, best_batch_id:{}, eval_sample_num:{}'
.
format
(
train_batch_id
,
eval_acc
,
best_eval_acc
,
best_epoch
,
best_batch_id
,
eval_sample_num
)
...
...
@@ -439,14 +480,42 @@ def train_eval_rec_run(config, exe, train_info_dict, eval_info_dict):
train_loader
.
reset
()
if
epoch
==
0
and
save_epoch_step
==
1
:
save_path
=
save_model_dir
+
"/iter_epoch_0"
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
if
is_slim
is
None
:
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
else
:
import
paddleslim
as
slim
if
is_slim
==
"prune"
:
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
elif
is_slim
==
"quant"
:
save_model
(
eval_info_dict
[
'program'
],
save_path
)
else
:
raise
ValueError
(
"Only quant and prune are supported currently. But received {}"
.
format
(
is_slim
))
if
epoch
>
0
and
epoch
%
save_epoch_step
==
0
:
save_path
=
save_model_dir
+
"/iter_epoch_%d"
%
(
epoch
)
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
if
is_slim
is
None
:
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
else
:
import
paddleslim
as
slim
if
is_slim
==
"prune"
:
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
elif
is_slim
==
"quant"
:
save_model
(
eval_info_dict
[
'program'
],
save_path
)
else
:
raise
ValueError
(
"Only quant and prune are supported currently. But received {}"
.
format
(
is_slim
))
return
def
train_eval_cls_run
(
config
,
exe
,
train_info_dict
,
eval_info_dict
):
def
train_eval_cls_run
(
config
,
exe
,
train_info_dict
,
eval_info_dict
,
is_slim
=
None
):
train_batch_id
=
0
log_smooth_window
=
config
[
'Global'
][
'log_smooth_window'
]
epoch_num
=
config
[
'Global'
][
'epoch_num'
]
...
...
@@ -509,7 +578,21 @@ def train_eval_cls_run(config, exe, train_info_dict, eval_info_dict):
best_batch_id
=
train_batch_id
best_epoch
=
epoch
save_path
=
save_model_dir
+
"/best_accuracy"
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
if
is_slim
is
None
:
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
else
:
import
paddleslim
as
slim
if
is_slim
==
"prune"
:
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
elif
is_slim
==
"quant"
:
save_model
(
eval_info_dict
[
'program'
],
save_path
)
else
:
raise
ValueError
(
"Only quant and prune are supported currently. But received {}"
.
format
(
is_slim
))
strs
=
'Test iter: {}, acc:{:.6f}, best_acc:{:.6f}, best_epoch:{}, best_batch_id:{}, eval_sample_num:{}'
.
format
(
train_batch_id
,
eval_acc
,
best_eval_acc
,
best_epoch
,
best_batch_id
,
eval_sample_num
)
...
...
@@ -520,10 +603,34 @@ def train_eval_cls_run(config, exe, train_info_dict, eval_info_dict):
train_loader
.
reset
()
if
epoch
==
0
and
save_epoch_step
==
1
:
save_path
=
save_model_dir
+
"/iter_epoch_0"
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
if
is_slim
is
None
:
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
else
:
import
paddleslim
as
slim
if
is_slim
==
"prune"
:
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
elif
is_slim
==
"quant"
:
save_model
(
eval_info_dict
[
'program'
],
save_path
)
else
:
raise
ValueError
(
"Only quant and prune are supported currently. But received {}"
.
format
(
is_slim
))
if
epoch
>
0
and
epoch
%
save_epoch_step
==
0
:
save_path
=
save_model_dir
+
"/iter_epoch_%d"
%
(
epoch
)
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
if
is_slim
is
None
:
save_model
(
train_info_dict
[
'train_program'
],
save_path
)
else
:
import
paddleslim
as
slim
if
is_slim
==
"prune"
:
slim
.
prune
.
save_model
(
exe
,
train_info_dict
[
'train_program'
],
save_path
)
elif
is_slim
==
"quant"
:
save_model
(
eval_info_dict
[
'program'
],
save_path
)
else
:
raise
ValueError
(
"Only quant and prune are supported currently. But received {}"
.
format
(
is_slim
))
return
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录