import json
import argparse
from trainer import train
import random

ep_arr = [3, 5, 10, 15, 20, 25]
milestone_arr = [2, 3, 4]

lr_arr = [0.000875, 0.001375, 0.001875, 0.002375, 0.0025]
lr_decay_arr = [0.1, 0.3, 0.5]
batch_arr = [8, 16, 24, 48, 64, 128]
w_decay_arr = [0, 0.0001, 0.0005]
scheduler_arr = ['steplr', 'cosine', 'constant']
optimizer_arr = ['sgd', 'adam', 'adamw']

e_pool_size_arr = [30, 50, 100, 200, 300] # pool size 100 [5, 500]
e_p_length_arr=[4, 8, 16, 24, 32] #  prompt legnth 8  : [4, 40]
ortho_mu_arr = [0.2, 0.1, 0.01, 0.001, 0] # orthogonality 0 [1e−6 up to 1e2]

#SEED 부분 정리필요
seed_arr = [0,1,2,3,4]
total_rand_num = 10

def main():
    args = setup_parser().parse_args()
    param = load_json(args.config)
    args = vars(args)  # Converting argparse Namespace to a dict.
    args.update(param)  # Add parameters from json
    
    for rand_num in range(6, total_rand_num):
        
        ep = random.choice(ep_arr)
        milestone_num = random.choice(milestone_arr)
        lr = random.choice(lr_arr)
        lr_decay = random.choice(lr_decay_arr)
        batch = random.choice(batch_arr)
        w_decay = random.choice(w_decay_arr)
        scheduler = random.choice(scheduler_arr)
        optimizer = random.choice(optimizer_arr)
        seed = random.choice(seed_arr)
        
        e_pool_size = random.choice(e_pool_size_arr)
        e_p_length = random.choice(e_p_length_arr)
        ortho_mu = random.choice(ortho_mu_arr)
        
        prompt_param = [e_pool_size, e_p_length, ortho_mu]
        
        if milestone_num == 2:
            
            milestones = [int(ep*(2/5)), int(ep*(4/5))]
            
        elif milestone_num == 3:
            
            milestones = [int(ep*(2/7)), int(ep*(4/7)), int(ep*(6/7))]
            
        elif milestone_num == 4:
            
            milestones = [int(ep*(2/9)), int(ep*(4/9)), int(ep*(6/9)), int(ep*(8/9))]
            
        
        prefix = "rand_num_{}_ep_{}_milestone_{}_lr_{}_lr_decay_{}_batch_{}_w_decay_{}_scheduler_{}_optimizer_{}_e_pool_size_{}_e_p_length_{}_ortho_mu_{}".format(
                        rand_num,
                        ep,
                        milestone_num,
                        lr,
                        lr_decay,
                        batch,
                        w_decay,
                        scheduler,
                        optimizer,
                        e_pool_size,
                        e_p_length,
                        ortho_mu,
                    )

        parameters = {
            "seed":seed_arr, 
            "prefix":prefix, 
            "epochs":ep,
            "lrate":lr,
            "milestones":milestones,
            "lrate_decay":lr_decay,
            "batch_size":batch,
            "weight_decay":w_decay,
            "scheduler":scheduler,
            "optimizer":optimizer,
            "prompt_param":prompt_param
        }
        args.update(parameters)  # Add parameters from json

        print (args)

        train(args)
                        
    


def load_json(settings_path):
    with open(settings_path) as data_file:
        param = json.load(data_file)

    return param


def setup_parser():
    parser = argparse.ArgumentParser(description='Reproduce of multiple continual learning algorthms.')
    parser.add_argument('--config', type=str, default='./exps/finetune.json',
                        help='Json file of settings.')

    return parser


if __name__ == '__main__':
    main()
