#!/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 0-12:00:00   # 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 LNM

cd ~/SNNOverview/src

python3 main.py \
    --dataset cifar10dvs \
    --model MODEL_VAR \
    --loss crossentropy \
    --label_smoothing 0.01 \
    --sg triangle \
    --encoder identity \
    --epochs 200 \
    --batch_size 64 \
    --optimizer sgd \
    --lr 0.1 \
    --l2 5e-4 \
    --momentum 0.9 \
    --scheduler cosine \
    --num_workers 8 \
    --checkpoint 50 \
    --name "MODEL_NAME_VAR_CIFAR10DVS_SEED_VAR" \
    --num_workers 6 \
    --seed SEED_VAR'

MODELS=('lifvggsnn' 'lnmresnet19')
MODEL_NAME=('LNMVGGSNN' 'LNMResNet19')
SEED=('42' '43' '44')

for m in "${MODELS[@]}"; do
    for s in "${SEED[@]}"; do
        if [ "$m" == "lifvggsnn" ]; then
            mn=${MODEL_NAME[0]}
        elif [ "$m" == "lnmresnet19" ]; then
            mn=${MODEL_NAME[1]}
        fi
        JOB_NAME="${mn}_CIFAR10DVS_S${s}"
        JOB_FILE="${JOB_NAME}.sh"
        JOB_CONTENT="${TEMPLATE//MODEL_VAR/$m}"
        JOB_CONTENT="${JOB_CONTENT//MODEL_NAME_VAR/$mn}"
        JOB_CONTENT="${JOB_CONTENT//SEED_VAR/$s}"
        JOB_CONTENT="${JOB_CONTENT//MODEL_NAME_VAR_CIFAR10DVS_SEED_VAR/$JOB_NAME}"
        echo "Generating job file: $JOB_FILE"
        
        echo "$JOB_CONTENT" > "$JOB_FILE"
        # sbatch "$JOB_FILE"
    done
done
