-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_experiments.sh
executable file
·62 lines (55 loc) · 2.14 KB
/
run_experiments.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
#!/bin/bash
SER_DIR=/path/to/project/directory/
EXP_DIR=/path/to/job_scripts/
SEED_START=${SEED_START:-1}
SEED_END=${SEED_END:-10}
# Use as BATCH_SIZES="100_1 200_2"
BATCH_SIZES=${BATCH_SIZES:-"10_100 20_50 50_20 100_10"}
ROOT_DIR=${ROOT_DIR:-$SER_DIR}
CONFIG_DIR=${CONFIG_DIR:-cartpole_easy}
MODELS=${MODELS:-"linattn ffm s5 lru"}
TYPES=${TYPES:-"tape segment"}
WANDB_GROUP=${WANDB_GROUP:-"rdqn_paper"}
#XLA_PYTHON_CLIENT_MEM_FRACTION=${XLA_PYTHON_CLIENT_MEM_FRACTION:-0.2}
CHUNK_SIZE=${CHUNK_SIZE:-4}
CMD_DELIM=${CMD_DELIM:-";"} # Use ; or & to do serial or parallel
# Set to echo for debug
# EXECUTE_CMD=${EXECUTE:-echo}
# Or for the real thing
EXECUTE_CMD=${EXECUTE_CMD:-"sbatch your_slurm_submission_script"}
DEBUG=${DEBUG:-}
SLEEP=${SLEEP:-1}
# String to list
IFS=' ' read -r -a BATCH_SIZES <<< "${BATCH_SIZES}"
IFS=' ' read -r -a MODELS <<< "${MODELS}"
IFS=' ' read -r -a TYPES <<< "${TYPES}"
CMDS=()
for SEED in $(seq $SEED_START $SEED_END); do
for MODEL in ${MODELS[@]}; do
for TYPE in ${TYPES[@]}; do
if [ "$TYPE" == "tape" ]; then
CMD="$DEBUG python $ROOT_DIR/tape_dqn.py ${ROOT_DIR}/experiments/${CONFIG_DIR}/${TYPE}_${MODEL}.yaml -w -p $WANDB_GROUP -n ${CONFIG_DIR}_${MODEL}_${TYPE}_${SEED} --seed ${SEED} ${CMD_DELIM}"
CMDS+=("$CMD")
elif [ "$TYPE" == "segment" ]; then
for BATCH_SIZE in ${BATCH_SIZES[@]}; do
CMD="$DEBUG python $ROOT_DIR/segment_dqn.py ${ROOT_DIR}/experiments/${CONFIG_DIR}/${TYPE}_${MODEL}_${BATCH_SIZE}.yaml -w -p $WANDB_GROUP -n ${CONFIG_DIR}_${MODEL}_${TYPE}_${BATCH_SIZE}_${SEED} --seed ${SEED} ${CMD_DELIM}"
CMDS+=("$CMD")
done
fi
done
done
done
rm -r "${EXP_DIR}"
mkdir "${EXP_DIR}"
for ((i=0; i<${#CMDS[@]}; i+=CHUNK_SIZE)); do
IDX=$(printf "%03d" ${i})
FNAME="${EXP_DIR}/exp_${IDX}.sh"
touch "${FNAME}"
# Required if parallel (&)
#echo "${CMDS[@]:i:CHUNK_SIZE}" 'true; wait $(jobs -p)' >> "${FNAME}"
echo "${CMDS[@]:i:CHUNK_SIZE}" >> "${FNAME}"
chmod a+x "${FNAME}"
export EXEC_PATH="${FNAME}"
${EXECUTE_CMD}
sleep ${SLEEP}
done