#!/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 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 4 \
    --checkpoint 50 \
    --name "Ablation_LNMResNet19_CIFAR100_T4_SEED_VAR_PDPOLY_DEGREE_VAR" \
    --num_workers 6 \
    --label_smoothing 0.1 \
    --seed SEED_VAR \
    --poly_degree POLY_DEGREE_VAR'

TIMESTEPS=('4')
SEEDS=('42' '43' '44')
POLY_DEGREE=('1' '2' '3' '4' '5' '6' '7' '8' '9')

# Loop through each time and timestep combination. If two timesteps are specified, use TIME[0] for the first and TIME[1] for the second.

for sd in "${SEEDS[@]}"; do
    for ts in "${TIMESTEPS[@]}"; do
        for pd in "${POLY_DEGREE[@]}"; do
            JOB_NAME="Ablation_LNMResNet19_CIFAR100_T${ts}_S${sd}_PD${pd}"
            JOB_FILE="${JOB_NAME}.sh"
            JOB_CONTENT="${TEMPLATE//SEED_VAR/$sd}"
            JOB_CONTENT="${JOB_CONTENT//POLY_DEGREE_VAR/$pd}"
            JOB_CONTENT="${JOB_CONTENT//LNMResNet19_CIFAR10_TTIMESTEP_VAR_PDPOLY_DEGREE_VAR/$JOB_NAME}"

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