CONFIG_NAME=mmpretrain/vim/vtab1k/1_small/memba_2_small_lora_in_proj_32
CHECKPOINT_DIR=`date "+%Y%m%d_%H%M%S_%N"`
for DATASET in cifar caltech101 dtd oxford_flowers102 oxford_iiit_pet svhn sun397 \
               patch_camelyon eurosat resisc45 diabetic_retinopathy clevr_count clevr_dist \
               dmlab kitti dsprites_loc dsprites_ori smallnorb_azi smallnorb_ele
    do
        CUDA_VISIBLE_DEVICES=0 ./tools/dist_train.sh mmpretrain configs/${CONFIG_NAME}.py 1 \
            --work-dir work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR} \
            --cfg-options sub_dataset_name=${DATASET}
        CUDA_VISIBLE_DEVICES=0 ./tools/dist_test.sh mmpretrain configs/${CONFIG_NAME}.py \
            work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR}/last_checkpoint 1  \
            --cfg-options sub_dataset_name=${DATASET} | \
            tee work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR}/result_${DATASET}.txt
    done


CONFIG_NAME=mmpretrain/vim/vtab1k/1_small/memba_2_small_lora_out_proj_32
CHECKPOINT_DIR='loss_retino'
for DATASET in diabetic_retinopathy
    do
        CUDA_VISIBLE_DEVICES=0 ./tools/dist_test.sh mmpretrain configs/${CONFIG_NAME}.py \
            work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR}/last_checkpoint 1  \
            --cfg-options sub_dataset_name=${DATASET} | \
            tee work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR}/result_${DATASET}.txt
    done


CONFIG_NAME=mmpretrain/vim/vtab1k/1_small/memba_2_small_lora_in_proj_32
CHECKPOINT_DIR=`date "+%Y%m%d_%H%M%S_%N"`
for DATASET in cifar caltech101 dtd oxford_flowers102 oxford_iiit_pet svhn sun397 \
               patch_camelyon eurosat resisc45
                clevr_count clevr_dist \
               dmlab kitti dsprites_loc dsprites_ori smallnorb_azi smallnorb_ele
    do
        CUDA_VISIBLE_DEVICES=0 ./tools/dist_train.sh mmpretrain configs/${CONFIG_NAME}.py 1 \
            --work-dir work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR} \
            --cfg-options sub_dataset_name=${DATASET}
        CUDA_VISIBLE_DEVICES=0 ./tools/dist_test.sh mmpretrain configs/${CONFIG_NAME}.py \
            work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR}/last_checkpoint 1  \
            --cfg-options sub_dataset_name=${DATASET} | \
            tee work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR}/result_${DATASET}.txt
    done


### Vim-S ###
CONFIG_NAME=mmpretrain/vim/vtab1k/1_small/memba_2_small_lora_in_out_proj_32
CONFIG_NAME=mmpretrain/vim/vtab1k/1_small/memba_2_small_lora_in_proj_32
CHECKPOINT_DIR=`date "+%Y%m%d_%H%M%S_%N"`
for DATASET in diabetic_retinopathy
    do
        CUDA_VISIBLE_DEVICES=0 ./tools/dist_train.sh mmpretrain configs/${CONFIG_NAME}.py 1 \
            --work-dir work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR} \
            --cfg-options sub_dataset_name=${DATASET}
    done


### Vim-B ###
CONFIG_NAME=mmpretrain/vim/vtab1k/2_base/2_base_lorap_X_64
CHECKPOINT_DIR=`date "+%Y%m%d_%H%M%S_%N"`
for DATASET in cifar oxford_flowers102
    do
        CUDA_VISIBLE_DEVICES=0 ./tools/dist_train.sh mmpretrain configs/${CONFIG_NAME}.py 1 \
            --work-dir work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR} \
            --cfg-options sub_dataset_name=${DATASET}
    done


### Save to palmer ###
CONFIG_NAME=mmpretrain/vim/vtab1k/1_small/ablation_lim_lora
CHECKPOINT_DIR=`date "+%Y%m%d_%H%M%S_%N"`
for DATASET in patch_camelyon eurosat resisc45 diabetic_retinopathy
    do
        CUDA_VISIBLE_DEVICES=0 ./tools/dist_train.sh mmpretrain configs/${CONFIG_NAME}.py 1 \
            --work-dir /vast/palmer/scratch/panda/dl2345/MambaPEFT/work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR} \
            --cfg-options sub_dataset_name=${DATASET}
    done


cifar caltech101 dtd oxford_flowers102 oxford_iiit_pet svhn sun397 \
patch_camelyon eurosat resisc45 diabetic_retinopathy clevr_count clevr_dist \
dmlab kitti dsprites_loc dsprites_ori smallnorb_azi smallnorb_ele

######
vanilla_2_small_lora_in_proj_64
CONFIG_NAME=mmpretrain/vmamba/vtab1k/1_small/vanilla_2_small_lora_in_out_proj_64
CHECKPOINT_DIR=`date "+%Y%m%d_%H%M%S_%N"`
for DATASET in cifar caltech101 dtd oxford_flowers102 oxford_iiit_pet svhn sun397 \
               patch_camelyon eurosat resisc45 diabetic_retinopathy clevr_count clevr_dist \
               dmlab kitti dsprites_loc dsprites_ori smallnorb_azi smallnorb_ele
    do
        CUDA_VISIBLE_DEVICES=0 ./tools/dist_train.sh mmpretrain configs/${CONFIG_NAME}.py 1 \
            --work-dir /vast/palmer/scratch/panda/dl2345/MambaPEFT/work_dirs/${CONFIG_NAME}/${CHECKPOINT_DIR} \
            --cfg-options sub_dataset_name=${DATASET}
    done


dmlab kitti dsprites_loc dsprites_ori smallnorb_azi smallnorb_ele
cifar caltech101 dtd oxford_flowers102 oxford_iiit_pet svhn sun397
patch_camelyon eurosat resisc45 diabetic_retinopathy clevr_count clevr_dist




# Lang
CUDA_VISIBLE_DEVICES=0 python finetune.py --base_model state-spaces/mamba-130m-hf --data_path commonsense_170k.json --adapter_name lora_out_proj_lif --output_dir /vast/palmer/scratch/panda/dl2345/MambaPEFT/lang/iso_param_790m --learning_rate 1e-3

CUDA_VISIBLE_DEVICES=0 python finetune.py --base_model state-spaces/mamba-1.4b-hf --data_path commonsense_170k.json --adapter_name lora_out_proj_lif --output_dir ./results/lora_out_proj_lif_14b_lr1e4 --learning_rate 1e-4
CUDA_VISIBLE_DEVICES=0 python finetune.py --base_model state-spaces/mamba-1.4b-hf --data_path commonsense_170k.json --adapter_name lora_in_out_proj_lif --output_dir ./results/lora_in_out_proj_lif_14b_lr1e4 --learning_rate 1e-4
CUDA_VISIBLE_DEVICES=0 python finetune.py --base_model state-spaces/mamba-790m-hf --data_path commonsense_170k.json --adapter_name lora_in_out_x_dt_proj_lif --output_dir ./results/lora_in_out_proj_lif_790m_lr5e4 --learning_rate 5e-4


# Lang - math
CUDA_VISIBLE_DEVICES=0 python finetune.py --base_model state-spaces/mamba-130m-hf --data_path math_50k.json --adapter_name lora_in_proj_lif --output_dir ./results/math_lora_in_proj_lif --learning_rate 1e-3

# Mamba 2
CUDA_VISIBLE_DEVICES=0 python finetune.py --base_model state-spaces/mamba2-130m --data_path commonsense_170k.json --adapter_name lora_in_out_x_proj_lif --output_dir ./results/mamba2_lora_in_out_x_proj_lif --learning_rate 1e-3



TASKS='boolq,social_iqa,hellaswag,piqa,arc_easy,arc_challenge,winogrande,openbookqa'
python lm_harness_eval.py --model MambaPEFT --model_args pretrained="state-spaces/mamba-130m-hf,peft_weights=./results/iso_param_130m,trust_remote_code=True" --output_path results/iso_param_130m --tasks $TASKS
TASKS='boolq,social_iqa,hellaswag,piqa,arc_easy,arc_challenge,winogrande,openbookqa'
python lm_harness_eval.py --model MambaPEFT --model_args pretrained="state-spaces/mamba-1.4b-hf,peft_weights=/vast/palmer/scratch/panda/dl2345/MambaPEFT/lang/iso_param_14b,trust_remote_code=True" --output_path /vast/palmer/scratch/panda/dl2345/MambaPEFT/lang/iso_param_14b --tasks $TASKS
python lm_harness_eval_loss.py --model MambaPEFT --model_args pretrained="state-spaces/mamba-130m-hf,peft_weights=./results/lora_X,trust_remote_code=True" --output_path results/lora_X --tasks $TASKS


TASKS='asdiv,gsm8k,mathqa'
TASKS='gsm8k'
python lm_harness_eval.py --model MambaPEFT --model_args pretrained="state-spaces/mamba-130m-hf,peft_weights=./results/math_lora_in_proj_lif,trust_remote_code=True" --output_path results/math_lora_in_proj_lif --tasks $TASKS --batch_size 16
