run.sh 6.3 KB
Newer Older
Y
Yan Chunwei 已提交
1
#!/bin/bash
W
Wilber 已提交
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16

# 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.

17
set -x
I
iducn 已提交
18 19 20 21 22 23 24 25
PADDLE_ROOT=$1
TURN_ON_MKL=$2 # use MKL or Openblas
TEST_GPU_CPU=$3 # test both GPU/CPU mode or only CPU mode
DATA_DIR=$4 # dataset
TENSORRT_INCLUDE_DIR=$5 # TensorRT header file dir, default to /usr/local/TensorRT/include
TENSORRT_LIB_DIR=$6 # TensorRT lib file dir, default to /usr/local/TensorRT/lib
MSVC_STATIC_CRT=$7
inference_install_dir=${PADDLE_ROOT}/build/paddle_inference_install_dir
26
WIN_DETECT=$(echo `uname` | grep "Win") # detect current platform
N
nhzlx 已提交
27

I
iducn 已提交
28 29 30
cd `dirname $0`
current_dir=`pwd`
if [ $2 == ON ]; then
31
  # You can export yourself if move the install path
I
iducn 已提交
32 33
  MKL_LIB=${inference_install_dir}/third_party/install/mklml/lib
  export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:${MKL_LIB}
34
fi
I
iducn 已提交
35
if [ $3 == ON ]; then
36
  use_gpu_list='true false'
Y
Yan Chunwei 已提交
37
else
38 39
  use_gpu_list='false'
fi
L
Luo Tao 已提交
40

N
nhzlx 已提交
41
USE_TENSORRT=OFF
I
iducn 已提交
42
if [ -d "$TENSORRT_INCLUDE_DIR" -a -d "$TENSORRT_LIB_DIR" ]; then
N
nhzlx 已提交
43 44 45
  USE_TENSORRT=ON
fi

D
dzhwinter 已提交
46
PREFIX=inference-vis-demos%2F
47
URL_ROOT=http://paddlemodels.bj.bcebos.com/${PREFIX}
D
dzhwinter 已提交
48

L
Luo Tao 已提交
49 50
# download vis_demo data
function download() {
I
iducn 已提交
51 52 53
  dir_name=$1
  mkdir -p $dir_name
  cd $dir_name
D
dzhwinter 已提交
54
  if [[ -e "${PREFIX}${dir_name}.tar.gz" ]]; then
55
    echo "${PREFIX}${dir_name}.tar.gz has been downloaded."
D
dzhwinter 已提交
56
  else
57 58 59 60 61
      if [ $WIN_DETECT != "" ]; then
        wget -q -Y off ${URL_ROOT}$dir_name.tar.gz
      else
        wget -q --no-proxy ${URL_ROOT}$dir_name.tar.gz
      fi
I
iducn 已提交
62
      tar xzf *.tar.gz
D
dzhwinter 已提交
63
  fi
I
iducn 已提交
64
  cd ..
L
Luo Tao 已提交
65
}
I
iducn 已提交
66 67
mkdir -p $DATA_DIR
cd $DATA_DIR
L
Luo Tao 已提交
68 69
vis_demo_list='se_resnext50 ocr mobilenet'
for vis_demo_name in $vis_demo_list; do
I
iducn 已提交
70
  download $vis_demo_name
L
Luo Tao 已提交
71 72
done

73 74
# download word2vec data
mkdir -p word2vec
I
iducn 已提交
75
cd word2vec
76 77 78 79
if [[ -e "word2vec.inference.model.tar.gz" ]]; then
  echo "word2vec.inference.model.tar.gz has been downloaded."
else
    wget -q http://paddle-inference-dist.bj.bcebos.com/word2vec.inference.model.tar.gz
I
iducn 已提交
80
    tar xzf *.tar.gz
81 82
fi

L
Luo Tao 已提交
83
# compile and test the demo
I
iducn 已提交
84
cd $current_dir
L
Luo Tao 已提交
85
mkdir -p build
I
iducn 已提交
86 87
cd build
rm -rf *
L
Luo Tao 已提交
88

89
for WITH_STATIC_LIB in ON OFF; do
I
iducn 已提交
90
  if [ $(echo `uname` | grep "Win") != "" ]; then
W
Wilber 已提交
91 92
    # TODO(wilber, T8T9): Do we still need to support windows gpu static library
    if [ $TEST_GPU_CPU == ON ] && [ $WITH_STATIC_LIB == ON ]; then
Z
Zhou Wei 已提交
93
      continue
W
Wilber 已提交
94
    fi
95
    # -----simple_on_word2vec on windows-----
96
    cmake .. -G "Visual Studio 15 2017" -A x64 -T host=x64 -DPADDLE_LIB=${inference_install_dir} \
I
iducn 已提交
97
      -DWITH_MKL=$TURN_ON_MKL \
98
      -DDEMO_NAME=simple_on_word2vec \
I
iducn 已提交
99 100 101
      -DWITH_GPU=$TEST_GPU_CPU \
      -DWITH_STATIC_LIB=$WITH_STATIC_LIB \
      -DMSVC_STATIC_CRT=$MSVC_STATIC_CRT
102 103 104
    msbuild  /maxcpucount /property:Configuration=Release cpp_inference_demo.sln
    for use_gpu in $use_gpu_list; do
      Release/simple_on_word2vec.exe \
I
iducn 已提交
105 106 107
        --dirname=$DATA_DIR/word2vec/word2vec.inference.model \
        --use_gpu=$use_gpu
      if [ $? -ne 0 ]; then
108 109 110 111 112 113
        echo "simple_on_word2vec demo runs fail."
        exit 1
      fi
    done

    # -----vis_demo on windows-----
I
iducn 已提交
114
    rm -rf *
115
    cmake .. -G "Visual Studio 15 2017" -A x64 -T host=x64 -DPADDLE_LIB=${inference_install_dir} \
I
iducn 已提交
116
      -DWITH_MKL=$TURN_ON_MKL \
117
      -DDEMO_NAME=vis_demo \
I
iducn 已提交
118 119 120
      -DWITH_GPU=$TEST_GPU_CPU \
      -DWITH_STATIC_LIB=$WITH_STATIC_LIB \
      -DMSVC_STATIC_CRT=$MSVC_STATIC_CRT
121 122 123 124
    msbuild  /maxcpucount /property:Configuration=Release cpp_inference_demo.sln
    for use_gpu in $use_gpu_list; do
      for vis_demo_name in $vis_demo_list; do
        Release/vis_demo.exe \
I
iducn 已提交
125 126 127 128 129
          --modeldir=$DATA_DIR/$vis_demo_name/model \
          --data=$DATA_DIR/$vis_demo_name/data.txt \
          --refer=$DATA_DIR/$vis_demo_name/result.txt \
          --use_gpu=$use_gpu
        if [ $? -ne 0 ]; then
130 131 132 133 134 135
          echo "vis demo $vis_demo_name runs fail."
          exit 1
        fi
      done
    done
  else
136
    # -----simple_on_word2vec on linux/mac-----
I
iducn 已提交
137 138 139
    rm -rf *
    cmake .. -DPADDLE_LIB=${inference_install_dir} \
      -DWITH_MKL=$TURN_ON_MKL \
140
      -DDEMO_NAME=simple_on_word2vec \
I
iducn 已提交
141 142 143 144 145
      -DWITH_GPU=$TEST_GPU_CPU \
      -DWITH_STATIC_LIB=$WITH_STATIC_LIB
    make -j$(nproc)
    word2vec_model=$DATA_DIR'/word2vec/word2vec.inference.model'
    if [ -d $word2vec_model ]; then
146 147
      for use_gpu in $use_gpu_list; do
        ./simple_on_word2vec \
I
iducn 已提交
148 149 150
          --dirname=$DATA_DIR/word2vec/word2vec.inference.model \
          --use_gpu=$use_gpu
        if [ $? -ne 0 ]; then
151 152 153 154 155 156
          echo "simple_on_word2vec demo runs fail."
          exit 1
        fi
      done
    fi
    # ---------vis_demo on linux/mac---------
I
iducn 已提交
157 158 159
    rm -rf *
    cmake .. -DPADDLE_LIB=${inference_install_dir} \
      -DWITH_MKL=$TURN_ON_MKL \
160
      -DDEMO_NAME=vis_demo \
I
iducn 已提交
161 162 163
      -DWITH_GPU=$TEST_GPU_CPU \
      -DWITH_STATIC_LIB=$WITH_STATIC_LIB
    make -j$(nproc)
164 165 166
    for use_gpu in $use_gpu_list; do
      for vis_demo_name in $vis_demo_list; do
        ./vis_demo \
I
iducn 已提交
167 168 169 170 171
          --modeldir=$DATA_DIR/$vis_demo_name/model \
          --data=$DATA_DIR/$vis_demo_name/data.txt \
          --refer=$DATA_DIR/$vis_demo_name/result.txt \
          --use_gpu=$use_gpu
        if [ $? -ne 0 ]; then
172 173 174 175 176 177
          echo "vis demo $vis_demo_name runs fail."
          exit 1
        fi
      done
    done
    # --------tensorrt mobilenet on linux/mac------
I
iducn 已提交
178 179 180 181
    if [ $USE_TENSORRT == ON -a $TEST_GPU_CPU == ON ]; then
      rm -rf *
      cmake .. -DPADDLE_LIB=${inference_install_dir} \
        -DWITH_MKL=$TURN_ON_MKL \
182
        -DDEMO_NAME=trt_mobilenet_demo \
I
iducn 已提交
183 184 185 186 187 188
        -DWITH_GPU=$TEST_GPU_CPU \
        -DWITH_STATIC_LIB=$WITH_STATIC_LIB \
        -DUSE_TENSORRT=$USE_TENSORRT \
        -DTENSORRT_INCLUDE_DIR=$TENSORRT_INCLUDE_DIR \
        -DTENSORRT_LIB_DIR=$TENSORRT_LIB_DIR
      make -j$(nproc)
189
      ./trt_mobilenet_demo \
I
iducn 已提交
190 191 192 193
        --modeldir=$DATA_DIR/mobilenet/model \
        --data=$DATA_DIR/mobilenet/data.txt \
        --refer=$DATA_DIR/mobilenet/result.txt 
      if [ $? -ne 0 ]; then
194 195 196
        echo "trt demo trt_mobilenet_demo runs fail."
        exit 1
      fi
N
nhzlx 已提交
197
    fi
198 199
  fi
done
200
set +x