#! /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


# epochs per task 20

# online

# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 2  \
#                --learning_rate 0.001 --memory_size 200 --batch_size 30 --memory random \
#                --sample_memory_batch  30 --epochs_per_task 1 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 1  --exp_name test_mnist_split

# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 2  \
#                --learning_rate 0.05 --memory_size 1000 --batch_size 30 --memory reservoir \
#                --sample_memory_batch  30 --epochs_per_task 5 \
#                --network_architecture [256,256] --shuffle_tasks \
#                --seed 3 --exp_name adagrad_mnist_split_reservoir_lr0.05

# success
# hidden layer [400, 400]
# python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 2  \
#                --learning_rate 0.01 --memory_size 500 --batch_size 10 --memory reservoir \
#                --sample_memory_batch  10 --epochs_per_task 1 --beta_max 0.7 1.0 1.5 2.0 5.0 10.0 \
#                --network_architecture [400,400] --shuffle_tasks \
#                --seed 1 --exp_name mnist_split_reservoir_nccl_ver_clip_1

python -m run nccl --transform split --raw_data mnist --num_tasks 5 --l_upper_bound 2  \
               --learning_rate 0.01 --memory_size 500 --batch_size 10 --memory reservoir \
               --sample_memory_batch  10 --epochs_per_task 1 --beta_max 1.5 2.0 3.0 4.0 5.0 \
               --network_architecture [400,400] --shuffle_tasks \
               --seed 2 5 6 --exp_name split_mnist_beta_max_adagrad


