#!/bin/bash

# the same as scripts/run_gpt2_124M.sh but with PyTorch

# if you wish to train on just a single GPU, simply skip the torchrun part, i.e.
# python train_gpt2.py ... (all the other arguments the same)

for k in "d12"; do
if [ $k = "d12" ]
then
BS=16
runcommand="python3 train_gpt2_soap.py"
traindir="dev/data/fineweb10B/fineweb_train_*.bin"
valdir="dev/data/fineweb10B/fineweb_val_*.bin"
iternum=18865
fi
if [ $k = "d24" ]
then
BS=8
runcommand="python3 train_gpt2_soap.py"
traindir="dev/data/fineweb100B/fineweb_train_*.bin"
valdir="dev/data/fineweb100B/fineweb_val_*.bin"
iternum=60000
runcommand="torchrun --standalone --nproc_per_node=2 train_gpt2_soap.py"
fi
for j in "layerdepth"; do
for lrmode in fanin none; do
if [ $lrmode = "fanin" ]
then
    lrmul=16.0
fi
if [ $lrmode = "none" ]
then
    lrmul=32.0
fi
    ${runcommand}  \
    --input_bin "${traindir}" \
    --input_val_bin "${valdir}" \
    --val_loss_every 250 \
    --sample_every 0 \
    --output_dir pylog_gpt2_${k}soap${j}${lrmode} \
    --write_tensors 0 \
    --model ${k} \
    --residual_scale ${j} \
    --weight_init fanin \
    --lwlr_mode ${lrmode} \
    --batch_size ${BS} \
    --sequence_length 1024 \
    --total_batch_size 524288 \
    --dtype bfloat16 \
    --compile 1 \
    --tensorcores 1 \
    --flash 1 \
    --num_iterations ${iternum} \
    --zero_stage 0 \
    --lr_multiplier ${lrmul} \
    --warmup_iters 700 \
    --learning_rate_decay_frac 0.0 \
    --grad_clip 0.5 \
    --overfit_single_batch 0
done
done
done
