import time
import pandas as pd
import numpy as np
from statsmodels.tsa.stattools import grangercausalitytests

start_time = time.time()
data = pd.read_csv('/dataset/exchange_rate/exchange_rate.csv', header=0)
data = data.iloc[:, 1:]
col_names = data.columns
data_array = data.values

maxlag = 5
n_vars = data.shape[1]

#results[(cause, effect)] = dict_of_lags
results = {}

for i in range(n_vars):
    for j in range(n_vars):
        if i != j:

            cName_i = col_names[i]  # effect
            cName_j = col_names[j]  # cause

            df_ij = data[[cName_i, cName_j]].dropna()
            test_result = grangercausalitytests(df_ij, maxlag=maxlag, verbose=False)
            results[(cName_j, cName_i)] = test_result

end_time = time.time()
print("Time used for Granger tests: {:.2f} seconds".format(end_time - start_time))

coeff = np.full((n_vars, n_vars), np.nan, dtype=float)  # (D x D)

for i in range(n_vars):
    for j in range(n_vars):
        if i != j:

            iName = col_names[i]
            jName = col_names[j]
            key = (iName, jName)  # i->j
            if key in results:
                test_info = results[key]

                pvals = []
                for lag, val in test_info.items():
                    # val[0]['ssr_ftest'] => (F, p, df_denom, df_num)
                    f_val, p_val, _, _ = val[0]['ssr_ftest']
                    pvals.append(p_val)
                min_p = min(pvals) if pvals else np.nan
                coeff[i, j] = min_p

# coeff_df = pd.DataFrame(coeff, index=col_names, columns=col_names)
# print(coeff_df)

import matplotlib.pyplot as plt

raw = np.array(coeff)
vars_ = [f'V{i+1}' for i in range(raw.shape[0])]
p_df  = pd.DataFrame(raw, index=vars_, columns=vars_)

logp_df = -np.log10(p_df)
logp_df.replace([np.inf, -np.inf], np.nan, inplace=True)

fig, ax = plt.subplots(figsize=(7, 6))
im = ax.imshow(logp_df.values, cmap='Reds', aspect='auto')

cbar = fig.colorbar(im, ax=ax)
cbar.set_label(r'$-\log_{10}(p)$', rotation=270, labelpad=15)

ax.set_xticks(range(len(vars_)))
ax.set_yticks(range(len(vars_)))
ax.set_xticklabels(vars_, rotation=90)
ax.set_yticklabels(vars_)
# ax.set_title("Granger causality: -log10(p) single‑hue heat‑map")

plt.tight_layout()

fig = plt.gcf()

out_file = "granger_Exchange.pdf"

fig.savefig(
    out_file,
    format='pdf',
    bbox_inches='tight',
    pad_inches=0,
    dpi=300
)

print(f"Save as {out_file}")

plt.show()
