import os
import pickle

import numpy as np
from joblib import Parallel, delayed

from results import ResultSummary, ResultItem
from run_utils import run, mkdir_if_not_exist

n_jobs = 1
n_runs = 100

mu = np.array([0, 75, 0, -75])
delta = 1e-80
eps = 0.1
algo = "sticky-sequence-tas"

results_dir = "results"


# Launch pure-exploration
seeds = [np.random.randint(1000000) for _ in range(n_runs)]
if n_jobs == 1:
    results = [run(run_id=id,
                   seed=seed,
                   algo=algo,
                   delta=delta,
                   eps=eps,
                   mu=mu
                   )
               for id, seed in zip(range(n_runs), seeds)]
else:
    results = Parallel(n_jobs=n_jobs, backend='loky')(
        delayed(run)(run_id=id,
                     seed=seed,
                     algo=algo,
                     delta=delta,
                     eps=eps,
                     mu=mu
                     )
        for id, seed in zip(range(n_runs), seeds))

results = [ResultItem(r[0], r[1]) for r in results]

result_summary = ResultSummary(experiments=results,
                               delta=delta,
                               epsilon=eps,
                               mu=mu,
                               x1=np.array([mu[0], mu[1]]),
                               x2=np.array([mu[2], mu[3]])
                               )

mkdir_if_not_exist(results_dir)
with open(os.path.join(results_dir, f"results_{algo}.pkl"), "wb") as output:
    pickle.dump(result_summary, output)
