#!/bin/bash
#SBATCH --job-name=sgd
#SBATCH --output=/directory/logs/%j.out
#SBATCH --error=/directory/logs/%j.err
#SBATCH --time 4:00:00
#SBATCH --gpus-per-node=1
#SBATCH --nodes=1
#SBATCH --ntasks-per-node 1
#SBATCH --cpus-per-task 4
#SBATCH --array=0-100
#SBATCH --mem-per-cpu=32GB
#SBATCH --partition=userlab

# Note: you can only use one of mem or mem-per-cpu.  
# mem=32GB OR mem-per-cpu=32GB

# Activate the virtual environment
source /net/scratch/user/venvs/bin/activate

# Extract dataset automatically, pickles to not hit API tens of thousands of times
# Also handles automatic hyperparameter configuration sweep, fit to max_array 
# Generate the list using numpy.linspace in Python and format it as space-separated values
lr_list=$(python -c "import numpy as np; print(' '.join(map(str, np.linspace(1e-7, 2, 30))))")

python central_training/ensemble_main.py \
--lr_list $lr_list \
--eps_list 1e-9 \
--beta_1_list 0.9 \
--beta_2_list 0.999 \
--warmup_epochs_list 0 \
--optimzer_choice_list 0 \
--weight_decay_list 0.0 1e-1 \
--p_list 1 \
--num_ingredients_list 2 4 6 8 10 12 14 16 \
--epochs_list 5 \
--z_list 2.0 \
--shuffletrue_list 1 \
--batch_size_list 1 \
--max_array 100 \
--slurm_id $SLURM_ARRAY_TASK_ID \
--reload 0 \
--greedy 0 \
--base_project_name SGD