import argparse

from src.experiments import tasks, active_learning
from src.preprocessing import init_train_set, preprocessing
import cfg

# Parse command-line arguments
parser = argparse.ArgumentParser(description='Run the script with custom configuration.')
parser.add_argument('--datasets', type=str, nargs='+', help='Specify the dataset',
                    default=cfg.all_datasets)
parser.add_argument('--dataset_types', type=str, nargs='+', help='Specify the dataset type',
                    default=cfg.all_dataset_types)
parser.add_argument('--budgets', type=int, nargs='+', help='Specify initial and query budget size',
                    default=cfg.all_budgets)
parser.add_argument('--train_paradigms', type=str, nargs='+', help='Specify training paradigms',
                    default=cfg.all_train_paradigms)
parser.add_argument('--qms', type=str, nargs='+', help='Specify the query methods',
                    default=cfg.all_qms)
parser.add_argument('--weight_inits', type=str, nargs='+', help='Specify the query methods',
                    default=cfg.all_weight_inits)
parser.add_argument('--trainings', type=str, nargs='+', help='Specify the training',
                    default=cfg.all_training)
parser.add_argument('--nr_processing_pool', type=int, help='Specify the number of parallel processes',
                    default=10)

# DELETE AFTER CARINA BADGE
parser.add_argument('--random_seeds', type=int, nargs='+',
                    default=[0])
# DELETE AFTER CARINA BADGE


args = parser.parse_args()
if args:
    cfg.initialize_config(args)

print('START MAIN: SUCCESSFULL')

# unify datasets
preprocessing.unify_datasets()

# create initial training sets for all experiments
init_train_set.create()

# create tasks
all_tasks = tasks.create()

# DELETE AFTER CARINA BADGE
all_tasks = [task for task in all_tasks if task[2] in args.random_seeds]
# DELETE AFTER CARINA BADGE

# run experiments
active_learning.conduct(all_tasks)
