Merge pull request #4368 from tink2123/add_test_serving
Add test serving
This commit is contained in:
commit
0a63385f2b
|
@ -65,6 +65,8 @@ inference:./deploy/cpp_infer/build/ppocr det
|
||||||
null:null
|
null:null
|
||||||
--benchmark:True
|
--benchmark:True
|
||||||
===========================serving_params===========================
|
===========================serving_params===========================
|
||||||
|
model_name:ocr_det
|
||||||
|
python:python3.7
|
||||||
trans_model:-m paddle_serving_client.convert
|
trans_model:-m paddle_serving_client.convert
|
||||||
--dirname:./inference/ch_ppocr_mobile_v2.0_det_infer/
|
--dirname:./inference/ch_ppocr_mobile_v2.0_det_infer/
|
||||||
--model_filename:inference.pdmodel
|
--model_filename:inference.pdmodel
|
||||||
|
|
|
@ -49,4 +49,35 @@ inference:tools/infer/predict_det.py
|
||||||
--save_log_path:null
|
--save_log_path:null
|
||||||
--benchmark:True
|
--benchmark:True
|
||||||
null:null
|
null:null
|
||||||
|
===========================cpp_infer_params===========================
|
||||||
|
use_opencv:True
|
||||||
|
infer_model:./inference/ch_ppocr_server_v2.0_det_infer/
|
||||||
|
infer_quant:False
|
||||||
|
inference:./deploy/cpp_infer/build/ppocr det
|
||||||
|
--use_gpu:True|False
|
||||||
|
--enable_mkldnn:True|False
|
||||||
|
--cpu_threads:1|6
|
||||||
|
--rec_batch_num:1
|
||||||
|
--use_tensorrt:False|True
|
||||||
|
--precision:fp32|fp16
|
||||||
|
--det_model_dir:
|
||||||
|
--image_dir:./inference/ch_det_data_50/all-sum-510/
|
||||||
|
null:null
|
||||||
|
--benchmark:True
|
||||||
|
===========================serving_params===========================
|
||||||
|
model_name:ocr_det_server
|
||||||
|
python:python3.7
|
||||||
|
trans_model:-m paddle_serving_client.convert
|
||||||
|
--dirname:./inference/ch_ppocr_server_v2.0_det_infer/
|
||||||
|
--model_filename:inference.pdmodel
|
||||||
|
--params_filename:inference.pdiparams
|
||||||
|
--serving_server:./deploy/pdserving/ppocr_det_mobile_2.0_serving/
|
||||||
|
--serving_client:./deploy/pdserving/ppocr_det_mobile_2.0_client/
|
||||||
|
serving_dir:./deploy/pdserving
|
||||||
|
web_service:web_service_det.py --config=config.yml --opt op.det.concurrency=1
|
||||||
|
op.det.local_service_conf.devices:null|0
|
||||||
|
op.det.local_service_conf.use_mkldnn:True|False
|
||||||
|
op.det.local_service_conf.thread_num:1|6
|
||||||
|
op.det.local_service_conf.use_trt:False|True
|
||||||
|
op.det.local_service_conf.precision:fp32|fp16|int8
|
||||||
|
pipline:pipeline_http_client.py --image_dir=../../doc/imgs
|
||||||
|
|
|
@ -65,6 +65,8 @@ inference:./deploy/cpp_infer/build/ppocr rec
|
||||||
null:null
|
null:null
|
||||||
--benchmark:True
|
--benchmark:True
|
||||||
===========================serving_params===========================
|
===========================serving_params===========================
|
||||||
|
model_name:ocr_rec
|
||||||
|
python:python3.7
|
||||||
trans_model:-m paddle_serving_client.convert
|
trans_model:-m paddle_serving_client.convert
|
||||||
--dirname:./inference/ch_ppocr_mobile_v2.0_rec_infer/
|
--dirname:./inference/ch_ppocr_mobile_v2.0_rec_infer/
|
||||||
--model_filename:inference.pdmodel
|
--model_filename:inference.pdmodel
|
||||||
|
@ -78,4 +80,4 @@ op.rec.local_service_conf.use_mkldnn:True|False
|
||||||
op.rec.local_service_conf.thread_num:1|6
|
op.rec.local_service_conf.thread_num:1|6
|
||||||
op.rec.local_service_conf.use_trt:False|True
|
op.rec.local_service_conf.use_trt:False|True
|
||||||
op.rec.local_service_conf.precision:fp32|fp16|int8
|
op.rec.local_service_conf.precision:fp32|fp16|int8
|
||||||
pipline:pipeline_http_client.py --image_dir=../../doc/imgs_words_en
|
pipline:pipeline_http_client.py --image_dir=../../doc/imgs_words_en
|
||||||
|
|
|
@ -65,12 +65,14 @@ inference:./deploy/cpp_infer/build/ppocr rec
|
||||||
null:null
|
null:null
|
||||||
--benchmark:True
|
--benchmark:True
|
||||||
===========================serving_params===========================
|
===========================serving_params===========================
|
||||||
|
model_name:ocr_server_rec
|
||||||
|
python:python3.7
|
||||||
trans_model:-m paddle_serving_client.convert
|
trans_model:-m paddle_serving_client.convert
|
||||||
--dirname:./inference/ch_ppocr_server_v2.0_rec_infer/
|
--dirname:./inference/ch_ppocr_server_v2.0_rec_infer/
|
||||||
--model_filename:inference.pdmodel
|
--model_filename:inference.pdmodel
|
||||||
--params_filename:inference.pdiparams
|
--params_filename:inference.pdiparams
|
||||||
--serving_server:./deploy/pdserving/ppocr_rec_server_2.0_serving/
|
--serving_server:./deploy/pdserving/ppocr_rec_mobile_2.0_serving/
|
||||||
--serving_client:./deploy/pdserving/ppocr_rec_server_2.0_client/
|
--serving_client:./deploy/pdserving/ppocr_rec_mobile_2.0_client/
|
||||||
serving_dir:./deploy/pdserving
|
serving_dir:./deploy/pdserving
|
||||||
web_service:web_service_rec.py --config=config.yml --opt op.rec.concurrency=1
|
web_service:web_service_rec.py --config=config.yml --opt op.rec.concurrency=1
|
||||||
op.rec.local_service_conf.devices:null|0
|
op.rec.local_service_conf.devices:null|0
|
||||||
|
@ -78,4 +80,4 @@ op.rec.local_service_conf.use_mkldnn:True|False
|
||||||
op.rec.local_service_conf.thread_num:1|6
|
op.rec.local_service_conf.thread_num:1|6
|
||||||
op.rec.local_service_conf.use_trt:False|True
|
op.rec.local_service_conf.use_trt:False|True
|
||||||
op.rec.local_service_conf.precision:fp32|fp16|int8
|
op.rec.local_service_conf.precision:fp32|fp16|int8
|
||||||
pipline:pipeline_http_client.py --image_dir=../../doc/imgs_words_en
|
pipline:pipeline_http_client.py --image_dir=../../doc/imgs_words_en
|
||||||
|
|
|
@ -134,5 +134,5 @@ if [ ${MODE} = "serving_infer" ];then
|
||||||
wget -nc -P ./inference https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_rec_infer.tar
|
wget -nc -P ./inference https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_mobile_v2.0_rec_infer.tar
|
||||||
wget -nc -P ./inference https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_det_infer.tar
|
wget -nc -P ./inference https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_det_infer.tar
|
||||||
wget -nc -P ./inference https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_rec_infer.tar
|
wget -nc -P ./inference https://paddleocr.bj.bcebos.com/dygraph_v2.0/ch/ch_ppocr_server_v2.0_rec_infer.tar
|
||||||
cd ./inference && tar xf ch_ppocr_mobile_v2.0_det_infer.tar && tar xf ch_ppocr_mobile_v2.0_rec_infer.tar && tar xf ch_ppocr_server_v2.0_rec_infer.tar && tar xf ch_ppocr_server_v2.0_det_infer.tar cd ../
|
cd ./inference && tar xf ch_ppocr_mobile_v2.0_det_infer.tar && tar xf ch_ppocr_mobile_v2.0_rec_infer.tar && tar xf ch_ppocr_server_v2.0_rec_infer.tar && tar xf ch_ppocr_server_v2.0_det_infer.tar && cd ../
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -2,44 +2,44 @@
|
||||||
source tests/common_func.sh
|
source tests/common_func.sh
|
||||||
|
|
||||||
FILENAME=$1
|
FILENAME=$1
|
||||||
dataline=$(awk 'NR==67, NR==81{print}' $FILENAME)
|
dataline=$(awk 'NR==67, NR==83{print}' $FILENAME)
|
||||||
|
|
||||||
# parser params
|
# parser params
|
||||||
IFS=$'\n'
|
IFS=$'\n'
|
||||||
lines=(${dataline})
|
lines=(${dataline})
|
||||||
|
|
||||||
# parser serving
|
# parser serving
|
||||||
trans_model_py=$(func_parser_value "${lines[1]}")
|
model_name=$(func_parser_value "${lines[1]}")
|
||||||
infer_model_dir_key=$(func_parser_key "${lines[2]}")
|
python=$(func_parser_value "${lines[2]}")
|
||||||
infer_model_dir_value=$(func_parser_value "${lines[2]}")
|
trans_model_py=$(func_parser_value "${lines[3]}")
|
||||||
model_filename_key=$(func_parser_key "${lines[3]}")
|
infer_model_dir_key=$(func_parser_key "${lines[4]}")
|
||||||
model_filename_value=$(func_parser_value "${lines[3]}")
|
infer_model_dir_value=$(func_parser_value "${lines[4]}")
|
||||||
params_filename_key=$(func_parser_key "${lines[4]}")
|
model_filename_key=$(func_parser_key "${lines[5]}")
|
||||||
params_filename_value=$(func_parser_value "${lines[4]}")
|
model_filename_value=$(func_parser_value "${lines[5]}")
|
||||||
serving_server_key=$(func_parser_key "${lines[5]}")
|
params_filename_key=$(func_parser_key "${lines[6]}")
|
||||||
serving_server_value=$(func_parser_value "${lines[5]}")
|
params_filename_value=$(func_parser_value "${lines[6]}")
|
||||||
serving_client_key=$(func_parser_key "${lines[6]}")
|
serving_server_key=$(func_parser_key "${lines[7]}")
|
||||||
serving_client_value=$(func_parser_value "${lines[6]}")
|
serving_server_value=$(func_parser_value "${lines[7]}")
|
||||||
serving_dir_value=$(func_parser_value "${lines[7]}")
|
serving_client_key=$(func_parser_key "${lines[8]}")
|
||||||
web_service_py=$(func_parser_value "${lines[8]}")
|
serving_client_value=$(func_parser_value "${lines[8]}")
|
||||||
web_use_gpu_key=$(func_parser_key "${lines[9]}")
|
serving_dir_value=$(func_parser_value "${lines[9]}")
|
||||||
web_use_gpu_list=$(func_parser_value "${lines[9]}")
|
web_service_py=$(func_parser_value "${lines[10]}")
|
||||||
web_use_mkldnn_key=$(func_parser_key "${lines[10]}")
|
web_use_gpu_key=$(func_parser_key "${lines[11]}")
|
||||||
web_use_mkldnn_list=$(func_parser_value "${lines[10]}")
|
web_use_gpu_list=$(func_parser_value "${lines[11]}")
|
||||||
web_cpu_threads_key=$(func_parser_key "${lines[11]}")
|
web_use_mkldnn_key=$(func_parser_key "${lines[12]}")
|
||||||
web_cpu_threads_list=$(func_parser_value "${lines[11]}")
|
web_use_mkldnn_list=$(func_parser_value "${lines[12]}")
|
||||||
web_use_trt_key=$(func_parser_key "${lines[12]}")
|
web_cpu_threads_key=$(func_parser_key "${lines[13]}")
|
||||||
web_use_trt_list=$(func_parser_value "${lines[12]}")
|
web_cpu_threads_list=$(func_parser_value "${lines[13]}")
|
||||||
web_precision_key=$(func_parser_key "${lines[13]}")
|
web_use_trt_key=$(func_parser_key "${lines[14]}")
|
||||||
web_precision_list=$(func_parser_value "${lines[13]}")
|
web_use_trt_list=$(func_parser_value "${lines[14]}")
|
||||||
pipeline_py=$(func_parser_value "${lines[14]}")
|
web_precision_key=$(func_parser_key "${lines[15]}")
|
||||||
|
web_precision_list=$(func_parser_value "${lines[15]}")
|
||||||
|
pipeline_py=$(func_parser_value "${lines[16]}")
|
||||||
|
|
||||||
|
LOG_PATH="../../tests/output"
|
||||||
LOG_PATH="./tests/output"
|
mkdir -p ./tests/output
|
||||||
mkdir -p ${LOG_PATH}
|
|
||||||
status_log="${LOG_PATH}/results_serving.log"
|
status_log="${LOG_PATH}/results_serving.log"
|
||||||
|
|
||||||
|
|
||||||
function func_serving(){
|
function func_serving(){
|
||||||
IFS='|'
|
IFS='|'
|
||||||
_python=$1
|
_python=$1
|
||||||
|
@ -65,12 +65,12 @@ function func_serving(){
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
for threads in ${web_cpu_threads_list[*]}; do
|
for threads in ${web_cpu_threads_list[*]}; do
|
||||||
_save_log_path="${_log_path}/server_cpu_usemkldnn_${use_mkldnn}_threads_${threads}_batchsize_1.log"
|
_save_log_path="${LOG_PATH}/server_infer_cpu_usemkldnn_${use_mkldnn}_threads_${threads}_batchsize_1.log"
|
||||||
set_cpu_threads=$(func_set_params "${web_cpu_threads_key}" "${threads}")
|
set_cpu_threads=$(func_set_params "${web_cpu_threads_key}" "${threads}")
|
||||||
web_service_cmd="${python} ${web_service_py} ${web_use_gpu_key}=${use_gpu} ${web_use_mkldnn_key}=${use_mkldnn} ${set_cpu_threads} &>${_save_log_path} &"
|
web_service_cmd="${python} ${web_service_py} ${web_use_gpu_key}=${use_gpu} ${web_use_mkldnn_key}=${use_mkldnn} ${set_cpu_threads} &"
|
||||||
eval $web_service_cmd
|
eval $web_service_cmd
|
||||||
sleep 2s
|
sleep 2s
|
||||||
pipeline_cmd="${python} ${pipeline_py}"
|
pipeline_cmd="${python} ${pipeline_py} > ${_save_log_path} 2>&1 "
|
||||||
eval $pipeline_cmd
|
eval $pipeline_cmd
|
||||||
last_status=${PIPESTATUS[0]}
|
last_status=${PIPESTATUS[0]}
|
||||||
eval "cat ${_save_log_path}"
|
eval "cat ${_save_log_path}"
|
||||||
|
@ -93,13 +93,13 @@ function func_serving(){
|
||||||
if [[ ${use_trt} = "False" || ${precision} =~ "int8" ]] && [[ ${_flag_quant} = "True" ]]; then
|
if [[ ${use_trt} = "False" || ${precision} =~ "int8" ]] && [[ ${_flag_quant} = "True" ]]; then
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
_save_log_path="${_log_path}/server_gpu_usetrt_${use_trt}_precision_${precision}_batchsize_1.log"
|
_save_log_path="${LOG_PATH}/server_infer_gpu_usetrt_${use_trt}_precision_${precision}_batchsize_1.log"
|
||||||
set_tensorrt=$(func_set_params "${web_use_trt_key}" "${use_trt}")
|
set_tensorrt=$(func_set_params "${web_use_trt_key}" "${use_trt}")
|
||||||
set_precision=$(func_set_params "${web_precision_key}" "${precision}")
|
set_precision=$(func_set_params "${web_precision_key}" "${precision}")
|
||||||
web_service_cmd="${python} ${web_service_py} ${web_use_gpu_key}=${use_gpu} ${set_tensorrt} ${set_precision} &>${_save_log_path} & "
|
web_service_cmd="${python} ${web_service_py} ${web_use_gpu_key}=${use_gpu} ${set_tensorrt} ${set_precision} & "
|
||||||
eval $web_service_cmd
|
eval $web_service_cmd
|
||||||
sleep 2s
|
sleep 2s
|
||||||
pipeline_cmd="${python} ${pipeline_py}"
|
pipeline_cmd="${python} ${pipeline_py} > ${_save_log_path} 2>&1"
|
||||||
eval $pipeline_cmd
|
eval $pipeline_cmd
|
||||||
last_status=${PIPESTATUS[0]}
|
last_status=${PIPESTATUS[0]}
|
||||||
eval "cat ${_save_log_path}"
|
eval "cat ${_save_log_path}"
|
||||||
|
@ -129,3 +129,7 @@ eval $env
|
||||||
|
|
||||||
|
|
||||||
echo "################### run test ###################"
|
echo "################### run test ###################"
|
||||||
|
|
||||||
|
export Count=0
|
||||||
|
IFS="|"
|
||||||
|
func_serving "${web_service_cmd}"
|
||||||
|
|
Loading…
Reference in New Issue