This repository has been archived by the owner on Jun 15, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy pathlaunch.sh
executable file
·86 lines (81 loc) · 2.02 KB
/
launch.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
#!/bin/bash
# Copyright (c) Facebook, Inc. and its affiliates.
#
# This source code is licensed under the MIT license found in the
# LICENSE file in the root directory of this source tree.
TASK=${1:-mlp_cifar10}
DIVISION=${2:-best}
GPU=${3:-1}
OUT=${4:-stdout} # to analyze result, you should change from "stdout" to "file"
if [ "$TASK" = "mlp_cifar10" ]
then
DATASET='cifar10'
PREFIX='mlp_bs128_1gpu_layer3'
elif [ "$TASK" = "mlp_cifar10_bio" ]
then
DATASET='cifar10'
PREFIX='mlp_bs128_1gpu_layer3'
elif [ "$TASK" = "cnn_imagenet" ]
then
DATASET='imagenet'
if [ "GPU" = 1 ]
then
PREFIX='cnn6_bs32_1gpu_64d'
else
PREFIX='cnn6_bs256_8gpu_64d'
fi
elif [ "$TASK" = "resnet34_imagenet" ]
then
DATASET='imagenet'
if [ "GPU" = 1 ]
then
PREFIX='R-34_bs32_1gpu'
else
PREFIX='R-34_bs256_8gpu'
fi
elif [ "$TASK" = "resnet34sep_imagenet" ]
then
DATASET='imagenet'
if [ "GPU" = 1 ]
then
PREFIX='R-34_bs32_1gpu'
else
PREFIX='R-34_bs256_8gpu'
fi
elif [ "$TASK" = "resnet50_imagenet" ]
then
DATASET='imagenet'
if [ "GPU" = 1 ]
then
PREFIX='R-50_bs32_1gpu'
else
PREFIX='R-50_bs256_8gpu'
fi
elif [ "$TASK" = "efficient_imagenet" ]
then
DATASET='imagenet'
if [ "GPU" = 1 ]
then
PREFIX='EN-B0_bs64_1gpu_nms'
else
PREFIX='EN-B0_bs512_8gpu_nms'
fi
else
exit 1
fi
DIR=configs/baselines/${DATASET}/${TASK}/${DIVISION}/*
(trap 'kill 0' SIGINT;
for CONFIG in $DIR
do
if echo "$CONFIG" | grep -q "$PREFIX"; then
if [ "${CONFIG##*.}" = "yaml" ]; then
CONFIG=${CONFIG##*/}
CONFIG=${CONFIG%.yaml}
echo ${CONFIG}
# run one model at a time
# Note: with slurm scheduler, one can run multiple jobs in parallel
python tools/train_net.py --cfg configs/baselines/${DATASET}/${TASK}/${DIVISION}/${CONFIG}.yaml TRAIN.AUTO_RESUME False OUT_DIR checkpoint/${DATASET}/${TASK}/${DIVISION}/${CONFIG} BN.USE_PRECISE_STATS True LOG_DEST $OUT
fi
fi
done
)