import numpy as np

from utils.evaluation import MetricsDAG

np.set_printoptions(formatter={'float': lambda x: "{:f}".format(x)})

# DREAM-3
# CUTS_auroc = [0.5835439003847117, 0.581352864850099, 0.6268467299506022, 0.5885405996039063, 0.6036786632975938, 0.5835439003847117, 0.6333003255252794, 0.6023298959684946, 0.5785870381752373, 0.5998315463588973]
# NGM_auroc = [0.5677912085410549, 0.5674838944660702, 0.5680985226160394, 0.5677912085410549, 0.5680985226160394, 0.5680985226160394, 0.5677912085410549, 0.5674838944660702, 0.567483894466070, 0.5677912085410549]
# DyCausal_auroc = [0.6394864440346923, 0.6214118236244849, 0.6459741856177013, 0.6645951421612146, 0.6353946140362858, 0.6297093036490701, 0.6331295954836214, 0.6396230280680187, 0.6645951421612146, 0.6587561747365065]
# CUTS_precision = [0.0526, 0.0625, 0.0323, 0.0968, 0.08, 0.0588, 0.0526, 0.0909, 0.0625, 0.0625]
# NGM_precision = [0.0645, 0.04, 0.0261, 0.049, 0.0259, 0.0274, 0.0213, 0.0319, 0.0187, 0.021]
# DyCausal_precision = [0.0909, 0.1628, 0.1263, 0.1538, 0.15, 0.165, 0.1905, 0.1667, 0.1386, 0.2051]
# # Phoenix
# NGM_auroc = [0.4795640979582061, 0.4996197832465122, 0.4917010957427699, 0.4982156757080414, 0.48300101790311956, 0.48378240823902763, 0.4932159750913119, 0.510113166876235, 0.4966049937129513, 0.49769774265014066]
# CUTS_auroc = [0.505906831926232, 0.5148224657206156, 0.4988413867433088, 0.5108107298964134, 0.5060265852344171, 0.5051733429135981, 0.48562062151966956, 0.5120382013053111, 0.5233548889288067, 0.5191605293096222]
# DyCausal_auroc = [0.539919765283516, 0.5469762289683253, 0.5252380097000179, 0.5341386743308784, 0.5319771271181367, 0.5340668223459673, 0.5372402850128735, 0.549266510987366, 0.5387072630381413, 0.5307975570325131]
# NGM_precision = [0.468, 0.4731, 0.4614, 0.4708, 0.4532, 0.4602, 0.4646, 0.4614, 0.4505, 0.4685]
# CUTS_precision = [0.5012, 0.4914, 0.5088, 0.5012, 0.5, 0.4751, 0.5127, 0.5242, 0.518]
# DyCausal_precision = [0.5446, 0.5212, 0.5254, 0.5252, 0.5256, 0.5301, 0.5372, 0.5331, 0.5157, 0.5217]
# mean = np.mean(DyCausal_auroc)
# std = np.std(DyCausal_auroc)
# print(f"{mean:.4f}", f"{std:.4f}")

# read dynamic graphs
# est_W = np.load('W_est.npy')
# true_W = np.load('B_trues.npy')
# print(est_W.shape, true_W.shape)
# # A = (est_W[1:, :, :] - est_W[:-1, :, :]) / 2
# # Ws = [est_W[:-1, :, :]]
# # for i in range(1, 2):
# #     Ws.append(A * i + est_W[:-1, :, :])
# # Ws = np.stack(Ws, axis=1)
# # Ws = np.concatenate(Ws, axis=0)
# # Ws = np.concatenate([Ws, est_W[-1:]], axis=0)
# # print(Ws.shape)
# tpr = []
# fdr = []
# f1 = []
# shd = []
# for i in range(est_W.shape[0]):
#     met = MetricsDAG(abs(est_W[i] > 0.15).astype(int), (abs(true_W[i]) > 0).astype(int)).metrics
#     tpr.append(f"{met['tpr']*100:.2f}")
#     fdr.append(f"{met['fdr']*100:.2f}")
#     f1.append(f"{met['F1']*100:.2f}")
#     shd.append(f"{met['shd']:.2f}")
# print(tpr)
# print(fdr)
# print(f1)
# print(shd)

# read dyanmic results
with open('D:/学习/我的论文/DyCausal/结果/results/NTS-NOTEARS_dy_result.txt', 'r') as file:
    times = []
    tpr = []
    f1 = []
    shd = []
    for line in file:
        matrics = line.split(',matrics')
        time = matrics[0].split(':')[-1]
        matrics = eval(matrics[1])
        times.append(float(time))
        tpr.append(matrics['tpr'])
        f1.append(matrics['F1'])
        shd.append(matrics['shd'])
    matrics = np.array([times, tpr, f1, shd])
    W1_matrics = matrics[:, [i * 3 for i in range(9, 19)]]
    W25_matrics = matrics[:, [i * 3 + 1 for i in range(9, 19)]]
    W50_matrics = matrics[:, [i * 3 + 2 for i in range(9, 19)]]
    W1_mean = np.mean(W1_matrics, axis=1)
    W1_std = np.std(W1_matrics, axis=1)
    W25_mean = np.mean(W25_matrics, axis=1)
    W25_std = np.std(W25_matrics, axis=1)
    W50_mean = np.mean(W50_matrics, axis=1)
    W50_std = np.std(W50_matrics, axis=1)
    print(format(W1_mean), W1_std)
    print(W25_mean, W25_std)
    print(W50_mean, W50_std)

# real static results
# with open('C:/Users/14515/Desktop/results/NTS-NOTEARS_result.txt', 'r') as file:
#     times = []
#     tpr = []
#     f1 = []
#     shd = []
#     for line in file:
#         matrics = line.split(',matrics')
#         time = matrics[0].split(':')[-1]
#         matrics = eval(matrics[1])
#         times.append(float(time))
#         tpr.append(matrics['tpr'])
#         f1.append(matrics['F1'])
#         shd.append(matrics['shd'])
#     matrics = np.array([times, tpr, f1, shd])
#     for i in range(4):
#         matric = matrics[:, i*10:(i+1)*10]
#         mean = np.mean(matric, axis=1)
#         std = np.std(matric, axis=1)
#         print(mean, std)

