-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathperf-ci.sh
executable file
·128 lines (100 loc) · 4.12 KB
/
perf-ci.sh
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
126
127
128
#!/bin/bash -x
NO_SRC=false
TVM_TUNED_CPU=$HOME/tvm_tuned_cpu
TVM_TUNED_GPU=$HOME/tvm_tuned_gpu
while getopts “n” OPTION
do
case $OPTION in
n)
echo "Not checking out src tree.. running from current checkout.."
NO_SRC=true
;;
?)
echo "Unsupported option.. -n for no checkout and run as developer instead of a CI"
exit
;;
esac
done
if [ "$NO_SRC" = true ]; then
echo "Using existing checkout"
else
echo "Checking out transformer-benchmarks..."
git clone https://github.com/nod-ai/transformer-benchmarks --recursive
cd transformer-benchmarks
git submodule update --init --recursive
cd mmperf/external/iree
git submodule update --init --recursive
cd -
#echo "Updating submodules to origin/main...things may break.. but that is the point.."
#./update_submodules.sh
fi
#Gather results
TIMESTAMP=`date +%Y-%m-%d_%H-%M-%S`
#. $HOME/miniconda3/etc/profile.d/conda.sh
#conda env remove -n perf_env
#conda create -n perf_env python=3.9 -y
#conda activate perf_env
rm -rf perf_env
python3 -m venv perf_env
source perf_env/bin/activate
#E2E Transformer benchmarks
./run_benchmark.sh --cpu_fp32=true --gpu_fp32=false --create_venv=true --ort=true --torchscript=true --tensorflow=true --iree=true --ort_optimizer=false
#./run_benchmark.sh --gpu_fp32=true --cpu_fp32=false --create_venv=true --ort=true --torchscript=true --tensorflow=true --iree=true --ort_optimizer=false
mkdir -p transformer-bench-results/${TIMESTAMP}/BERT_e2e/
cp *.csv transformer-bench-results/${TIMESTAMP}/BERT_e2e/
cp model.mlir transformer-bench-results/${TIMESTAMP}/BERT_e2e/model_${TIMESTAMP}.mlir
#mmperf tests
cd mmperf
rm -rf mmperf_env
python3 -m venv mmperf_env
source mmperf_env/bin/activate
pip install --upgrade pip
pip install -r requirements.txt
#CPU tests
if [ -d ${TVM_TUNED_CPU} ]; then
echo "Using TVM TUNED for CPU"
cmake -GNinja -DCMAKE_CXX_COMPILER=clang++ -DCMAKE_C_COMPILER=clang -DMKL_DIR=/opt/intel/oneapi/mkl/latest/ -DUSE_TVM=ON -DUSE_MKL=ON -DUSE_MLIR=ON -DUSE_IREE=ON -DIREE_DYLIB=ON -DUSE_TVM_TUNED=ON -DTVM_LIB_DIR=${TVM_TUNED_CPU} -B build .
else
echo "No TVM tuned libs so skipping.."
cmake -GNinja -DCMAKE_CXX_COMPILER=clang++ -DCMAKE_C_COMPILER=clang -DMKL_DIR=/opt/intel/oneapi/mkl/latest/ -DUSE_MKL=ON -DUSE_MLIR=ON -DUSE_IREE=ON -DIREE_DYLIB=ON -B build .
fi
#build mmperf
cmake --build build
#Sometimes bad things happen to MLIR deps and ninja deps. Lets do another try.
cmake --build build
#Run all tests and generate the plots
cmake --build build/matmul --target run_all_tests
python mmperf.py build/matmul ../transformer-bench-results/${TIMESTAMP}/mmperf-cpu/
mv build build.cpu
#GPU tests
if [ -d ${TVM_TUNED_GPU} ] ; then
echo "Using TVM TUNED for GPU"
# cmake -GNinja -DCMAKE_CXX_COMPILER=clang++ -DCMAKE_C_COMPILER=clang -DMKL_DIR=/opt/intel/oneapi/mkl/latest/ -DCMAKE_CUDA_COMPILER=/usr/local/cuda/bin/nvcc -DUSE_TVM=ON -DUSE_MLIR=ON -DUSE_IREE=ON -DIREE_CUDA=ON -DUSE_CUBLAS=ON -DUSE_TVM_CUDA=ON -DTVM_ENABLE_CUDA=ON -DUSE_TVM_TUNED=ON -DTVM_LIB_DIR=${TVM_TUNED_GPU} -B build .
else
echo "No TVM tuned libs so skipping.."
# cmake -GNinja -DCMAKE_CXX_COMPILER=clang++ -DCMAKE_C_COMPILER=clang -DCMAKE_CUDA_COMPILER=/usr/local/cuda/bin/nvcc -DUSE_MLIR_CUDA=ON -DUSE_IREE=ON -DIREE_CUDA=ON -DUSE_CUBLAS=ON -B build .
fi
#build mmperf
#cmake --build build
#Sometimes bad things happen to MLIR deps and ninja deps. Lets do another try.
#cmake --build build
#Run all tests and generate the plots
#cmake --build build/matmul --target run_all_tests
#python mmperf.py build/matmul ../transformer-bench-results/${TIMESTAMP}/mmperf-gpu/
#mv build build.gpu
cd ..
cd transformer-bench-results
ln -s ${TIMESTAMP} latest
cd ../
echo "Remove old symlink.."
gsutil rm -rf gs://shark-public/nod-perf/results/transformer-bench/latest
echo "Copying to Google Storage.."
gsutil cp -r transformer-bench-results/* gs://shark-public/nod-perf/results/transformer-bench/
if [ "$NO_SRC" = true ]; then
echo "leaving sources and results for manual clean up"
else
cd ../..
echo "deleting transformer-benchmarks..."
echo `pwd`
rm -rf transformer-bench
fi