#!/bin/bash

usage="usage: $0 [options] <run_config>"
Help()
{
echo $usage
}
# Get the options
while getopts ":h" option; do
  case $option in
    h) # display Help
      echo $usage
      exit;
  esac
done

if [[ $# -lt 1 ]]; then
  echo $usage
  exit
fi

run_config=$(realpath $1)

# to have colors on terminal
Red='\033[0;31m'          # Red
Green='\033[0;32m'        # Green
Yellow='\033[0;33m'       # Yellow
Blue='\033[0;34m'         # Blue
NC='\033[0m'              # No Color

## dump for yamls
dump=$PWD/"dump"
mkdir -p $dump

## all runs
exp_list=( $(yq 'keys | .[] | select(. != "common")' $run_config) )
template=$(yq '.common' $run_config)

run_job="true" #default
for exp in "${exp_list[@]}"; do
  config_exp_yaml=$dump/$exp.yml
  # apply base template
  yq '.common' $run_config > $config_exp_yaml
  # apply specific change to experiment
  keys=( $(yq ".$exp | keys | .[]" $run_config) )
  vals=( $(yq ".$exp | .[]" $run_config) )
  count=0
  for k in "${keys[@]}"; do
    if [ $k == "run" ]; then
      run_job="${vals[$count]}"
      count=$(( count + 1 ))
      continue
    fi
    v="${vals[$count]}" yq -i ".$k |= env(v)" $config_exp_yaml
    count=$(( count + 1 ))
  done
  # (maybe) launch job
  if [ "$run_job" = "true" ]; then
    printf "${Green}>> Begin new run: ${Blue}$exp${NC}\n"
    printf "${Yellow}>>> Start Training${NC}\n"
    CUDA_VISIBLE_DEVICES=1,2,3,4,5,6,7 ACCELERATE_LOG_LEVEL=info \
      accelerate launch --config_file accelerate_configs/zero3.yaml \
      --num_processes 7 trl_gsm8k.py --config $config_exp_yaml
    sleep 10
  fi
done
