run_benchmark.sh 4.1 KB
Newer Older
1 2
#!/usr/bin/env bash
set -xe
3
# Usage:CUDA_VISIBLE_DEVICES=0 bash benchmark/run_benchmark.sh ${run_mode} ${batch_size} ${fp_item} ${max_epoch} ${model_name}
4 5 6 7
python="python3.7"
# Parameter description
function _set_params(){
    run_mode=${1:-"sp"}            # sp|mp
8
    batch_size=${2:-"2"}
9
    fp_item=${3:-"fp32"}           # fp32|fp16
10
    max_epoch=${4:-"1"}
G
gmm 已提交
11
    model_item=${5:-"model_item"}
12
    run_log_path=${TRAIN_LOG_DIR:-$(pwd)}
G
gmm 已提交
13 14 15 16 17 18 19 20 21
# 添加日志解析需要的参数
    base_batch_size=${batch_size}
    mission_name="目标检测"
    direction_id="0"
    ips_unit="images/s"
    skip_steps=10                     # 解析日志,有些模型前几个step耗时长,需要跳过                                    (必填)
    keyword="ips:"                 # 解析日志,筛选出数据所在行的关键字                                             (必填)
    index="1"
    model_name=${model_item}_bs${batch_size}_${fp_item}
22 23 24 25

    device=${CUDA_VISIBLE_DEVICES//,/ }
    arr=(${device})
    num_gpu_devices=${#arr[*]}
G
gmm 已提交
26
    log_file=${run_log_path}/${model_item}_${run_mode}_bs${batch_size}_${fp_item}_${num_gpu_devices}
27 28 29 30 31
}
function _train(){
    echo "Train on ${num_gpu_devices} GPUs"
    echo "current CUDA_VISIBLE_DEVICES=$CUDA_VISIBLE_DEVICES, gpus=$num_gpu_devices, batch_size=$batch_size"

32 33 34
    # set runtime params
    set_optimizer_lr_sp=" "
    set_optimizer_lr_mp=" "
G
gmm 已提交
35 36
    # parse model_item
    case ${model_item} in
37
        faster_rcnn) model_yml="benchmark/configs/faster_rcnn_r50_fpn_1x_coco.yml"
38 39 40
            set_optimizer_lr_sp="LearningRate.base_lr=0.001" ;;
        fcos) model_yml="configs/fcos/fcos_r50_fpn_1x_coco.yml"
            set_optimizer_lr_sp="LearningRate.base_lr=0.001" ;;
41
        deformable_detr) model_yml="configs/deformable_detr/deformable_detr_r50_1x_coco.yml" ;;
42 43
        gfl) model_yml="configs/gfl/gfl_r50_fpn_1x_coco.yml"
            set_optimizer_lr_sp="LearningRate.base_lr=0.001" ;;
44 45 46
        hrnet) model_yml="configs/keypoint/hrnet/hrnet_w32_256x192.yml" ;;
        higherhrnet) model_yml="configs/keypoint/higherhrnet/higherhrnet_hrnet_w32_512.yml" ;;
        solov2) model_yml="configs/solov2/solov2_r50_fpn_1x_coco.yml" ;;
47 48
        jde) model_yml="configs/mot/jde/jde_darknet53_30e_1088x608.yml" ;;
        fairmot) model_yml="configs/mot/fairmot/fairmot_dla34_30e_1088x608.yml" ;;
G
gmm 已提交
49
        *) echo "Undefined model_item"; exit 1;
50 51 52 53
    esac

    set_batch_size="TrainReader.batch_size=${batch_size}"
    set_max_epoch="epoch=${max_epoch}"
54
    set_log_iter="log_iter=1"
55 56 57 58 59 60 61 62
    if [ ${fp_item} = "fp16" ]; then
        set_fp_item="--fp16"
    else
        set_fp_item=" "
    fi

    case ${run_mode} in
        sp) train_cmd="${python} -u tools/train.py -c ${model_yml} ${set_fp_item} \
63
            -o ${set_batch_size} ${set_max_epoch} ${set_log_iter} ${set_optimizer_lr_sp}" ;;
G
gmm 已提交
64 65
        mp) rm -rf mylog
            train_cmd="${python} -m paddle.distributed.launch --log_dir=./mylog \
66
            --gpus=${CUDA_VISIBLE_DEVICES} tools/train.py -c ${model_yml} ${set_fp_item} \
67
            -o ${set_batch_size} ${set_max_epoch} ${set_log_iter} ${set_optimizer_lr_mp}"
68 69 70
            log_parse_file="mylog/workerlog.0" ;;
        *) echo "choose run_mode(sp or mp)"; exit 1;
    esac
71

72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
    timeout 15m ${train_cmd} > ${log_file} 2>&1
    if [ $? -ne 0 ];then
        echo -e "${train_cmd}, FAIL"
        export job_fail_flag=1
    else
        echo -e "${train_cmd}, SUCCESS"
        export job_fail_flag=0
    fi
    kill -9 `ps -ef|grep 'python'|awk '{print $2}'`

    if [ $run_mode = "mp" -a -d mylog ]; then
        rm ${log_file}
        cp mylog/workerlog.0 ${log_file}
    fi
}

G
gmm 已提交
88
source ${BENCHMARK_ROOT}/scripts/run_model.sh   # 在该脚本中会对符合benchmark规范的log使用analysis.py 脚本进行性能数据解析;该脚本在连调时可从benchmark repo中下载https://github.com/PaddlePaddle/benchmark/blob/master/scripts/run_model.sh;如果不联调只想要产出训练log可以注掉本行,提交时需打开
89
_set_params $@
G
gmm 已提交
90 91 92
# _train       # 如果只想产出训练log,不解析,可取消注释
_run     # 该函数在run_model.sh中,执行时会调用_train; 如果不联调只想要产出训练log可以注掉本行,提交时需打开