#!/bin/bash

TEMPLATE='#!/bin/bash

#SBATCH -N 1            # number of nodes
#SBATCH -c 8           # number of cpus
#SBATCH -G a100:1	# number of GPUS
#SBATCH --mem=32G	# amount of memory
#SBATCH -t TIME_VAR   # time in d-hh:mm:ss
#SBATCH -p general      # partition
#SBATCH -q public       # QOS
#SBATCH -o /home/%u/out/%j.out # file to save jobs STDOUT (%j = JobId)
#SBATCH -e /home/%u/err/%j.err # file to save jobs STDERR (%j = JobId)

#SBATCH --export=NONE   # Purge the job-submitting shell environment

module load mamba/latest

source activate QIF

cd ~/SNNOverview/src

python3 main.py \
    --dataset cifar100 \
    --model itlifresnet19 \
    --loss crossentropy \
    --sg rectangle \
    --encoder copy \
    --decode mean \
    --epochs 400 \
    --optimizer sgd \
    --lr 0.1 \
    --l2 1e-4 \
    --momentum 0.9 \
    --scheduler cosine \
    --batch_size 128 \
    --seq_length TIMESTEP_VAR \
    --checkpoint 50 \
    --name "LNMResNet19_CIFAR100_label_smoothing_TTIMESTEP_VAR_SEED_VAR" \
    --num_workers 6 \
    --label_smoothing 0.1 \
    --seed SEED_VAR'

TIME=('0-12:00:00' '0-24:00:00')
TIMESTEPS=('2' '4')
SEED=('42' '43' '44')

for ts in "${TIMESTEPS[@]}"; do
    for s in "${SEED[@]}"; do
        if [ "$ts" == "2" ]; then
            t=${TIME[0]}
        else
            t=${TIME[1]}
        fi
        JOB_NAME="LNMResNet19_CIFAR100_T${ts}_S${s}"
        JOB_FILE="${JOB_NAME}.sh"
        JOB_CONTENT="${TEMPLATE//TIME_VAR/$t}"
        JOB_CONTENT="${JOB_CONTENT//TIMESTEP_VAR/$ts}"
        JOB_CONTENT="${JOB_CONTENT//SEED_VAR/$s}"
        JOB_CONTENT="${JOB_CONTENT//ITQIFResNet19_CIFAR10_TTIMESTEP_VAR_SEED_VAR/$JOB_NAME}"

        echo "$JOB_CONTENT" > "$JOB_FILE"
        # sbatch "$JOB_FILE"
    done
done
