#!/bin/bash

echo "STARTING TRAIN"

args="$@"

for arg in "$@"; do
    eval "$arg"
done

# Arguments with default values
n_gpus=${n_gpus:-8}
exp_group=${exp_group:-"gla-1.3B_StateX"}
proj_name=${proj_name:-"StateX"}
train_config=${train_config:-"drop/10b_bsz-512k_64k_cos_3e-4_slimpj"}
comment=${comment:-""}
# Some arguments need to be constructed
run_name="${exp_group}_${model_config}_${train_config}_${comment}"

ckpt_path="huggingface/gla-1.3B-100B"

model_name="gla"
model_config="${ckpt_path}/config.json"
train_config="./configs/training/${train_config}.json"

steps=""
init_from="${ckpt_path}${steps}/model.safetensors"

drop_prop=6
drop_mode="gla"

# Build command
cmd="accelerate launch --num_processes=${n_gpus} train.py"

cmd+=" --run_name=${run_name}"
cmd+=" --proj_name=${proj_name}"
cmd+=" --init_from=${init_from}"
cmd+=" --drop_prop=${drop_prop}"
cmd+=" --drop_mode=${drop_mode}"

# Add command-line arguments to the cmd string
for arg in "$@"; do
    cmd+=" --$arg"
done

cmd+=" --model_name=${model_name}"
cmd+=" --model_config=${model_config}"
cmd+=" --train_config=${train_config}"
cmd+=" --grad_ckpt=1"


echo "======== Final command ========"
echo "$cmd" | tr ' ' '\n'
echo "==============================="

export WANDB_MODE=offline

$cmd
