import cfg


def create():
    tasks = []

    # standard settings
    dataset_type = '2k'
    max_train_samples = 1400
    if dataset_type == '2k':
        max_train_samples = 2000
    train_paradigm = 'sl'
    weight_init = 'tl'
    training = 'frozen'
    init_train_sample = 20
    add_train_sample = 20

    for random_seed in range(5):
        for qm in ['random', 'ratio_max']:
            for dataset in ['cifar10', 'mscoco']:

                # test initial budget and query budget
                for current_budget in cfg.all_budgets:
                    fname_result = (f'{dataset}_{dataset_type}_{random_seed}_{current_budget}_{current_budget}_'
                                    f'{max_train_samples}_{train_paradigm}_{weight_init}_{training}_{qm}')
                    new_task = (dataset, dataset_type, random_seed, current_budget, current_budget,
                                max_train_samples, train_paradigm, weight_init, training, qm, fname_result)
                    tasks.append(new_task)

                # test supervised and semi-supervised learning
                for current_train_paradigm in cfg.all_train_paradigms:
                    for current_budget in [20, 200]:
                        fname_result = (f'{dataset}_{dataset_type}_{random_seed}_{current_budget}_{current_budget}_'
                                        f'{max_train_samples}_{current_train_paradigm}_{weight_init}_{training}_{qm}')
                        new_task = (dataset, dataset_type, random_seed, current_budget, current_budget,
                                    max_train_samples, current_train_paradigm, weight_init, training, qm, fname_result)
                        tasks.append(new_task)

                # test weight_initialisations
                for current_weight_init in cfg.all_weight_inits:
                    current_training = 'finetune'
                    fname_result = (f'{dataset}_{dataset_type}_{random_seed}_{init_train_sample}_{add_train_sample}_'
                                    f'{max_train_samples}_{train_paradigm}_{current_weight_init}_{current_training}_'
                                    f'{qm}')
                    new_task = (dataset, dataset_type, random_seed, init_train_sample, add_train_sample,
                                max_train_samples, train_paradigm, current_weight_init, current_training, qm,
                                fname_result)
                    tasks.append(new_task)

                # test training (which layers stay frozen in Transfer Learning scenarious)
                for current_training in cfg.all_training:
                    fname_result = (f'{dataset}_{dataset_type}_{random_seed}_{init_train_sample}_{add_train_sample}_'
                                    f'{max_train_samples}_{train_paradigm}_{weight_init}_{current_training}_'
                                    f'{qm}')
                    new_task = (dataset, dataset_type, random_seed, init_train_sample, add_train_sample,
                                max_train_samples, train_paradigm, weight_init, current_training, qm,
                                fname_result)
                    tasks.append(new_task)

    # add tasks for all datasets
    budget = 20
    train_paradigm = 'sl'
    weight_init = 'tl'
    training = 'frozen'
    for dataset in cfg.all_datasets:
        for qm in cfg.all_qms:
            for dataset_type in cfg.all_dataset_types:
                if dataset_type == '2k':
                    nr_random_seeds = cfg.random_seeds_2k
                    max_train_samples = cfg.max_train_samples_2k
                    if dataset == 'scene':
                        max_train_samples = 1927
                elif dataset_type == 'complete':
                    nr_random_seeds = cfg.random_seeds_complete
                    max_train_samples = cfg.max_train_samples_complete

                for random_seed in range(nr_random_seeds):
                    fname_result = (f'{dataset}_{dataset_type}_{random_seed}_{budget}_{budget}_{max_train_samples}_'
                                    f'{train_paradigm}_{weight_init}_{training}_{qm}')
                    new_task = (dataset, dataset_type, random_seed, budget, budget, max_train_samples, train_paradigm,
                                weight_init, training, qm, fname_result)
                    tasks.append(new_task)

    # remove dublicate tasks
    tasks = list(set(tasks))

    # check validity of tasks
    valid_tasks = []
    for task in tasks:
        (dataset, dataset_type, random_seed, init_train_sample, add_train_sample, max_train_samples, train_paradigm,
         weight_init, training, qm, fname_result) = task
        if (
                (dataset in cfg.datasets) and
                (dataset_type in cfg.dataset_types) and
                (init_train_sample in cfg.init_train_samples) and
                (add_train_sample in cfg.add_train_samples) and
                (train_paradigm in cfg.train_paradigms) and
                (qm in cfg.qms) and
                (weight_init in cfg.weight_inits) and
                (training in cfg.trainings)):
            valid_tasks.append(task)

    return valid_tasks
