OUTPUT_DIR='./mnli_rank_1_s1'
num_gpus=4
NCCL_P2P_DISABLE=1 CUDA_VISIBLE_DEVICES=0,1,2,3 nohup python -m torch.distributed.launch --nproc_per_node=$num_gpus --master_port=22349 non-GPT-2/examples/pytorch/text-classification/run_glue.py \
    --save_total_limit 20 \
    --model_name_or_path bert-base-uncased \
    --task_name mnli \
    --output_dir ${OUTPUT_DIR} \
    --do_train \
    --do_eval \
    --num_train_epochs 3 \
    --save_steps 500 \
    --seed 2 \
    --per_device_train_batch_size 8 \
    --max_seq_length 128 \
    --per_device_eval_batch_size 8 \
    --overwrite_output_dir \
    --logging_steps 500 \
    --load_best_model_at_end True \
    --metric_for_best_model eval_accuracy \
    --apply_lora \
    --apply_sparse \
    --num_sparse 64 \
    --lora_r 1 \
    --evaluation_strategy steps > 0930_mnli_rank_1_sparse.out


OUTPUT_DIR='./mnli_rank_2_s1'
NCCL_P2P_DISABLE=1 CUDA_VISIBLE_DEVICES=0,1,2,3 nohup python -m torch.distributed.launch --nproc_per_node=$num_gpus --master_port=22349 non-GPT-2/examples/pytorch/text-classification/run_glue.py \
    --save_total_limit 20 \
    --model_name_or_path bert-base-uncased \
    --task_name mnli \
    --output_dir ${OUTPUT_DIR} \
    --do_train \
    --do_eval \
    --num_train_epochs 3 \
    --save_steps 500 \
    --seed 2 \
    --per_device_train_batch_size 8 \
    --max_seq_length 128 \
    --per_device_eval_batch_size 8 \
    --overwrite_output_dir \
    --logging_steps 500 \
    --load_best_model_at_end True \
    --metric_for_best_model eval_accuracy \
    --apply_lora \
    --apply_sparse \
    --num_sparse 64 \
    --lora_r 2 \
    --evaluation_strategy steps > 0930_mnli_rank_2_sparse.out

OUTPUT_DIR='./mnli_rank_4_s1'
NCCL_P2P_DISABLE=1 CUDA_VISIBLE_DEVICES=0,1,2,3 nohup python -m torch.distributed.launch --nproc_per_node=$num_gpus --master_port=22349 non-GPT-2/examples/pytorch/text-classification/run_glue.py \
    --save_total_limit 20 \
    --model_name_or_path bert-base-uncased \
    --task_name mnli \
    --output_dir ${OUTPUT_DIR} \
    --do_train \
    --do_eval \
    --num_train_epochs 3 \
    --save_steps 500 \
    --seed 2 \
    --per_device_train_batch_size 8 \
    --max_seq_length 128 \
    --per_device_eval_batch_size 8 \
    --overwrite_output_dir \
    --logging_steps 500 \
    --load_best_model_at_end True \
    --metric_for_best_model eval_accuracy \
    --apply_lora \
    --apply_sparse \
    --num_sparse 64 \
    --lora_r 4 \
    --evaluation_strategy steps > 0930_mnli_rank_4_sparse.out

OUTPUT_DIR='./mnli_rank_8_s1'
NCCL_P2P_DISABLE=1 CUDA_VISIBLE_DEVICES=0,1,2,3 nohup python -m torch.distributed.launch --nproc_per_node=$num_gpus --master_port=22349 non-GPT-2/examples/pytorch/text-classification/run_glue.py \
    --save_total_limit 20 \
    --model_name_or_path bert-base-uncased \
    --task_name mnli \
    --output_dir ${OUTPUT_DIR} \
    --do_train \
    --do_eval \
    --num_train_epochs 3 \
    --save_steps 500 \
    --seed 2 \
    --per_device_train_batch_size 8 \
    --max_seq_length 128 \
    --per_device_eval_batch_size 8 \
    --overwrite_output_dir \
    --logging_steps 500 \
    --load_best_model_at_end True \
    --metric_for_best_model eval_accuracy \
    --apply_lora \
    --apply_sparse \
    --num_sparse 64 \
    --lora_r 8 \
    --evaluation_strategy steps > 0930_mnli_rank_8_sparse.out

OUTPUT_DIR='./mnli_rank_16_s1'
NCCL_P2P_DISABLE=1 nohup python -m torch.distributed.launch --nproc_per_node=$num_gpus --master_port=22349 non-GPT-2/examples/pytorch/text-classification/run_glue.py \
    --save_total_limit 20 \
    --model_name_or_path bert-base-uncased \
    --task_name mnli \
    --output_dir ${OUTPUT_DIR} \
    --do_train \
    --do_eval \
    --num_train_epochs 3 \
    --save_steps 500 \
    --seed 2 \
    --per_device_train_batch_size 8 \
    --max_seq_length 128 \
    --per_device_eval_batch_size 8 \
    --overwrite_output_dir \
    --logging_steps 500 \
    --load_best_model_at_end True \
    --metric_for_best_model eval_accuracy \
    --apply_lora \
    --apply_sparse \
    --num_sparse 64 \
    --lora_r 16 \
    --evaluation_strategy steps > 0930_mnli_rank_16_sparse.out

OUTPUT_DIR='./mnli_rank_32_s1'
NCCL_P2P_DISABLE=1 nohup python -m torch.distributed.launch --nproc_per_node=$num_gpus --master_port=22349 non-GPT-2/examples/pytorch/text-classification/run_glue.py \
    --save_total_limit 20 \
    --model_name_or_path bert-base-uncased \
    --task_name mnli \
    --output_dir ${OUTPUT_DIR} \
    --do_train \
    --do_eval \
    --num_train_epochs 3 \
    --save_steps 500 \
    --seed 2 \
    --per_device_train_batch_size 8 \
    --max_seq_length 128 \
    --per_device_eval_batch_size 8 \
    --overwrite_output_dir \
    --logging_steps 500 \
    --load_best_model_at_end True \
    --metric_for_best_model eval_accuracy \
    --apply_lora \
    --apply_sparse \
    --num_sparse 64 \
    --lora_r 32 \
    --evaluation_strategy steps > 0930_mnli_rank_32_sparse.out


OUTPUT_DIR='./mnli_rank_64_s1'
NCCL_P2P_DISABLE=1 nohup python -m torch.distributed.launch --nproc_per_node=$num_gpus --master_port=22349 non-GPT-2/examples/pytorch/text-classification/run_glue.py \
    --save_total_limit 20 \
    --model_name_or_path bert-base-uncased \
    --task_name mnli \
    --output_dir ${OUTPUT_DIR} \
    --do_train \
    --do_eval \
    --num_train_epochs 3 \
    --save_steps 500 \
    --seed 2 \
    --per_device_train_batch_size 8 \
    --max_seq_length 128 \
    --per_device_eval_batch_size 8 \
    --overwrite_output_dir \
    --logging_steps 500 \
    --load_best_model_at_end True \
    --metric_for_best_model eval_accuracy \
    --apply_lora \
    --apply_sparse \
    --num_sparse 64 \
    --lora_r 64 \
    --evaluation_strategy steps > 0930_mnli_rank_64_sparse.out
