# Defining main function
import multiprocessing
from random import random
import datetime
from itertools import repeat
from functools import partial
from itertools import repeat
from multiprocessing import Pool, freeze_support

import numpy as np
import pandas as pd

from SBM2 import SBM2
from SBM_dev import SBM

def task(m, n, x):
    np.random.seed(x)
    k = 2
    #n = 1500
    #m = 2
    p = 6/100
    q = 4/100
    a = n*p
    b = n*q
    s = SBM2(k=k, n=n, a=a, b=b, m=m)
    M_norm, sin_angle, gamma, sin_vector = s.run(do_deletion=False, do_red_blue=False, do_naive=False)
    return M_norm, sin_angle, gamma, sin_vector

def log(content: str):
    now_str = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
    print(now_str + content)
    with open("log.txt", "a") as f:
        f.write(now_str + content + "\n")


def main():
    print("starting")
    n_values = [500]
    m_values = [2]

    results_df = pd.DataFrame(columns=['m','M_max', 'M_mean', 'M_std', 'sin_max', 'sin_mean', 'sin_std', 'gamma_max', 'gamma_mean', 'gamma_std'])
    for n in n_values:
        for m in m_values:
            log("*****************")
            log("starting" + str(n))
            log("*****************")
            repetitions = 2

            first_arg = [m, n]
            second_args = range(repetitions)
            with Pool() as pool:
                 results = pool.starmap(task, zip(repeat(first_arg), second_args))

            M_norms = []
            sin_angles = []
            gammas = []
            sin_vectors = []
            for result in results:
                M_norms.append(result[0])
                sin_angles.append(result[1])
                gammas.append(result[2])
                sin_vectors.append(result[3])

            row = pd.DataFrame({'m': [m],
                                'n': [n],
                                'M_max': [max(M_norms)],
                                'M_mean': [np.mean(M_norms)],
                                'M_std': [np.std(M_norms)],
                                'sin_max': [np.max(sin_angles)],
                                'sin_mean': [np.mean(sin_angles)],
                                'sin_std': [np.std(sin_angles)],
                                'gamma_max': [np.max(gammas)],
                                'gamma_mean': [np.mean(gammas)],
                                'gamma_std': [np.std(gammas)],
                                'sin_vector_max': [np.max(sin_vectors)],
                                'sin_vector_mean': [np.mean(sin_vectors)],
                                'sin_vector_std': [np.std(sin_vectors)],
                             })
            results_df = pd.concat([results_df, row], ignore_index=True)
            log(str(results_df))
            log("end")

    print(results_df)
    now_str = datetime.datetime.now().strftime("%Y%m%d_%H%M%S")

    results_df.to_csv("results_"  + now_str + ".csv", index=False)


# Using the special variable
# __name__
if __name__=="__main__":
    main()