#!/bin/bash

TEMPLATE='#!/bin/bash

#SBATCH -N 1            # number of nodes
#SBATCH -c 36           # number of cpus
#SBATCH -G a100:4	# number of GPUS
#SBATCH --mem=256G	# amount of memory
#SBATCH -t 7-00: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 --mail-type=ALL # Send an e-mail when a job starts, stops, or fails
#SBATCH --export=NONE   # Purge the job-submitting shell environment

module load mamba/latest

source activate LNM

# Update path to hugging face here
export HF_HOME=""

cd ~/SNNOverview/src

python3 main.py \
    --dataset imagenet \
    --model itlifresnet34 \
    --loss crossentropy \
    --sg rectangle \
    --encoder copy \
    --decode mean \
    --epochs 350 \
    --optimizer sgd \
    --lr 0.1 \
    --l2 5e-5 \
    --momentum 0.9 \
    --scheduler cosine \
    --batch_size 128 \
    --seq_length 4 \
    --checkpoint 5 \
    --name "LNMResNet34_ImageNet_T4_SEED_VAR" \
    --num_workers 6 \
    --seed SEED_VAR \
    --ddp True  \
    --warmup 5'

SEED=('42')

for s in "${SEED[@]}"; 
do
    JOB_NAME="LNMResNet34_ImageNet_T4_S${s}"
    JOB_FILE="${JOB_NAME}.sh"
    JOB_CONTENT="${TEMPLATE//SEED_VAR/$s}"
    JOB_CONTENT="${JOB_CONTENT//LNMResNet34_ImageNet_T4_SEED_VAR/$JOB_NAME}"

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