test_serving_infer_python.sh 4.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
#!/bin/bash
source test_tipc/utils_func.sh

FILENAME=$1

# parser model_name
dataline=$(cat ${FILENAME})
IFS=$'\n'
lines=(${dataline})
model_name=$(func_parser_value "${lines[1]}")
echo "ppdet serving_infer: ${model_name}"
python=$(func_parser_value "${lines[2]}")
filename_key=$(func_parser_key "${lines[3]}")
filename_value=$(func_parser_value "${lines[3]}")

# parser export params
save_export_key=$(func_parser_key "${lines[5]}")
save_export_value=$(func_parser_value "${lines[5]}")
export_weight_key=$(func_parser_key "${lines[6]}")
export_weight_value=$(func_parser_value "${lines[6]}")
norm_export=$(func_parser_value "${lines[7]}")
pact_export=$(func_parser_value "${lines[8]}")
fpgm_export=$(func_parser_value "${lines[9]}")
distill_export=$(func_parser_value "${lines[10]}")
export_key1=$(func_parser_key "${lines[11]}")
export_value1=$(func_parser_value "${lines[11]}")
export_key2=$(func_parser_key "${lines[12]}")
export_value2=$(func_parser_value "${lines[12]}")
kl_quant_export=$(func_parser_value "${lines[13]}")

# parser serving params
infer_mode_list=$(func_parser_value "${lines[15]}")
infer_is_quant_list=$(func_parser_value "${lines[16]}")

web_service_py=$(func_parser_value "${lines[17]}")
model_dir_key=$(func_parser_key "${lines[18]}")
opt_key=$(func_parser_key "${lines[19]}")
opt_use_gpu_list=$(func_parser_value "${lines[19]}")
web_service_key1=$(func_parser_key "${lines[20]}")
web_service_value1=$(func_parser_value "${lines[20]}")
http_client_py=$(func_parser_value "${lines[21]}")
infer_image_key=$(func_parser_key "${lines[22]}")
infer_image_value=$(func_parser_value "${lines[22]}")
http_client_key1=$(func_parser_key "${lines[23]}")
http_client_value1=$(func_parser_value "${lines[23]}")

LOG_PATH="./test_tipc/output"
mkdir -p ${LOG_PATH}
status_log="${LOG_PATH}/results_serving_python.log"

function func_serving_inference(){
    IFS='|'
    _python=$1
    _log_path=$2
    _service_script=$3
    _client_script=$4
    _set_model_dir=$5
    _set_image_file=$6
    set_web_service_params1=$(func_set_params "${web_service_key1}" "${web_service_value1}")
    set_http_client_params1=$(func_set_params "${http_client_key1}" "${http_client_value1}")
    # inference
    for opt in ${opt_use_gpu_list[*]}; do
        device_type=$(func_parser_key "${opt}")
        _save_log_path="${_log_path}/serving_infer_python_${device_type}_batchsize_1.log"
        opt_value=$(func_parser_value "${opt}")
        _set_opt=$(func_set_params "${opt_key}" "${opt_value}")
        # run web service
        web_service_cmd="${_python} ${_service_script} ${_set_model_dir} ${_set_opt} ${set_web_service_params1} &"
        eval $web_service_cmd
        last_status=${PIPESTATUS[0]}
        status_check $last_status "${web_service_cmd}" "${status_log}" "${model_name}"
        sleep 5s
        # run http client
        http_client_cmd="${_python} ${_client_script} ${_set_image_file} ${set_http_client_params1} > ${_save_log_path} 2>&1 "
        eval $http_client_cmd
        last_status=${PIPESTATUS[0]}
        status_check $last_status "${http_client_cmd}" "${status_log}" "${model_name}"
        eval "cat ${_save_log_path}"
        ps ux | grep -E 'web_service' | awk '{print $2}' | xargs kill -s 9
    done
}

# set cuda device
GPUID=$2
if [ ${#GPUID} -le 0 ];then
    env=" "
else
    env="export CUDA_VISIBLE_DEVICES=${GPUID}"
fi
eval $env

# run serving infer
Count=0
IFS="|"
infer_quant_flag=(${infer_is_quant_list})
for infer_mode in ${infer_mode_list[*]}; do
    # run export
    case ${infer_mode} in
        norm) run_export=${norm_export} ;;
        quant) run_export=${pact_export} ;;
        fpgm) run_export=${fpgm_export} ;;
        distill) run_export=${distill_export} ;;
        kl_quant) run_export=${kl_quant_export} ;;
        *) echo "Undefined infer_mode!"; exit 1;
    esac
    if [ ${run_export} = "null" ]; then
        continue
    fi
    set_export_weight=$(func_set_params "${export_weight_key}" "${export_weight_value}")
    set_save_export_dir=$(func_set_params "${save_export_key}" "${save_export_value}")
    set_filename=$(func_set_params "${filename_key}" "${model_name}")
    export_cmd="${python} ${run_export} ${set_export_weight} ${set_filename} ${set_save_export_dir} "
    echo  $export_cmd
    eval $export_cmd
    status_export=$?
    status_check $status_export "${export_cmd}" "${status_log}" "${model_name}"

    #run inference
    set_export_model_dir=$(func_set_params "${model_dir_key}" "${save_export_value}/${model_name}")
    set_infer_image_file=$(func_set_params "${infer_image_key}" "${infer_image_value}")
    is_quant=${infer_quant_flag[Count]}
    func_serving_inference "${python}" "${LOG_PATH}" "${web_service_py}" "${http_client_py}" "${set_export_model_dir}" ${set_infer_image_file}
    Count=$(($Count + 1))
done
eval "unset CUDA_VISIBLE_DEVICES"