import numpy as np
import os
import random

np.set_printoptions(suppress=True)

from utils import sample, stopping_rule, sticky_weights, sequence_weights, update_mean_online, \
    forced_exploration, get_answer


def fix_seed(seed_val):
    if seed_val is not None:
        os.environ["PYTHONHASHSEED"] = str(seed_val)

        random.seed(seed_val)
        np.random.seed(seed_val)


def mkdir_if_not_exist(directory):
    if not os.path.exists(directory):
        os.makedirs(directory)


def run(run_id,
        seed,
        algo,
        delta,
        eps,
        mu,
        debug=False):
    print(f"Run {run_id} started.")

    # Fix seed
    fix_seed(seed)

    mu_hat = np.array([sample(m) for m in mu])
    nt = np.array([1, 1, 1, 1])
    t = 5

    cum_w = np.array([1 / 4, 1 / 4, 1 / 4, 1 / 4])

    prev_answer = None

    while not stopping_rule(nt, mu_hat, delta, eps, t):

        if algo == "sticky-tas":
            wt = sticky_weights(nt, mu_hat, t)
        elif algo == "sticky-sequence-tas":
            wt, answer = sequence_weights(nt, mu_hat, t, prev_answer)
            prev_answer = answer
        else:
            raise RuntimeError()

        # Project wt for forced exploration
        wt = forced_exploration(wt, t)

        cum_w += wt
        A_t = np.argmax(cum_w - nt)

        new_data = sample(mu[A_t])
        mu_hat[A_t] = update_mean_online(nt[A_t], mu_hat[A_t], new_data)
        nt[A_t] += 1
        t += 1

    final_answer = get_answer(nt, mu_hat, eps)

    correct = False
    if ((abs(mu[0] - final_answer[0]) <= eps and abs(mu[1] - final_answer[1]) <= eps) or
            (abs(mu[2] - final_answer[0] <= eps) and abs(mu[3] - final_answer[1])) <= eps):
        correct = True
        if debug:
            print(f"Run id: {run_id}: Correct")
    else:
        if debug:
            print(f"Run id: {run_id}: Not correct")

    if debug:
        print(f"Run id: {run_id}, final answer: {final_answer}")
        print(f"Run id: {run_id}, pulls: {nt}")
        print()

    return [final_answer, nt]
