-
Notifications
You must be signed in to change notification settings - Fork 220
/
Copy pathbenchmark.sh
executable file
·63 lines (55 loc) · 2.3 KB
/
benchmark.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
#!/bin/bash
# Copyright (c) 2023-2024 Intel Corporation
#
# 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.
(( EUID != 0 )) && echo "fatal: must be executed under root" && exit 1
OUTPUT_DIR=${OUTPUT_DIR:-$PWD}
PROFILE=${PROFILE:-profiles/b0.bf16.csv}
PLATFORM=${PLATFORM:-Flex}
AMP=${AMP:-yes}
JIT=${JIT:-trace}
if [[ ${PLATFORM} == "Flex" || ${PLATFORM} == "Max" ]]; then
IMAGE=${IMAGE:-intel/image-recognition:pytorch-flex-gpu-efficientnet-inference}
platform_opt="--device /dev/dri/"
elif [[ ${PLATFORM} == "CUDA" ]]; then
IMAGE=${IMAGE:-intel/image-recognition:pytorch-cuda-gpu-efficientnet-inference}
platform_opt="--gpus all"
else
echo "fatal: unsupported platform: ${PLATFORM}"
exit 1
fi
METADATA="$METADATA"
METADATA+=" config.system.docker0.docker.image=$IMAGE"
METADATA+=" config.system.docker0.docker.sha256=$(docker images --no-trunc --quiet $IMAGE | cut -d: -f2)"
# arguments in {} are mapped by benchmark.py from:
# 1. Profile given by --profile argument for each iteration of the test
# 2. Predefined variables: {output_dir}, {socket}
python3 -m benchmark --profile=$PROFILE --output_dir=$OUTPUT_DIR --telemetry --socket=/tmp/telemetry.s --platform=$PLATFORM --indent 4 --metadata "$METADATA" \
docker run -it --rm --ipc=host --cap-add SYS_NICE $platform_opt \
$(env | grep -E '(_proxy=|_PROXY)' | sed 's/^/-e /') \
-e PLATFORM=${PLATFORM} \
-e AMP=${AMP} \
-e JIT=${JIT} \
-e MODEL_NAME={model_name} \
-e BATCH_SIZE={batch_size} \
-e NUM_INPUTS={num_inputs} \
-e STREAMS={streams} \
-e MAX_TEST_DURATION={test_duration} \
-e MIN_TEST_DURATION={test_duration} \
-e PRECISION={precision} \
-e OUTPUT_DIR=/opt/output \
-v {output_dir}:/opt/output \
-e SOCKET=/tmp/telemetry.s \
-v {socket}:/tmp/telemetry.s \
$IMAGE \
/bin/bash -c './run_model.sh --dummy'