1.1 Install python environment
conda create -n <env name> python=3.7
conda activate <env name>
cd <neural_compressor_folder>/examples/baremetal/nlp/mrpc/bert_mini
pip install -r requirements.txt
Preload libiomp5.so can improve the performance when bs=1.
export LD_PRELOAD=<path_to_libiomp5.so>
Preloading libjemalloc.so can improve the performance. It has been built in third_party/jemalloc/lib.
export LD_PRELOAD=<path_to_libjemalloc.so>
python prepare_dataset.py --output_dir=./data
bash prepare_model.sh
run python
GLOG_minloglevel=2 python run_engine.py --tune
or run shell
bash run_tuning.sh --config=bert_static.yaml --input_model=bert_mini_mrpc.onnx --output_model=ir --dataset_location=data
2.1 accuracy run python
GLOG_minloglevel=2 python run_engine.py --input_model=./ir --benchmark --mode=accuracy --batch_size=8
or run shell
bash run_benchmark.sh --config=bert_static.yaml --input_model=ir --dataset_location=data --batch_size=8 --mode=accuracy
2.2 performance run python
GLOG_minloglevel=2 python run_engine.py --input_model=./ir --benchmark --mode=performance --batch_size=8
or run shell
bash run_benchmark.sh --config=bert_static.yaml --input_model=ir --dataset_location=data --batch_size=8 --mode=performance
or run C++ The warmup below is recommended to be 1/10 of iterations and no less than 3.
export GLOG_minloglevel=2
export OMP_NUM_THREADS=<cpu_cores>
export DNNL_MAX_CPU_ISA=AVX512_CORE_AMX
export UNIFIED_BUFFER=1
numactl -C 0-<cpu_cores-1> <neural_compressor_folder>/engine/bin/inferencer --batch_size=<batch_size> --iterations=<iterations> --w=<warmup> --seq_len=128 --config=./ir/conf.yaml --weight=./ir/model.bin