#! /bin/bash

export PYTHONPATH="/home/****/Documents/nonconvex-continual-learning"
# put your home path"

# python -m run nccl --transform permutation --raw_data mnist --num_tasks 20 --l_coeff 0.01 \
#                --learning_rate 0.005 --memory_size 250 --batch_size 128 \
#                --sample_memory_batch 30 50 150 250 --epochs_per_task 1 --delta 0.5 \
#                --network_architecture [400,400] --shuffle_tasks

# python -m run nccl --transform permutation --raw_data mnist --num_tasks 20 --l_coeff 0.01 \
#                --learning_rate 0.001 --memory_size 500 --batch_size 128 \
#                --sample_memory_batch 128 --epochs_per_task 1 --delta 0.5 \
#                --network_architecture [256,256] --shuffle_tasks --seed 0 10 20 40

# python -m run nccl --transform permutation --raw_data mnist --num_tasks 20 --l_coeff 0.01 \
#                --learning_rate 0.001 --memory_size 250 200 100 --batch_size 100 \
#                --sample_memory_batch 100 50 30 --epochs_per_task 1 --delta 0.5 \
#                --network_architecture [256,256] --shuffle_tasks --exp_name one_minus_alpha \
#                --seed 1 13 15 19 200

# python -m run nccl --transform permutation --raw_data mnist --num_tasks 20 --l_coeff 0.01 0.1 1 \
#                --learning_rate 0.001 0.0005 0.003 0.007 --memory_size 250 --batch_size 100 \
#                --sample_memory_batch 30 --epochs_per_task 1 --delta 0.5 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1 13 15 19 200

# python -m run nccl --transform permutation --raw_data mnist --num_tasks 20 --l_c 1.5 \
#                --learning_rate 0.0005 --memory_size 256 --batch_size 100 \
#                --sample_memory_batch  10 30 50 100 200 --epochs_per_task 1 --memory random\
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1 13 15 --exp_name nccl_lr5e-4_mem256

# python -m run nccl --transform permutation --raw_data mnist --num_tasks 20 --l_upper_bound 2.0 \
#                --learning_rate 0.0005 --memory_size 256 --batch_size 16 --memory reservoir \
#                --sample_memory_batch  10 30 50 100 200 --epochs_per_task 1 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1 13 15 --exp_name final

############### mnist-split ##########################


# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 0.5 0.3 0.1  \
#                --learning_rate 0.0005 0.002 --memory_size 256 --batch_size 128 --memory random \
#                --sample_memory_batch  10 --epochs_per_task 5 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1  --exp_name mnist_split_smallL

# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 1  \
#                --learning_rate 0.0005 --memory_size 256 --batch_size 50 --memory random \
#                --sample_memory_batch  10 --epochs_per_task 5 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1  --exp_name mnist_split_smallL22

# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 1  \
#                --learning_rate 0.0005 --memory_size 256 --batch_size 50 --memory random \
#                --sample_memory_batch  10 --epochs_per_task 5 \
#                --network_architecture [400,400] --shuffle_tasks \
#                --seed 1  --exp_name mnist_split_small_fc400

# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 1  \
#                --learning_rate 0.0001 --memory_size 100 --batch_size 100 --memory random \
#                --sample_memory_batch  10 100 --epochs_per_task 5 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1  --exp_name ms_mem100_lr1e-4

# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 1  \
#                --learning_rate 0.0001 --memory_size 256 --batch_size 100 --memory random \
#                --sample_memory_batch  100 --epochs_per_task 5 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1  --exp_name ms_mem256_lr1e-4

# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 3  \
#                --learning_rate 0.0001 --memory_size 256 --batch_size 100 --memory random \
#                --sample_memory_batch  100 --epochs_per_task 5 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1  --exp_name ms_mem256_lr1e-4

# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 0.5  \
#                --learning_rate 0.0001 --memory_size 256 --batch_size 100 --memory random \
#                --sample_memory_batch  100 --epochs_per_task 5 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1  --exp_name ms_mem256_lr1e-4_l0.5

# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 0.5 0.3 1 3 5  \
#                --learning_rate 0.0001 --memory_size 256 --batch_size 100 --memory random \
#                --sample_memory_batch  100 --epochs_per_task 5 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1  --exp_name ms_mem256_lr1e-4

# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 2 3 4 5  \
#                --learning_rate 0.0001 --memory_size 256 --batch_size 100 50 30 20 10 5 --memory reservoir \
#                --sample_memory_batch  100 --epochs_per_task 5 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1  --exp_name ms_mem256_resevoir_highl

# python -m run nccl --transform split --raw_data cifar10 --num_tasks 5 --l_upper_bound 5  \
#                 --learning_rate 0.0001 --memory_size 256 --batch_size 10 --memory reservoir \
#                 --sample_memory_batch  100 --epochs_per_task 5 \
#                 --network_architecture -1  --shuffle_tasks \
#                 --seed 1  --exp_name cifar10


# online


# adagrad
# python -m run nccl --transform split --raw_data cifar10 --num_tasks 5 --l_upper_bound 25  \
#                --learning_rate 0.0002 --memory_size 1000 --batch_size 10 --memory reservoir \
#                --sample_memory_batch  10 --epochs_per_task 1 --beta_max 0.7 1.0 2.0 3.0 4.0 5.0 8.0 10.0 25.0 50.0 100.0 \
#                --network_architecture [-1] --shuffle_tasks False \
#                --seed 111 --exp_name cifar_clip_resp

# adam clip both learning rates respectively
# python -m run nccl --transform split --raw_data cifar10 --num_tasks 5 --l_upper_bound 25  \
#                --learning_rate 0.0002 --memory_size 1000 --batch_size 10 --memory reservoir \
#                --sample_memory_batch  10 --epochs_per_task 1 --beta_max 0.7 1.0 2.0 3.0 4.0 5.0 8.0 10.0 25.0 50.0 100.0 \
#                --network_architecture [-1] --shuffle_tasks False \
#                --seed 111 --exp_name cifar_clip_resp_adam

# adam clip curr only
# python -m run nccl --transform split --raw_data cifar10 --num_tasks 5 --l_upper_bound 25  \
#                --learning_rate 0.0002 --memory_size 1000 --batch_size 10 --memory reservoir \
#                --sample_memory_batch  10 --epochs_per_task 1 --beta_max 0.7 1.0 2.0 3.0 4.0 5.0 8.0 10.0 25.0 50.0 100.0 \
#                --network_architecture [-1] --shuffle_tasks False \
#                --seed 111 --exp_name cifar_clip_curr_only

python -m run nccl --transform split --raw_data cifar100 --num_tasks 20 --l_upper_bound 25  \
               --learning_rate 0.0001 0.0002 0.0005 --memory_size 1000 --batch_size 10 --memory reservoir \
               --sample_memory_batch  10 --epochs_per_task 1 --beta_max 5.0 \
               --network_architecture [-1] --shuffle_tasks False \
               --seed 111 --exp_name cifar100