#!/bin/bash

export DEVICE=localhost:0,1
NUM_GPU=2
PER_DEVICE_TRAIN_BATCH_SIZE=16
GRADIENT_ACCUMULATION_STEPS=1
export MASTER_PORT=
OUTPUT_DIR_PREFIX=""
LORA_CONFIG_FILE=""
TRAINING_EPOCH_LIST=(3)
LORA_RANK_LIST=(64)
DATASET_LIST=("iconqa_txt5k_scienceqa5k")
TRAINER_NAME_LIST=("AlloOrth")
ATTEMPT_LIST=()
ENTROPY_TEMPERATURE_LIST=(0.2)
INIT_LORA_SCALE_LIST=(5)
ALLOORTH_REG_LAMBDA_LIST=(1e-4)
for ALLOORTH_REG_LAMBDA in "${ALLOORTH_REG_LAMBDA_LIST[@]}"; do
    for INIT_LORA_SCALE in "${INIT_LORA_SCALE_LIST[@]}"; do
        for ENTROPY_TEMPERATURE in "${ENTROPY_TEMPERATURE_LIST[@]}"; do
            for ATTEMPT in "${ATTEMPT_LIST[@]}"; do
                for NUM_TRAIN_EPOCHS in "${TRAINING_EPOCH_LIST[@]}"; do
                    for LORA_RANK in "${LORA_RANK_LIST[@]}"; do
                        for DATASET_NAME in "${DATASET_LIST[@]}"; do
                            for TRAINER_NAME in "${TRAINER_NAME_LIST[@]}"; do
                                export ENTROPY_TEMPERATURE
                                export INIT_LORA_SCALE
                                export DATASET_NAME
                                export LORA_RANK
                                export ALLOORTH_REG_LAMBDA
                                LORA_INIT_DIR_PREFIX=""
                                COPARTRANK=$((LORA_RANK / 3))
                                LORA_INIT_DIR="${LORA_INIT_DIR_PREFIX}/llava1.5_7b-${DATASET_NAME//5k/}-r${LORA_RANK}wCoPartRank${COPARTRANK}-T${ENTROPY_TEMPERATURE}-S${INIT_LORA_SCALE}"
                                LORA_ALLOCATION_PATH="${LORA_INIT_DIR}/rank_allocation.json"
                                export LORA_ALLOCATION_PATH
                                export LORA_INIT_DIR    
                                OTHER_PARAMS="lora-ThanoRA-T${ENTROPY_TEMPERATURE}-S${INIT_LORA_SCALE}-LAMBDA${ALLOORTH_REG_LAMBDA}-CoPartRank${COPARTRANK}-attempt${ATTEMPT}"
                                LORA_ALPHA=$((2 * LORA_RANK))
                                HYPERPARAMS="lora-r${LORA_RANK}-a${LORA_ALPHA}-bs$((PER_DEVICE_TRAIN_BATCH_SIZE * GRADIENT_ACCUMULATION_STEPS * NUM_GPU))-e${NUM_TRAIN_EPOCHS}-${OTHER_PARAMS}"
                                OUTPUT_DIR="${OUTPUT_DIR_PREFIX}-${DATASET_NAME}-${TRAINER_NAME}-${HYPERPARAMS}"
                                bash $LORA_CONFIG_FILE $TRAINER_NAME $DATASET_NAME $LORA_RANK $LORA_ALPHA $PER_DEVICE_TRAIN_BATCH_SIZE $GRADIENT_ACCUMULATION_STEPS $NUM_TRAIN_EPOCHS $OUTPUT_DIR
                            done
                        done
                    done
                done
            done
        done
    done
done











