from copy import deepcopy
from multiprocessing import Process, Queue
from itertools import product
import sys, os
import numpy as np
import time
import argparse

sys.path.append(os.path.abspath("."))

# note: new algorithm code
def kwargs_to_cmd(kwargs):
    cmd = "/ext3/miniconda3/bin/python3 basis_single_random_task.py "
    for flag, val in kwargs.items():
        cmd += f"--{flag}={val} "
    cmd +="--train_mask_alphas "
    cmd +="--single_task_only "

    return cmd


def run_exp(gpu_num, in_queue):
    while not in_queue.empty():
        try:
            experiment = in_queue.get(timeout=3)
        except:
            return

        before = time.time()

        experiment["multigpu"] = gpu_num
        print(f"==> Starting experiment {kwargs_to_cmd(experiment)}")
        os.system(kwargs_to_cmd(experiment))

        with open("output.txt", "a+") as f:
            f.write(
                f"Finished experiment {experiment} in {str((time.time() - before) / 60.0)}."
            )


def main():
    parser = argparse.ArgumentParser()
    parser.add_argument('--gpu-sets', default=[0], type=lambda x: [a for a in x.split("|") if a])
    parser.add_argument('--seeds', default=[0], type=lambda x: [int(a) for a in x.split(',')])
    parser.add_argument('--sparsities', type=lambda x: [int(a) for a in x.split(',')], default=[25,30,35,40])
    parser.add_argument('--data', default='/scratch/data', type=str)
    parser.add_argument('--seed_model_dir', default='/scratch/seed_models_{num_masks}/id\=supsup~seed\={seed}~sparsity\={sparsity}~try\={try}/', type=str)
    parser.add_argument('--num-masks', default=20, type=int)
    parser.add_argument('--single_task_only_task', type=int, default=0)
    parser.add_argument('--logdir-prefix', type=str)
    parser.add_argument('--epochs', type=int, default=150)
    parser.add_argument('--lr', type=str, default='0.005')
    parser.add_argument('--al', type=float, default=0.005)
    parser.add_argument('--batch-size', type=int, default=64)
    args = parser.parse_args()

    gpus = args.gpu_sets
    seeds = args.seeds
    data = args.data

#    config = "experiments/basis/splitcifar100/configs/rn18-supsup-basis-multitask-extended.yaml"
    config = "experiments/basis/splitcifar100/configs/rn18-supsup-basis-multitask.yaml"
    log_dir = "{scratch}/runs/{logdir_prefix}/SupsupBasisRand/rn18-supsup_basis_num_masks_{num_masks}".format(num_masks=str(args.num_masks), scratch=os.environ.get("SCRATCH"), logdir_prefix=args.logdir_prefix)
    experiments = []
    sparsities = args.sparsities

    # at change for 1 epoch to check dir
    model_seed = int(args.seed_model_dir.split('=')[1].split('/')[0])
    for sparsity, seed in product(sparsities, seeds):
        kwargs = {
            "config": config,
            "name": f"id=basis-supsup-single-task~model_seed={model_seed}~seed={seed}~sparsity={sparsity}",
            "log-dir": log_dir,
            "epochs": 75,
            "batch-size": int(args.batch_size),
            "num-seed-tasks-learned": int(args.num_masks),
            "lr": float(args.lr),
            "data": data,
            "seed-model-format": "{}/final.pt".format(args.seed_model_dir),
            "single_task_only_task": args.single_task_only_task,
            "al": args.al,
            "wd": 0.01,
            "seed": seed,
            "sparsity": sparsity,
            "trainer": "alphareg"
        }

        experiments.append(kwargs)

    print(experiments)
    queue = Queue()

    for e in experiments:
        queue.put(e)

    processes = []
    for gpu in gpus:
        p = Process(target=run_exp, args=(gpu, queue))
        p.start()
        processes.append(p)

    for p in processes:
        p.join()


if __name__ == "__main__":
    main()
