forked from openml/automlbenchmark
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathrunstable.sh
executable file
·116 lines (100 loc) · 2.18 KB
/
runstable.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
#!/usr/bin/env bash
FRAMEWORKS=(
#constantpredictor
#constantpredictor_enc
#decisiontree
#randomforest
#tunedrandomforest
autosklearn
h2oautoml
tpot
oboe
autoweka
autoxgboost
#hyperoptsklearn
#ranger
)
BENCHMARKS=(
#test
#validation
small
medium
large
)
CONSTRAINTS=(
1h8c
4h8c
)
MODE=(
local
docker
aws
)
mode='local'
usage() {
echo "Usage: $0 framework_or_benchmark [-c|--constraint] [-m|--mode=<local|docker|aws>]" 1>&2;
}
POSITIONAL=()
for i in "$@"; do
case $i in
-h | --help)
usage
exit ;;
-f=* | --framework=*)
frameworks="${i#*=}"
shift ;;
-b=* | --benchmark=*)
benchmarks="${i#*=}"
shift ;;
-c=* | --constraint=*)
constraints="${i#*=}"
shift ;;
-m=* | --mode=*)
mode="${i#*=}"
shift ;;
-p=* | --parallel=*)
parallel="${i#*=}"
shift ;;
-*|--*=) # unsupported args
usage
exit 1 ;;
*)
POSITIONAL+=("$i")
shift ;;
esac
done
if [[ -z $frameworks ]]; then
frameworks=${FRAMEWORKS[*]}
fi
if [[ -z $benchmarks ]]; then
benchmarks=${BENCHMARKS[*]}
fi
if [[ -z $constraints ]]; then
constraints=${CONSTRAINTS[*]}
fi
if [[ -z $parallel ]]; then
if [[ $mode == "aws" ]]; then
parallel=60
else
parallel=1
fi
fi
#extra_params="-u /dev/null -o ./stable -Xmax_parallel_jobs=40"
extra_params="-u ~/dev/null -o ./stable -Xmax_parallel_jobs=60 -Xaws.use_docker=True -Xaws.query_frequency_seconds=60"
#extra_params="-u ~/.config/automlbenchmark/stable -o ./stable -Xmax_parallel_jobs=20 -Xaws.use_docker=True -Xaws.query_frequency_seconds=60"
#identify the positional param if any
#if [[ -n $POSITIONAL ]]; then
# if [[ -z $framework ]]; then
# for i in ${FRAMEWORKS[*]}; do
#fi
#run the benchmarks
# usage
# exit 1
for c in ${constraints[*]}; do
for b in ${benchmarks[*]}; do
for f in ${frameworks[*]}; do
# echo "python runbenchmark.py $f $b $c -m $mode -p $parallel $extra_params"
python runbenchmark.py $f $b $c -m $mode -p $parallel $extra_params
done
done
done