-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathparallel_run2.sh
executable file
·72 lines (56 loc) · 2.12 KB
/
parallel_run2.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
#!/usr/bin/env bash
# -*- encoding: utf-8 -*-
### Get the current date and start making the results directory
CURRDATE=$(date +"%FT%H%M")
RESBASE="/beegfs/nvardala/results_MS_stim_pacing"
RESDIRTOT="$RESBASE"_"$CURRDATE"
### Check and make directory for saving ALL the results
if [ -d $RESDIRTOT ]; then
echo "Directory $RESDIRTOT exists. Cleaning..."
rm $RESDIRTOT/*.txt
else
echo "Directory $RESDIRTOT does not exist. Creating..."
mkdir $RESDIRTOT
fi
### Get all config directories
# CONF_DIRS=$(find ./configs/ -maxdepth 1 -mindepth 1 -type d)
# ISTIM=$1
# CONF_DIRS="configs/${ISTIM}_nA"
CONF_DIRS="configs/MS_stim_test"
### Go through the config directories and do the following:
for DIR in $CONF_DIRS;
do
### Store the basename for the parameters i.e. 10nA
PNAME=$(basename $DIR)
echo "In $PNAME"
### 1. Make a subdirectory to store the used configuration files for this parameter set i.e. results_{date}/10nA/...
CURRRES="$RESDIRTOT/$PNAME"
if ! [ -d $CURRRES ]; then
echo "Directory $CURRRES does not exist. Creating..."
mkdir $CURRRES
fi
BACKCONF="$CURRRES/configs"
if ! [ -d $BACKCONF ]; then
echo "Directory $BACKCONF does not exist. Creating..."
mkdir $BACKCONF
fi
### 2. Make the current config set output logs
echo "Creating txt output for current config set..."
touch "$CURRRES/total.txt"
### 3. Queue the batch script
### Set the variables used as arguments
CNT=0
RESDIR=$CURRRES
for FN_CONF in $DIR/*.json
do
echo $FN_CONF
### Queue the simulation
let DELAY="CNT*60"
echo "Delayed: $DELAY seconds"
sbatch --job-name="SIM_${FN_CONF}" --begin=now+$DELAY --time=60 --cpus-per-task=1 --mem-per-cpu=16G --ntasks=1 --export=FCONF=$FN_CONF,RESDIR=$RESDIR,CNT=$CNT,OUTDIR=$RESBASE run_sim.sh
let "CNT+=1"
sleep 1
### Copy the config file used to results dir
cp $FN_CONF $BACKCONF
done
done