import matplotlib.pyplot as plt
import numpy as np
from matplotlib.ticker import ScalarFormatter

# results on lienar
# x = [10, 20, 40, 80]
# dycausal_tpr = [0.97128, 0.9711, 0.96872, 0.98133]
# dynotears_tpr = [0.8546, 0.93379, 0.84455, 0.9633]
# pcmci_tpr = [0.95591, 0.96256, 0.97313, 0.97563]
# svam_tpr = [0.39785, 0.65354, 0.62301, 0.01506]
# tecdi_tpr = [0.8228, 0.8103, 0.7811]
#
# dycausal_f1 = [0.98447, 0.98517, 0.98403, 0.99055]
# dynotears_f1 = [0.91536, 0.96536, 0.87251, 0.98116]
# pcmci_f1 = [0.58868, 0.49374, 0.44349, 0.39005]
# svam_f1 = [0.4686, 0.70397, 0.70566, 0.01926]
# tecdi_f1 = [0.4248, 0.1775, 0.2114]
#
# dycausal_shd = [1.8, 3.4, 7.9, 9]
# dynotears_shd = [9.3, 8.2, 36.5, 17.6]
# pcmci_shd = [88.3, 244.1, 599.1, 1484]
# svam_shd = [52.6, 66.1, 125, 728.5]
# tecdi_shd = [332, 1685, 2643]
#
# dycausal_time = [151.099166, 150.53576, 211.32632, 282.804889]
# dynotears_time = [5.719541, 13.094282, 43.784778, 227.755472]
# pcmci_time = [3.840277, 17.387112, 83.186441, 421.159674]
# svam_time = [0.206797, 1.518361, 12.005926, 94.534254]
# tecdi_time = [741.2836, 6427.087, 24367.42586]
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 8))
# axs[0].plot(x, dycausal_tpr, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[0].plot(x, dynotears_tpr, '-D', color='red', linewidth='2', markersize=10, label='DYNO')
# axs[0].plot(x, pcmci_tpr, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[0].plot(x, svam_tpr, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[0].plot([10, 20, 40], tecdi_tpr, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks([10, 20, 40, 80])
# axs[0].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
# axs[1].plot(x, dycausal_f1, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[1].plot(x, dynotears_f1, '-D', color='red', linewidth='2', markersize=10, label='DYNO')
# axs[1].plot(x, pcmci_f1, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[1].plot(x, svam_f1, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[1].plot([10, 20, 40], tecdi_f1, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks([10, 20, 40, 80])
# axs[1].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[1].set_ylabel('F1', fontsize=30, fontweight='bold')
# axs[2].plot(x, dycausal_shd, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[2].plot(x, dynotears_shd, '-D', color='red', linewidth='2', markersize=10, label='DYNO')
# axs[2].plot(x, pcmci_shd, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[2].plot(x, svam_shd, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[2].plot([10, 20, 40], tecdi_shd, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks([10, 20, 40, 80])
# axs[2].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[2].set_ylim([0, 1000])
# axs[2].set_ylabel('SHD', fontsize=30, fontweight='bold')
# axs[3].plot(x, dycausal_time, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[3].plot(x, dynotears_time, '-D', color='red', linewidth='2', markersize=10, label='DYNO')
# axs[3].plot(x, pcmci_time, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[3].plot(x, svam_time, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[3].plot([10, 20, 40], tecdi_time, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks([10, 20, 40, 80])
# axs[3].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[3].set_ylim([0, 2000])
# axs[3].set_ylabel('Runtimes', fontsize=30, fontweight='bold')
# fig.add_subplot(1, 1, 1, frameon=False)
# plt.tick_params(labelcolor='none', top=False, bottom=False, left=False, right=False)
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower center', bbox_to_anchor=(0.48, 1), ncol=5)
# plt.savefig('results_linear.pdf')
# # plt.show()

# results on nonlinear
# x = [10, 20, 40, 80]
# dycausal_tpr = [0.92347, 0.92977, 0.88655, 0.85519]
# ntsnotears_tpr = [0.93329, 0.87866, 0.79228, 0.557244]
# pcmci_tpr = [0.78053, 0.75694, 0.73735, 0.71786]
# svam_tpr = [0.3663, 0.38508, 0.10022, 0.01129]
# tecdi_tpr = [0.9016, 0.839, 0.8553]
#
# dycausal_f1 = [0.93996, 0.94262, 0.90597, 0.90093]
# ntsnotears_f1 = [0.94001, 0.83372, 0.8108, 0.707456]
# pcmci_f1 = [0.5365, 0.50208, 0.46801, 0.41397]
# svam_f1 = [0.4688, 0.51268, 0.1333, 0.0164]
# tecdi_f1 = [0.3642, 0.1857, 0.0999]
#
# dycausal_shd = [7.1, 13.8, 43.8, 90.4]
# ntsnotears_shd = [7.2, 45.9, 90.2, 219.666667]
# pcmci_shd = [82.1, 183.7, 413.4, 977.3]
# svam_shd = [49.2, 90.1, 300.5, 655.4]
# tecdi_shd = [369, 1691, 6946]
#
# dycausal_time = [277.771511, 285.923374, 563.972924, 1756.307772]
# ntsnotears_time = [227.099289, 594.905129, 2876.891427, 22548.87927]
# pcmci_time = [3.149375, 14.576985, 71.518446, 468.628065]
# svam_time = [0.209499, 1.525882, 11.838731, 93.243963]
# tecdi_time = [920.7863696, 8720.37393, 24367.42586]
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 8))
# # 绘制折线图
# axs[0].plot(x, dycausal_tpr, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[0].plot(x, ntsnotears_tpr, '-D', color='red', linewidth='2', markersize=10, label='NTS-NO')
# axs[0].plot(x, pcmci_tpr, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[0].plot(x, svam_tpr, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[0].plot([10, 20, 40], tecdi_tpr, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks([10, 20, 40, 80])
# axs[0].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
# axs[1].plot(x, dycausal_f1, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[1].plot(x, ntsnotears_f1, '-D', color='red', linewidth='2', markersize=10, label='NTS-NO')
# axs[1].plot(x, pcmci_f1, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[1].plot(x, svam_f1, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[1].plot([10, 20, 40], tecdi_f1, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks([10, 20, 40, 80])
# axs[1].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[1].set_ylabel('F1', fontsize=30, fontweight='bold')
# axs[2].plot(x, dycausal_shd, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[2].plot(x, ntsnotears_shd, '-D', color='red', linewidth='2', markersize=10, label='NTS-NO')
# axs[2].plot(x, pcmci_shd, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[2].plot(x, svam_shd, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[2].plot([10, 20, 40], tecdi_shd, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks([10, 20, 40, 80])
# axs[2].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[2].set_ylim([0, 1000])
# axs[2].set_ylabel('SHD', fontsize=30, fontweight='bold')
# axs[3].plot(x, dycausal_time, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[3].plot(x, ntsnotears_time, '-D', color='red', linewidth='2', markersize=10, label='NTS-NO')
# axs[3].plot(x, pcmci_time, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[3].plot(x, svam_time, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[3].plot([10, 20, 40], tecdi_time, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks([10, 20, 40, 80])
# axs[3].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[3].set_ylim([0, 2000])
# axs[3].set_ylabel('Runtimes', fontsize=30, fontweight='bold')
#
# fig.add_subplot(1, 1, 1, frameon=False)
# plt.tick_params(labelcolor='none', top=False, bottom=False, left=False, right=False)
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower center', bbox_to_anchor=(0.48, 1), ncol=5)
# # 展示图形
# plt.savefig('results_nonlinear.pdf')
# # plt.show()

# results on ode
# x = [10, 20, 40, 80]
# dycausal_tpr = [0.9975, 0.9875, 0.94687, 0.95905]
# ngm_tpr = [0.9175, 0.9675, 0.99378, 1]
# pcmci_tpr = [0.8375, 0.895, 0.88437, 0.85001]
# svam_tpr = [0.3825, 0.41625, 0.42562, 0.43313]
# tecdi_tpr = [0.75, 0.9, 0.9812]
#
# dycausal_f1 = [0.9975, 0.97236, 0.94295, 0.94128]
# ngm_f1 = [0.91895, 0.96093, 0.95337, 0.91441]
# pcmci_f1 = [0.61225, 0.52001, 0.32111, 0.19559]
# svam_f1 = [0.53873, 0.57367, 0.57841, 0.51539]
# tecdi_f1 = [0.75, 0.4915, 0.1924]
#
# dycausal_shd = [0.2, 7.7, 32.2, 65.5]
# ngm_shd = [9.3, 9.6, 29.3, 114]
# pcmci_shd = [49.7, 178.7, 823.1, 3148.3]
# svam_shd = [31.9, 57, 117.6, 359.7]
# tecdi_shd = [10, 214, 1422]
#
# dycausal_time = [160.313269, 371.476469, 377.036997, 476.787314]
# ngm_time = [470.491094, 656.855326, 832.473083, 1247.65191]
# pcmci_time = [1.949673, 8.706543, 50.338333, 255.217549]
# svam_time = [0.196774, 1.461989, 11.488175, 90.859807]
# tecdi_time = [1481.342788, 4221.243431, 19465.66102]
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 8))
# # 绘制折线图
# axs[0].plot(x, dycausal_tpr, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[0].plot(x, ngm_tpr, '-D', color='red', linewidth='2', markersize=10, label='NGM')
# axs[0].plot(x, pcmci_tpr, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[0].plot(x, svam_tpr, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[0].plot([10, 20, 40], tecdi_tpr, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks([10, 20, 40, 80])
# axs[0].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
# axs[1].plot(x, dycausal_f1, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[1].plot(x, ngm_f1, '-D', color='red', linewidth='2', markersize=10, label='NGM')
# axs[1].plot(x, pcmci_f1, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[1].plot(x, svam_f1, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[1].plot([10, 20, 40], tecdi_f1, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks([10, 20, 40, 80])
# axs[1].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[1].set_ylabel('F1', fontsize=30, fontweight='bold')
# axs[2].plot(x, dycausal_shd, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[2].plot(x, ngm_shd, '-D', color='red', linewidth='2', markersize=10, label='NGM')
# axs[2].plot(x, pcmci_shd, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[2].plot(x, svam_shd, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[2].plot([10, 20, 40], tecdi_shd, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks([10, 20, 40, 80])
# axs[2].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[2].set_ylim([0, 1000])
# axs[2].set_ylabel('SHD', fontsize=30, fontweight='bold')
# axs[3].plot(x, dycausal_time, '-*', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[3].plot(x, ngm_time, '-D', color='red', linewidth='2', markersize=10, label='NTS-NO')
# axs[3].plot(x, pcmci_time, '-^', color='orange', linewidth='2', markersize=10, label='PCMCI')
# axs[3].plot(x, svam_time, '-v', color='purple', linewidth='2', markersize=10, label='SVAM')
# axs[3].plot([10, 20, 40], tecdi_time, '-o', color='black', linewidth='2', markersize=10, label='TECDI')
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks([10, 20, 40, 80])
# axs[3].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[3].set_ylim([0, 2000])
# axs[3].set_ylabel('Runtimes', fontsize=30, fontweight='bold')
#
# fig.add_subplot(1, 1, 1, frameon=False)
# plt.tick_params(labelcolor='none', top=False, bottom=False, left=False, right=False)
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower center', bbox_to_anchor=(0.48, 1), ncol=5)
# # 展示图形
# plt.savefig('results_ode.pdf')
# # plt.show()

# results on fewer samples
# x = [20, 50, 100, 150]
# W1_tpr = [0.49951, 0.64906, 0.81736, 0.85407]
# W2_tpr = [0.71005, 0.85868, 0.88136, 0.91575]
# W3_tpr = [0.54433, 0.66248, 0.73272, 0.85865]
#
# W1_f1 = [0.2793, 0.71131, 0.88054, 0.90919]
# W2_f1 = [0.29888, 0.90669, 0.93641, 0.9552]
# W3_f1 = [0.28319, 0.72487, 0.79231, 0.91048]
#
# W1_shd = [246.6, 47, 18.7, 16.6]
# W2_shd = [334.1, 16.2, 11.5, 8.1]
# W3_shd = [261.7, 44.3, 34.7, 16.4]
#
# time = [296, 432, 676, 332]
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 8))
# axs[0].plot(x, W1_tpr, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[0].plot(x, W2_tpr, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[0].plot(x, W3_tpr, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks([20, 50, 100, 150])
# axs[0].set_xlabel('Sample size', fontsize=30, fontweight='bold')
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
# axs[1].plot(x, W1_f1, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[1].plot(x, W2_f1, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[1].plot(x, W3_f1, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks([20, 50, 100, 150])
# axs[1].set_xlabel('Sample size', fontsize=30, fontweight='bold')
# axs[1].set_ylabel('F1', fontsize=30, fontweight='bold')
# axs[2].plot(x, W1_shd, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[2].plot(x, W2_shd, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[2].plot(x, W3_shd, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks([20, 50, 100, 150])
# axs[2].set_xlabel('Sample size', fontsize=30, fontweight='bold')
# # axs[2].set_ylim([0, 1000])
# axs[2].set_ylabel('SHD', fontsize=30, fontweight='bold')
# axs[3].plot(x, time, '-o', color='red', linewidth='2', markersize=10, label='DyCausal')
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks([20, 50, 100, 150])
# axs[3].set_xlabel('Sample size', fontsize=30, fontweight='bold')
# axs[3].legend()
# # axs[3].set_ylim([0, 2000])
# axs[3].set_ylabel('Runtimes', fontsize=30, fontweight='bold')
# fig.add_subplot(1, 1, 1, frameon=False)
# plt.tick_params(labelcolor='none', top=False, bottom=False, left=False, right=False)
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower center', bbox_to_anchor=(0.48, 1), ncol=5)
# plt.savefig('results_linear.pdf')
# # plt.show()

# results on different time series length
# x = [10, 30, 50, 70, 90]
# W1_tpr = [0.69111, 0.86359, 0.83164, 0.89252, 0.90524]
# W2_tpr = [0.89717, 0.92013, 0.90253, 0.92019, 0.93274]
# W3_tpr = [0.69427, 0.8569, 0.83692, 0.89441, 0.89527]
#
# W1_f1 = [0.71732, 0.92101, 0.89541, 0.93949, 0.94561]
# W2_f1 = [0.9395, 0.9572, 0.94818, 0.95826, 0.96501]
# W3_f1 = [0.7288, 0.91187, 0.90361, 0.94041, 0.93933]
#
# W1_shd = [55.2, 13.8, 18.3, 11.1, 10]
# W2_shd = [10.6, 7.8, 9.6, 7.5, 6.2]
# W3_shd = [54.5, 15.6, 16.6, 11, 11.1]
#
# time = [349.381194, 352.702866, 359.131168, 1200.742451, 1210.266903]
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 8))
# axs[0].plot(x, W1_tpr, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[0].plot(x, W2_tpr, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[0].plot(x, W3_tpr, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks([10, 30, 50, 70, 90])
# axs[0].set_xlabel('Time series length', fontsize=30, fontweight='bold')
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
# axs[1].plot(x, W1_f1, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[1].plot(x, W2_f1, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[1].plot(x, W3_f1, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks([10, 30, 50, 70, 90])
# axs[1].set_xlabel('Time series length', fontsize=30, fontweight='bold')
# axs[1].set_ylabel('F1', fontsize=30, fontweight='bold')
# axs[2].plot(x, W1_shd, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[2].plot(x, W2_shd, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[2].plot(x, W3_shd, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks([10, 30, 50, 70, 90])
# axs[2].set_xlabel('Time series length', fontsize=30, fontweight='bold')
# # axs[2].set_ylim([0, 1000])
# axs[2].set_ylabel('SHD', fontsize=30, fontweight='bold')
# axs[3].plot(x, time, '-o', color='red', linewidth='2', markersize=10, label='DyCausal')
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks([10, 30, 50, 70, 90])
# axs[3].set_xlabel('Time series length', fontsize=30, fontweight='bold')
# axs[3].legend()
# # axs[3].set_ylim([0, 2000])
# axs[3].set_ylabel('Runtimes', fontsize=30, fontweight='bold')
# fig.add_subplot(1, 1, 1, frameon=False)
# plt.tick_params(labelcolor='none', top=False, bottom=False, left=False, right=False)
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower center', bbox_to_anchor=(0.48, 1), ncol=5)
# plt.savefig('results_linear.pdf')
# # plt.show()

# results on more nodes
# x = [50, 100, 200, 300]
# W1_tpr = [0.8565, 0.8725, 0.8365, 0.81585]
# W2_tpr = [0.93284, 0.91618, 0.92676, 0.9216]
# W3_tpr = [0.83436, 0.86745, 0.83518, 0.78537]
#
# W1_f1 = [0.91666, 0.92384, 0.8762, 0.85625]
# W2_f1 = [0.96428, 0.95531, 0.96136, 0.95709]
# W3_f1 = [0.89248, 0.92257, 0.88013, 0.8205]
#
# W1_shd = [14.4, 28, 90, 151.4]
# W2_shd = [6.2, 16.1, 28.2, 46.4]
# W3_shd = [18.7, 28.3, 87.3, 191.3]
#
# time = [368, 2400, 3840, 5541.00033]
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 8))
# axs[0].plot(x, W1_tpr, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[0].plot(x, W2_tpr, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[0].plot(x, W3_tpr, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks([50, 100, 200, 300])
# axs[0].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
# axs[1].plot(x, W1_f1, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[1].plot(x, W2_f1, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[1].plot(x, W3_f1, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks([50, 100, 200, 300])
# axs[1].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[1].set_ylabel('F1', fontsize=30, fontweight='bold')
# axs[2].plot(x, W1_shd, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[2].plot(x, W2_shd, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[2].plot(x, W3_shd, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks([50, 100, 200, 300])
# axs[2].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# # axs[2].set_ylim([0, 1000])
# axs[2].set_ylabel('SHD', fontsize=30, fontweight='bold')
# axs[3].plot(x, time, '-o', color='red', linewidth='2', markersize=10, label='DyCausal')
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks([50, 100, 200, 300])
# axs[3].set_xlabel('Number of nodes', fontsize=30, fontweight='bold')
# axs[3].legend()
# # axs[3].set_ylim([0, 2000])
# axs[3].set_ylabel('Runtimes', fontsize=30, fontweight='bold')
# fig.add_subplot(1, 1, 1, frameon=False)
# plt.tick_params(labelcolor='none', top=False, bottom=False, left=False, right=False)
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower center', bbox_to_anchor=(0.48, 1), ncol=5)
# plt.savefig('results_linear.pdf')
# # plt.show()

# results on different noise strength
# x = [0.5, 1.0, 2.5, 5.0]
# W1_tpr = [0.81821, 0.88105, 0.87716, 0.88778]
# W2_tpr = [0.92385, 0.93295, 0.9159, 0.92907]
# W3_tpr = [0.7975, 0.87049, 0.86391, 0.89048]
#
# W1_f1 = [0.87737, 0.93258, 0.92866, 0.93459]
# W2_f1 = [0.96015, 0.96516, 0.95564, 0.96233]
# W3_f1 = [0.85597, 0.92163, 0.9178, 0.93882]
#
# W1_shd = [18.7, 11.9, 12.5, 12.2]
# W2_shd = [7.6, 6.3, 7.7, 6.7]
# W3_shd = [21.4, 13.6, 14.4, 11.2]
#
# time = [345.1972497, 342.3181789, 398.9354467, 402.2332644]
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 8))
# axs[0].plot(x, W1_tpr, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[0].plot(x, W2_tpr, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[0].plot(x, W3_tpr, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks([0.5, 1.0, 2.5, 5.0])
# axs[0].set_xlabel('Noise strength', fontsize=30, fontweight='bold')
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
# axs[1].plot(x, W1_f1, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[1].plot(x, W2_f1, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[1].plot(x, W3_f1, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks([0.5, 1.0, 2.5, 5.0])
# axs[1].set_xlabel('Noise strength', fontsize=30, fontweight='bold')
# axs[1].set_ylabel('F1', fontsize=30, fontweight='bold')
# axs[2].plot(x, W1_shd, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[2].plot(x, W2_shd, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[2].plot(x, W3_shd, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks([0.5, 1.0, 2.5, 5.0])
# axs[2].set_xlabel('Noise strength', fontsize=30, fontweight='bold')
# # axs[2].set_ylim([0, 1000])
# axs[2].set_ylabel('SHD', fontsize=30, fontweight='bold')
# axs[3].plot(x, time, '-o', color='red', linewidth='2', markersize=10, label='DyCausal')
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks([0.5, 1.0, 2.5, 5.0])
# axs[3].set_xlabel('Noise strength', fontsize=30, fontweight='bold')
# axs[3].legend()
# # axs[3].set_ylim([0, 2000])
# axs[3].set_ylabel('Runtimes', fontsize=30, fontweight='bold')
# fig.add_subplot(1, 1, 1, frameon=False)
# plt.tick_params(labelcolor='none', top=False, bottom=False, left=False, right=False)
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower center', bbox_to_anchor=(0.48, 1), ncol=5)
# plt.savefig('results_linear.pdf')
# # plt.show()

# results on more lag
# x = [1, 2, 3, 4, 5]
# W1_tpr = [0.94457, 0.93642, 0.86391, 0.79901, 0.69602]
# W2_tpr = [0.99805, 0.97672, 0.91771, 0.8744, 0.84098]
# W3_tpr = [0.9557, 0.93422, 0.88454, 0.82438, 0.75868]
#
#
# W1_f1 = [0.95916, 0.95009, 0.89829, 0.83596, 0.73881]
# W2_f1 = [0.99853, 0.98818, 0.95657, 0.93239, 0.91165]
# W3_f1 = [0.95457, 0.95971, 0.93379, 0.90073, 0.85316]
#
# W1_shd = [7.9, 14.3, 40, 76.9, 136.4]
# W2_shd = [0.3, 3.6, 16.8, 31.5, 44.6]
# W3_shd = [9.3, 11.4, 25.5, 43.3, 70.9]
#
# time = [349.61529, 352.656736, 370.480581, 367.659037, 373.5199]
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 8))
# axs[0].plot(x, W1_tpr, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[0].plot(x, W2_tpr, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[0].plot(x, W3_tpr, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks([1, 2, 3, 4, 5])
# axs[0].set_xlabel('lagged Length', fontsize=30, fontweight='bold')
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
# axs[1].plot(x, W1_f1, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[1].plot(x, W2_f1, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[1].plot(x, W3_f1, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks([1, 2, 3, 4, 5])
# axs[1].set_xlabel('lagged Length', fontsize=30, fontweight='bold')
# axs[1].set_ylabel('F1', fontsize=30, fontweight='bold')
# axs[2].plot(x, W1_shd, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[2].plot(x, W2_shd, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[2].plot(x, W3_shd, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks([1, 2, 3, 4, 5])
# axs[2].set_xlabel('lagged Length', fontsize=30, fontweight='bold')
# # axs[2].set_ylim([0, 1000])
# axs[2].set_ylabel('SHD', fontsize=30, fontweight='bold')
# axs[3].plot(x, time, '-o', color='red', linewidth='2', markersize=10, label='DyCausal')
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks([1, 2, 3, 4, 5])
# axs[3].set_xlabel('lagged Length', fontsize=30, fontweight='bold')
# axs[3].legend()
# # axs[3].set_ylim([0, 2000])
# axs[3].set_ylabel('Runtimes', fontsize=30, fontweight='bold')
# fig.add_subplot(1, 1, 1, frameon=False)
# plt.tick_params(labelcolor='none', top=False, bottom=False, left=False, right=False)
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower center', bbox_to_anchor=(0.48, 1), ncol=5)
# plt.savefig('results_linear.pdf')
# # plt.show()

# # results on more lag
# x = [1, 2, 3, 4, 5]
# W1_tpr = [0.38737, 0.64628, 0.837, 0.84633, 0.81997]
# W2_tpr = [0.43801, 0.68707, 0.9105, 0.9194, 0.91496]
# W3_tpr = [0.38874, 0.64434, 0.85871, 0.87225, 0.86491]
#
#
# W1_f1 = [0.49968, 0.73009, 0.89711, 0.85515, 0.75004]
# W2_f1 = [0.57718, 0.78532, 0.95266, 0.9563, 0.95469]
# W3_f1 = [0.52101, 0.7503, 0.91897, 0.91608, 0.90112]
#
# W1_shd = [151.4, 93.5, 38, 55.8, 108.8]
# W2_shd = [126.2, 73.8, 18.4, 16.8, 17.3]
# W3_shd = [138.2, 83.7, 29.6, 31, 37.2]
#
# time = [346.319093, 353.154541, 361.30035, 375.47602, 377.881384]
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 8))
# axs[0].plot(x, W1_tpr, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[0].plot(x, W2_tpr, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[0].plot(x, W3_tpr, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks([1, 2, 3, 4, 5])
# axs[0].set_xlabel('lagged Length', fontsize=30, fontweight='bold')
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
# axs[1].plot(x, W1_f1, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[1].plot(x, W2_f1, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[1].plot(x, W3_f1, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks([1, 2, 3, 4, 5])
# axs[1].set_xlabel('lagged Length', fontsize=30, fontweight='bold')
# axs[1].set_ylabel('F1', fontsize=30, fontweight='bold')
# axs[2].plot(x, W1_shd, '-*', color='green', linewidth='2', markersize=10, label='W1')
# axs[2].plot(x, W2_shd, '-D', color='purple', linewidth='2', markersize=10, label='W2')
# axs[2].plot(x, W3_shd, '-^', color='orange', linewidth='2', markersize=10, label='W3')
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks([1, 2, 3, 4, 5])
# axs[2].set_xlabel('lagged Length', fontsize=30, fontweight='bold')
# # axs[2].set_ylim([0, 1000])
# axs[2].set_ylabel('SHD', fontsize=30, fontweight='bold')
# axs[3].plot(x, time, '-o', color='red', linewidth='2', markersize=10, label='DyCausal')
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks([1, 2, 3, 4, 5])
# axs[3].set_xlabel('lagged Length', fontsize=30, fontweight='bold')
# axs[3].legend()
# # axs[3].set_ylim([0, 2000])
# axs[3].set_ylabel('Runtimes', fontsize=30, fontweight='bold')
# fig.add_subplot(1, 1, 1, frameon=False)
# plt.tick_params(labelcolor='none', top=False, bottom=False, left=False, right=False)
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower center', bbox_to_anchor=(0.48, 1), ncol=5)
# plt.savefig('results_linear.pdf')
# # plt.show()

# acyclic constraint results
# x = np.linspace(0, 1, 50)
# h_norms = [1.5173759382395406, 1.5173759382395406, 1.51737593823954, 1.5173759382395406, 1.5173759382395402, 1.51737593823954, 1.5173759382395404, 1.5173759382395406, 1.5173759382395402, 1.5173759382395402, 1.5173759382395389, 1.51737593823954, 1.5173759382395406, 1.5173759382395404, 1.5173759382395406, 1.5173759382395406, 1.5173759382395426, 1.5173759382395402, 1.5173759382395402, 1.5173759382395402, 1.51737593823954, 1.5173759382395389, 1.51737593823954, 1.51737593823954, 1.517375938239541, 1.5173759382395406, 1.51737593823954, 1.5173759382395404, 1.5173759382395426, 1.5173759382395406, 1.5173759382395395, 1.5173759382395406, 1.5173759382395406, 1.5173759382395426, 1.5173759382395402, 1.5173759382395402, 1.51737593823954, 1.5173759382395402, 1.51737593823954, 1.5173759382395402, 1.51737593823954, 1.51737593823954, 1.5173759382395413, 1.5173759382395389, 1.51737593823954, 1.51737593823954, 1.5173759382395406, 1.51737593823954, 1.51737593823954, 1.517375938239541]
# h_logs = [0.00043547271957322664, 0.0017428811548825252, 0.003925203742738859, 0.006987430030221731, 0.010936599353556176, 0.01578185590500425, 0.02153452113330445, 0.028208184745921017, 0.03581881593223102, 0.04438489683988678, 0.053927580803303954, 0.06447087838176913, 0.07604187492262326, 0.08867098415768737, 0.10239224329893659, 0.11724365627534894, 0.13326759319286907, 0.15051125589141634, 0.16902722170968332, 0.18887408038426656, 0.21011718258154133, 0.23282952312803218, 0.25709278788934853, 0.2829986009026584, 0.31065001840758555, 0.34016332972333885, 0.37167024273776406, 0.40532055588630556, 0.44128545155854226, 0.4797615917590292, 0.5209762614940132, 0.5651938978101327, 0.6127244769426454, 0.6639344314552602, 0.7192610710872316, 0.779231948495493, 0.8444913540385812, 0.9158373394660941, 0.9942747267486425, 1.0810931716640653, 1.1779859883982624, 1.2872382828958848, 1.4120393893793448, 1.5570333827655531, 1.72936517301369, 1.940877616524972, 2.213420502046887, 2.5947403970770893, 3.2284206627104197, 5.468944866400221]
# h_exps = [0.007425505268606969, 0.029990969350215835, 0.06858229327180254, 0.12474133477032723, 0.2007705945688656, 0.29989393908149253, 0.4264896565490659, 0.5864202204502504, 0.7874944982595196, 1.0401144920286782, 1.358182576958832, 1.760380491156596, 2.2719839846767798, 2.9274563081228706, 3.774184084957824, 4.877903405228587, 6.330648531155873, 8.262498684790977, 10.859094226996994, 14.387995815188887, 19.238721615130217, 25.984137689766655, 35.47549709960016, 48.991008951432406, 68.47038823038463, 96.88886084282785, 138.859596060855, 201.6140518983895, 296.6138796526578, 442.22908648954433, 668.2349876053497, 1023.4440240608299, 1588.7978600985564, 2500.071441906293, 3987.6792096180516, 6447.240173050607, 10566.068285244559, 17552.464772118863, 29556.077073297154, 50447.33897335024, 87279.34032343447, 153061.32917358918, 272081.8967998272, 490245.2989523833, 895378.1330306306, 1657595.3784812826, 3110494.1892289123, 5916419.654387874, 11406888.18199162, 22292254.272812895]
# h_ploys = [0.007425025823962983, 0.02998314889824627, 0.06854140842463607, 0.12460616216880283, 0.2004208720495697, 0.29911538816249816, 0.4249208229236885, 0.5834708369767228, 0.7822194249601608, 1.0310183215461137, 1.3429157368646827, 1.735264915954481, 2.2312699272361343, 2.8621530052193194, 3.6702115743236163, 4.713157214849431, 6.070313805957099, 7.851529328135726, 10.210073769338713, 13.361429295370613, 17.610845171389442, 23.39401176801256, 31.33749312213284, 42.34910098136484, 57.75391814990682, 79.50034005181533, 110.47415383605238, 154.98030199727947, 219.4864227517624, 313.77739978007435, 452.758867752515, 659.2910545309371, 968.6673723440367, 1435.7325609437016, 2146.258998671408, 3235.227437021781, 4916.3587750197075, 7530.069055979547, 11621.73488950155, 18070.056440755023, 28298.59355930389, 44625.98842007802, 70848.41485658717, 113212.47132869583, 182047.11714950594, 294512.2651983359, 479246.3348777878, 784254.537474596, 1290346.5087874685, 2134107.4464296573]
# h_rhos = [0.006767899832552036, 0.027071599330208144, 0.060911098492968295, 0.10828639732083258, 0.1691974958138009, 0.24364439397187318, 0.3316270917950498, 0.4331455892833303, 0.5481998864367149, 0.6767899832552036, 0.8189158797387961, 0.9745775758874927, 1.1437750717012944, 1.3265083671801992, 1.5227774623242076, 1.7325823571333212, 1.9559230516075385, 2.1927995457468596, 2.443211839551284, 2.7071599330208143, 2.9846438261554473, 3.2756635189551844, 3.5802190114200294, 3.898310303549971, 4.229937395345016, 4.575100286805178, 4.933798977930429, 5.306033468720797, 5.69180375917626, 6.0911098492968305, 6.503951739082507, 6.930329428533285, 7.370242917649172, 7.823692206430154, 8.290677294876236, 8.771198182987439, 9.265254870763732, 9.772847358205135, 10.293975645311635, 10.828639732083257, 11.376839618519963, 11.93857530462179, 12.513846790388708, 13.102654075820737, 13.70499716091787, 14.320876045680118, 14.950290730107442, 15.593241214199884, 16.249727497957423, 16.919749581380064]
# delta_h_norms = [16.293191369935677, 8.146595684967838, 5.4310637899785545, 4.073297842483919, 3.258638273987134, 2.7155318949892773, 2.3275987671336673, 2.0366489212419596, 1.8103545966595183, 1.629319136993567, 1.4811992154486948, 1.3577659474946386, 1.2533224130719753, 1.1637993835668337, 1.0862127579957113, 1.0183244606209798, 0.9584230217609236, 0.9051772983297591, 0.857536387891351, 0.8146595684967834, 0.7758662557112224, 0.7405996077243474, 0.7083996247798116, 0.6788829737473193, 0.6517276547974276, 0.6266612065359877, 0.603451532219839, 0.5818996917834168, 0.5618341851701969, 0.5431063789978556, 0.525586818385021, 0.5091622303104899, 0.49373307181623255, 0.4792115108804618, 0.4655197534267333, 0.45258864916487956, 0.44035652351177457, 0.4287681939456755, 0.41777413769065813, 0.4073297842483917, 0.39739491146184547, 0.3879331278556112, 0.37891142720780674, 0.3702998038621737, 0.3620709193319037, 0.3541998123899058, 0.34666364616884415, 0.33944148687365966, 0.3325141095905238, 0.3258638273987138]
# delta_h_logs = [0.0023070284624119564, 0.004618693991749671, 0.0069396619778718804, 0.009274654926732007, 0.011628482207594697, 0.014006071265932382, 0.01641250085687359, 0.018853036914738334, 0.02133317175509395, 0.02385866741075637, 0.026435604037406746, 0.029070434494823914, 0.03177004642515683, 0.03454183342205197, 0.03739377722951459, 0.04033454334796647, 0.043373592984927295, 0.04652131500654519, 0.04984774911030449, 0.05337063721146278, 0.057062734311773805, 0.06094235855356186, 0.06503022131004758, 0.06934989132547283, 0.07392836901561997, 0.07879680295362332, 0.08399139164157408, 0.08955452925143773, 0.09553627624348092, 0.10199626793794622, 0.10900622142669422, 0.11665327202392001, 0.12504447849748287, 0.13431300469260793, 0.14462675376113743, 0.15620067103519936, 0.1693146731559653, 0.18434045338361987, 0.20178275141651683, 0.2223450943778148, 0.24703879490142022, 0.27737250412093656, 0.3157015342207808, 0.36591974026823, 0.43496244731466865, 0.5364989360020883, 0.7017294233336915, 1.020762109395254, 1.9059631736512423, 17.906057851517666]
# delta_h_exps = [0.039429951707378334, 0.08021543841450107, 0.12378338305911528, 0.17171028968421467, 0.2265794976340691, 0.29185565886745823, 0.36985188504620414, 0.4644731992952241, 0.5807692952533187, 0.7253911278689966, 0.9072385421670401, 1.138388366152759, 1.4354369683891273, 1.8214598193337435, 2.328896779237671, 3.0038376404785545, 3.912443458873303, 5.150653488068431, 6.858990642182594, 9.245348912557573, 12.620389372884677, 17.453035092236686, 24.45830168777293, 34.73763840004439, 50.005352439412086, 73.11319116947477, 108.58133225454058, 163.23188270814705, 248.43764585768596, 382.8638928898923, 597.4803248793479, 944.2408645479806, 1511.274628872192, 2449.7565446324347, 4021.9497941775458, 6688.035147197188, 11264.76049027321, 19218.515285309022, 33212.74804581318, 58141.903891792055, 103106.28870661165, 185226.92894581507, 337098.8690761365, 621520.259444774, 1160935.8112038672, 2196977.53140401, 4212273.378711118, 8182566.360207863, 16104699.028627774, 32115401.410957802]
# delta_h_ploys = [0.03942545717695537, 0.08017864490854108, 0.12365432885132942, 0.17138733842807669, 0.22579902792017015, 0.29038685124065156, 0.3672695515767972, 0.4601335616565775, 0.573694465655137, 0.7140887860819176, 0.8894194933058713, 1.1105222933290282, 1.3920504299344956, 1.7540214087603052, 2.2240373827166366, 2.84049371678295, 3.65724567851942, 4.750439532642689, 6.228575629181243, 8.247426465234403, 11.03229104119767, 14.911400498744461, 20.366373268209376, 28.10888919065326, 39.197915514490084, 55.220009670017824, 78.76030875201326, 113.60094704637076, 165.24433346960984, 242.38646430730816, 358.49035039127904, 534.5295372130352, 803.3784746584131, 1216.8753894446854, 1857.2431766246755, 2855.6506157309595, 4422.52673917351, 6897.308511862887, 10830.46175631134, 17119.327598062584, 27234.111308978736, 43595.44002862506, 70207.76446776564, 113726.23986031645, 185260.71755179082, 303437.53595463245, 499614.8235613075, 826796.7936133163, 1374921.3102302407, 2297161.0103734224]
# delta_h_rhos = [0.03920636149763966, 0.07841272299527932, 0.11761908449291923, 0.15682544599055864, 0.19603180748819854, 0.23523816898583846, 0.27444453048347794, 0.3136508919811173, 0.3528572534787574, 0.3920636149763971, 0.43126997647403664, 0.47047633797167693, 0.5096826994693159, 0.5488890609669559, 0.5880954224645955, 0.6273017839622346, 0.6665081454598746, 0.7057145069575148, 0.7449208684551538, 0.7841272299527942, 0.8233335914504356, 0.8625399529480733, 0.9017463144457145, 0.9409526759433539, 0.9801590374409918, 1.0193653989386318, 1.05857176043627, 1.0977781219339118, 1.1369844834315534, 1.176190844929191, 1.2153972064268317, 1.2546035679244691, 1.2938099294221101, 1.3330162909197492, 1.3722226524173886, 1.4114290139150296, 1.4506353754126686, 1.4898417369103076, 1.5290480984079462, 1.5682544599055883, 1.607460821403227, 1.6466671829008712, 1.6858735443985098, 1.7250799058961466, 1.7642862673937865, 1.803492628891429, 1.8426989903890665, 1.8819053518867077, 1.9211117133843403, 1.9603180748819835]
# t_norms = [1.067626953125, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.067626953125, 1.02978515625, 1.0029296875, 1.0966796875, 0.0, 0.0, 1.021484375, 0.0, 1.023681640625, 0.0, 0.0, 0.0, 0.0, 0.0, 1.070556640625, 0.0, 1.005615234375, 1.0556640625, 1.03857421875, 1.01806640625, 0.0, 1.0634765625, 1.055419921875, 1.002197265625, 1.003662109375, 0.0, 0.0, 0.0, 0.0, 1.04541015625, 0.0, 0.0, 1.002685546875, 1.020751953125, 1.002197265625, 1.03662109375, 1.013671875, 1.003662109375]
# t_logs = [1.010986328125, 1.01513671875, 1.017333984375, 1.01025390625, 1.2421875, 1.0048828125, 1.003662109375, 1.00146484375, 1.01708984375, 1.003662109375, 1.01806640625, 1.02978515625, 0.0, 0.0, 0.0, 0.0, 1.02587890625, 1.026123046875, 0.0, 1.01708984375, 0.0, 0.7294921875, 1.01953125, 1.033203125, 1.025390625, 1.03759765625, 0.0, 1.0029296875, 0.0, 0.0, 0.0, 0.0, 1.004638671875, 0.0, 0.0, 0.0, 0.0, 1.001708984375, 1.0048828125, 1.02587890625, 1.062744140625, 0.0, 1.318359375, 1.00390625, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0]
# t_exps = [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.024169921875, 0.0, 1.001953125, 1.001708984375, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.023681640625, 0.0, 1.00439453125, 1.0068359375, 1.07666015625, 1.031005859375, 0.0, 1.00244140625, 1.034912109375, 1.00537109375, 1.004638671875, 0.0, 1.087646484375, 0.0, 0.0, 2.01513671875, 0.0, 0.0, 1.001953125, 1.052978515625, 1.00537109375, 1.00390625, 1.001708984375, 1.00146484375]
# t_ploys = [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.01123046875, 0.0, 0.0, 0.0, 0.0, 0.0, 1.025634765625, 0.0, 0.0, 0.0, 0.0, 1.01806640625, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0]
# t_rhos = [4.462646484375, 4.141845703125, 4.084716796875, 4.064208984375, 4.229736328125, 4.05908203125, 4.123046875, 3.35986328125, 4.090576171875, 4.09716796875, 4.07958984375, 3.60888671875, 3.086181640625, 3.44140625, 3.034423828125, 3.505859375, 4.0703125, 4.02001953125, 3.40771484375, 4.028564453125, 4.626220703125, 4.23193359375, 4.20849609375, 4.513671875, 4.21826171875, 3.518798828125, 4.256591796875, 3.435302734375, 3.250732421875, 3.07373046875, 3.250244140625, 4.291748046875, 4.186767578125, 3.330322265625, 3.025146484375, 4.583740234375, 4.56591796875, 4.252685546875, 4.3740234375, 4.283935546875, 3.6591796875, 3.396728515625, 4.114013671875, 4.103759765625, 3.20947265625, 3.509765625, 3.18896484375, 3.203125, 3.21044921875, 3.1904296875]
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
#
# fig, axs = plt.subplots(1, 6, figsize=(55, 7))
#
# axs[0].plot(x, h_norms, '-', color='green', linewidth='5', markersize=10, label='hnorm')
# axs[0].plot(x, h_logs, '-', color='red', linewidth='5', markersize=10, label='hlog')
# axs[0].plot(x, h_exps, '-', color='blue', linewidth='5', markersize=10, label='hexp')
# axs[0].plot(x, h_ploys, '-', color='purple', linewidth='5', markersize=10, label='hploy')
# axs[0].plot(x, h_rhos, '-', color='orange', linewidth='5', markersize=10, label='hrho')
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks([0.0, 0.2, 0.4, 0.6, 0.8, 1.0])
# axs[0].set_yscale('log')
# axs[0].set_xlabel('k', fontsize=30, fontweight='bold')
# axs[0].set_ylabel('h', fontsize=30, fontweight='bold')
# axs[1].plot(x, delta_h_norms, '--', color='green', linewidth='5', markersize=10, label='dhnorm')
# axs[1].plot(x, delta_h_logs, '--', color='red', linewidth='5', markersize=10, label='dhlog')
# axs[1].plot(x, delta_h_exps, '--', color='blue', linewidth='5', markersize=10, label='dhexp')
# axs[1].plot(x, delta_h_ploys, '--', color='purple', linewidth='5', markersize=10, label='dhploy')
# axs[1].plot(x, delta_h_rhos, '--', color='orange', linewidth='5', markersize=10, label='dhrho')
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks([0.0, 0.2, 0.4, 0.6, 0.8, 1.0])
# axs[1].set_yscale('log')
# axs[1].set_xlabel('k', fontsize=30, fontweight='bold')
# axs[1].set_ylabel('h', fontsize=30, fontweight='bold')
# axs[2].plot(x, t_norms, '-', color='green', linewidth='5', markersize=10, label='hnorm')
# axs[2].plot(x, t_logs, '-', color='red', linewidth='5', markersize=10, label='hlog')
# axs[2].plot(x, t_exps, '-', color='blue', linewidth='5', markersize=10, label='hexp')
# axs[2].plot(x, t_ploys, '-', color='purple', linewidth='5', markersize=10, label='hploy')
# axs[2].plot(x, t_rhos, '-', color='orange', linewidth='5', markersize=10, label='hrho')
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks([0.0, 0.2, 0.4, 0.6, 0.8, 1.0])
# # axs[2].set_yscale('log')
# axs[2].set_xlabel('k', fontsize=30, fontweight='bold')
# axs[2].set_ylabel('runtime(ms)', fontsize=30, fontweight='bold')
#
# x = [2, 3, 4, 5, 6, 7, 8, 9, 10, 20, 30, 40, 50, 60, 70, 80, 90, 100, 200, 300, 400, 500, 600, 700, 800, 900, 1000]
# h_norms = [6.216107224046835, 5.811141657980055, 5.52395904431961, 5.301314868546728, 5.119492604044133, 4.965841133258304, 4.832808866425341, 4.7155248733107085, 4.610663316944886, 3.922501150590879, 3.5220127318542915, 3.2392990241476274, 3.021115513243119, 2.8437456728976436, 2.694538386014946, 2.5659420633714696, 2.453085775356086, 2.3526436857057234, 1.708223290102378, 1.3506541955296627, 1.1100394328731369, 0.9331373686713741, 0.7962351572159836, 0.6866861445655499, 0.5969439666745301, 0.5221436572945508, 0.45896605486611863]
# h_logs = [0.0644053963993954, 0.0157008341293509, 0.003898252306433488, 0.0009721667027783685, 0.00024271034633506494, 6.061145086340685e-05, 1.5137380809897641e-05, 3.7805431703993864e-06, 9.44190261880154e-07, 8.91564599925232e-13, -1.0408340855860843e-17, 0.0, 1.3183898417423734e-16, -4.163336342344337e-17, -5.551115123125783e-17, -2.7755575615628914e-17, 9.71445146547012e-17, 1.1102230246251565e-16, -8.049116928532385e-16, -2.220446049250313e-15, -3.4416913763379853e-15, -4.829470157119431e-15, -5.551115123125783e-16, 3.6637359812630166e-15, 7.993605777301127e-15, 1.2323475573339238e-14, 1.6431300764452317e-14]
# h_exps = [0.06282619975914638, 0.00781351728414137, 0.0006510431804356287, 4.069010548057861e-05, 2.034505209635995e-06, 8.47710506235444e-08, 3.0275373319454957e-09, 9.461054162329674e-11, 2.6290081223123707e-12, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0]
# h_ploys = [0.03125, 0.0017361111111111605, 6.103515625e-05, 1.5625000004959588e-06, 3.139668525165007e-08, 5.187903440173613e-10, 7.275957614183426e-12, 8.881784197001252e-14, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0]
# h_rhos = [0.25, 0.2500000000000002, 0.2500000000000001, 0.25, 0.25000000000000006, 0.2500000000000001, 0.25000000000000033, 0.2500000000000003, 0.2500000000000002, 0.2500000000000003, 0.25000000000000056, 0.25000000000000033, 0.25000000000000056, 0.25000000000000044, 0.2500000000000005, 0.25000000000000155, 0.2500000000000016, 0.2500000000000019, 0.25000000000000333, 0.2500000000000062, 0.2500000000000055, 0.2500000000000104, 0.2500000000000104, 0.2500000000000143, 0.25000000000001593, 0.25000000000001865, 0.25000000000002365]
# delta_h_norms = [1999.0004997503802, 1333.3328893332232, 1000.499250375201, 800.7992000007521, 667.6659439179899, 572.5708560017982, 501.2496231896078, 445.7776271133064, 401.4000967520113, 201.7030388521226, 135.1395694695098, 101.85949713318006, 81.89278352236984, 68.58274917469372, 59.07653144445092, 51.94769899220425, 46.40378994797355, 41.969327176514476, 22.032500320890698, 15.40896612618095, 12.113672741901384, 10.1495840984398, 8.851000625614983, 7.932605189963165, 7.251724677503326, 6.72908393498815, 6.317107411411589]
# delta_h_logs = [0.26609870558945664, 0.2534490334467155, 0.25047526409025556, 0.24974342326255133, 0.24956131276387813, 0.24951587206194775, 0.24950452581768406, 0.2495016922513842, 0.24950098457753733, 0.249500749001471, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858, 0.24950074900124858]
# delta_h_exps = [0.2526123168081683, 0.2501627725270795, 0.25000813803134564, 0.25000033908420743, 0.2500000121101501, 0.2500000003784422, 0.2500000000105123, 0.25000000000026285, 0.25000000000000605, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25, 0.25]
# delta_h_ploys = [0.125, 0.16666666666666666, 0.1875, 0.2, 0.20833333333333331, 0.21428571428571427, 0.21875, 0.2222222222222222, 0.225, 0.23750000000000002, 0.24166666666666667, 0.24375000000000002, 0.245, 0.24583333333333335, 0.2464285714285714, 0.246875, 0.24722222222222223, 0.2475, 0.24875, 0.24916666666666668, 0.249375, 0.2495, 0.24958333333333335, 0.24964285714285714, 0.2496875, 0.24972222222222223, 0.24975]
# delta_h_rhos = [0.0, 1.8791567052830518e-32, 6.740754805355328e-33, 6.412328373992688e-33, 1.604255456829175e-32, 4.88435549080129e-32, 4.224239434969577e-32, 9.103101304297837e-32, 2.7867454549049197e-32, 6.287320800783304e-32, 7.71134590306704e-32, 1.1652764273261956e-31, 9.278640974161657e-32, 4.826217193870549e-31, 1.3258306508157789e-31, 3.2355575071128224e-31, 2.1837779911801416e-31, 2.8975237903947755e-31, 6.765577849317038e-31, 1.1461988614513942e-30, 2.9979145034663045e-30, 1.6591183901366796e-30, 9.229689489091913e-31, 1.6661314522939677e-30, 1.8446493864747462e-30, 1.7260294187026858e-30, 2.238313329214455e-30]
# t_norms = [0.548828125, 0.9853515625, 0.0, 0.0, 1.16259765625, 0.224365234375, 0.0, 0.968994140625, 0.0, 0.0, 0.0, 0.0, 1.01416015625, 1.010009765625, 1.003173828125, 1.08837890625, 1.0048828125, 2.00390625, 4.677734375, 8.83740234375, 48.36962890625, 21.23876953125, 29.954345703125, 41.01025390625, 47.398681640625, 59.463134765625, 82.378173828125]
# t_logs = [0.0, 0.0, 0.0, 0.0, 0.0, 0.132568359375, 0.0, 0.0, 1.01025390625, 1.03564453125, 1.064697265625, 1.011962890625, 0.0, 1.0478515625, 1.003173828125, 1.002685546875, 1.686767578125, 2.005859375, 4.086181640625, 8.2880859375, 16.167236328125, 21.250244140625, 28.94580078125, 35.835693359375, 47.17236328125, 56.767333984375, 74.6484375]
# t_exps = [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.015380859375, 0.0, 0.0, 0.0, 1.0107421875, 1.028076171875, 3.37109375, 4.9013671875, 12.083984375, 18.091796875, 25.997802734375, 40.814697265625, 55.69580078125, 75.869873046875, 95.415283203125]
# t_ploys = [0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.02734375, 1.02099609375, 0.0, 1.0048828125, 2.0244140625, 6.171875, 21.31689453125, 32.627685546875, 50.999755859375, 79.06787109375, 102.845947265625, 130.175537109375, 207.020263671875]
# t_rhos = [0.0, 0.683349609375, 0.0, 0.0, 1.00048828125, 0.629150390625, 0.0, 0.0, 0.0, 1.001708984375, 2.09521484375, 2.318359375, 3.02880859375, 5.377685546875, 6.05078125, 15.18603515625, 21.384033203125, 28.619873046875, 127.215576171875, 394.161376953125, 625.937744140625, 963.258544921875, 1488.254638671875, 2029.9345703125, 2591.082763671875, 3210.291748046875, 3931.57568359375]
#
#
# axs[3].plot(x, h_norms, '-', color='green', linewidth='5', markersize=10, label='hnorm')
# axs[3].plot(x, h_logs, '-', color='red', linewidth='5', markersize=10, label='hlog')
# axs[3].plot(x, h_exps, '-', color='blue', linewidth='5', markersize=10, label='hexp')
# axs[3].plot(x, h_ploys, '-', color='purple', linewidth='5', markersize=10, label='hploy')
# axs[3].plot(x, h_rhos, '-', color='orange', linewidth='5', markersize=10, label='hrho')
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks([2, 10, 100, 1000])
# axs[3].set_yscale('log')
# axs[3].set_xscale('log')
# axs[3].set_xlabel('d', fontsize=30, fontweight='bold')
# axs[3].set_ylabel('h', fontsize=30, fontweight='bold')
# axs[4].plot(x, delta_h_norms, '--', color='green', linewidth='5', markersize=10, label='dhnorm')
# axs[4].plot(x, delta_h_logs, '--', color='red', linewidth='5', markersize=10, label='dhlog')
# axs[4].plot(x, delta_h_exps, '--', color='blue', linewidth='5', markersize=10, label='dhexp')
# axs[4].plot(x, delta_h_ploys, '--', color='purple', linewidth='5', markersize=10, label='dhploy')
# axs[4].plot(x, delta_h_rhos, '--', color='orange', linewidth='5', markersize=10, label='dhrho')
# axs[4].grid(linestyle='--', linewidth=1, color='gray')
# axs[4].set_xticks([2, 10, 100, 1000])
# axs[4].set_yscale('log')
# axs[4].set_xscale('log')
# axs[4].set_xlabel('d', fontsize=30, fontweight='bold')
# axs[4].set_ylabel('h', fontsize=30, fontweight='bold')
# axs[5].plot(x, t_norms, '-', color='green', linewidth='5', markersize=10, label='dhnorm')
# axs[5].plot(x, t_logs, '-', color='red', linewidth='5', markersize=10, label='dhlog')
# axs[5].plot(x, t_exps, '-', color='blue', linewidth='5', markersize=10, label='dhexp')
# axs[5].plot(x, t_ploys, '-', color='purple', linewidth='5', markersize=10, label='dhploy')
# axs[5].plot(x, t_rhos, '-', color='orange', linewidth='5', markersize=10, label='dhrho')
# axs[5].grid(linestyle='--', linewidth=1, color='gray')
# axs[5].set_xticks([2, 10, 100, 1000])
# # axs[5].set_yscale('log')
# axs[5].set_xscale('log')
# axs[5].set_xlabel('d', fontsize=30, fontweight='bold')
# axs[5].set_ylabel('runtime(ms)', fontsize=30, fontweight='bold')
# handles, labels = axs[0].get_legend_handles_labels()
# handles1, labels1 = axs[1].get_legend_handles_labels()
# print(handles+handles1)
# plt.legend(handles+handles1, labels+labels1, loc='lower right', bbox_to_anchor=(0.3, 1), ncol=10)
# # plt.savefig('results_h.pdf')
# plt.show()

# partially dynamic evaluation in each time step
# x = np.linspace(1, 10, 10)
# dycausal_tpr_mean = np.array([94.9, 92.14555556, 93.33666667, 92.64555556, 94.72888889, 95.16, 92.39888889, 94.49444444, 94.87, 94.53777778]) / 100
# dycausal_tpr_std = np.array([3.722009613, 4.183425261, 4.134341275, 2.883208518, 2.279490413, 1.898309189, 2.333721132, 3.647501766, 2.267044086, 3.617687345]) / 100
# dynotears_tpr_mean = np.array([66.968, 71.904, 74.067, 83.106, 92.384, 92.384, 83.106, 74.067, 71.904, 66.968]) / 100
# dynotears_tpr_std = np.array([4.873634783, 3.194783874, 2.957404436, 3.836712655, 4.356368212, 4.356368212, 3.836712655, 2.957404436, 3.194783874, 4.873634783]) / 100
# ntsnotears_tpr_mean = np.array([7.324, 16.228, 17.088, 17.315, 15.793, 15.793, 17.315, 17.088, 16.228, 7.324]) / 100
# ntsnotears_tpr_std = np.array([6.616528093, 4.981117947, 5.299403363, 6.008377901, 4.194672931, 4.194672931, 6.008377901, 5.299403363, 4.981117947, 6.616528093]) / 100
# dycast_tpr_mean = np.array([75.78222222,67.09888889,66.03555556,66.07333333,74.15888889,73.99222222,66.39333333,64.98888889,64.61777778,74.96]) / 100
# dycast_tpr_std = np.array([12.29357626,12.01375364,8.735262015,5.500763583,6.212076848,6.702314323,6.759620305,7.115186332,9.975585505,9.750410818]) / 100
#
# dycausal_fdr_mean = np.array([4.005555556, 1.87, 0.364444444, 0.168888889, 0.308888889, 0.158888889, 0, 1.002222222, 0.99, 2.493333333]) / 100
# dycausal_fdr_std = np.array([4.868798873, 3.329240821, 1.030804552, 0.477689914, 0.873669712, 0.449405643, 0, 1.013089639, 0.939420625, 1.837292694]) / 100
# dynotears_fdr_mean = np.array([28.934, 12.226, 8.864, 8.864, 9.238, 9.238, 8.864, 8.864, 12.226, 28.934]) / 100
# dynotears_fdr_std = np.array([5.030320467, 6.849536043, 7.846997133, 7.846997133, 8.365624663, 8.365624663, 7.846997133, 7.846997133, 6.849536043, 5.030320467]) / 100
# ntsnotears_fdr_mean = np.array([92.283, 76.997, 75.31, 76.796, 80.459, 80.459, 76.796, 75.31, 76.997, 92.283]) / 100
# ntsnotears_fdr_std = np.array([6.230168617, 5.358341255, 6.015007897, 6.934459171, 7.726288177, 7.726288177, 6.934459171, 6.015007897, 5.358341255, 6.2301686173]) / 100
# dycast_fdr_mean = np.array([9.405555556,6.823333333,6.027777778,7.421111111,8.755555556,8.334444444,7.896666667,5.68,6.144444444,9.213333333]) / 100
# dycast_fdr_std = np.array([6.922803079,3.188461837,3.480775066,5.133362434,6.47381411,6.073040811,6.143386688,4.072422157,4.590623562,2.560043402]) / 100
#
# dycausal_f1_mean = np.array([95.43333333, 95.01888889, 96.33222222, 96.07666667, 97.13111111, 97.43666667, 96.03333333, 96.65666667, 96.88555556, 95.96111111]) / 100
# dycausal_f1_std = np.array([3.9081823, 3.506325853, 2.324486934, 1.439328547, 1.290869168, 1.094460801, 1.270529199, 2.064509627, 1.46747789, 2.172358904]) / 100
# dynotears_f1_mean = np.array([68.803, 78.883, 81.549, 86.841, 91.265, 91.265, 86.841, 81.549, 78.883, 68.803]) / 100
# dynotears_f1_std = np.array([3.809126015, 3.632082185, 4.101890905, 5.370628362, 4.69643535, 4.69643535, 5.370628362, 4.101890905, 3.632082185, 3.809126015]) / 100
# ntsnotears_f1_mean = np.array([7.344, 18.527, 19.631, 19.22, 16.842, 16.842, 19.22, 19.631, 18.527, 7.344]) / 100
# ntsnotears_f1_std = np.array([6.069165017, 4.322029732, 4.486202069, 4.873282261, 3.971671688, 3.971671688, 4.873282261, 4.486202069, 4.322029732, 6.069165017]) / 100
# dycast_f1_mean = np.array([82.26222222,77.41444444,77.17666667,77.01222222,81.63777778,81.69333333,76.97,76.74111111,76.03222222,81.68333333]) / 100
# dycast_f1_std = np.array([9.916496668,8.682767238,6.437575458,5.024304878,5.371914159,5.462297034,5.778027345,5.519505703,7.498513598,6.046633591]) / 100
#
# dycausal_shd_mean = np.array([4.555555556, 6.222222222, 4.666666667, 4.888888889, 3.333333333, 3, 5, 4.333333333, 4.111111111, 4.222222222])
# dycausal_shd_std = np.array([3.467663674, 3.909469352, 2.666666667, 1.662958839, 1.632993162, 1.490711985, 1.632993162, 2.449489743, 2.182986967, 2.346523565])
# dynotears_shd_mean = np.array([38.4, 28.3, 24.9, 17.1, 10.7, 10.7, 17.1, 24.9, 28.3, 38.4])
# dynotears_shd_std = np.array([6.902173571, 7.798076686, 8.092589202, 9.396275858, 7.156116265, 7.156116265, 9.396275858, 8.092589202, 7.798076686, 6.902173571])
# ntsnotears_shd_mean = np.array([98.3, 95.1, 94.5, 90.9, 87.8, 87.8, 90.9, 94.5, 95.1, 98.3])
# ntsnotears_shd_std = np.array([12.14125199, 12.67635594, 13.0326513, 13.89568278, 14.43468046, 14.43468046, 13.89568278, 13.0326513, 12.67635594, 12.14125199])
# dycast_shd_mean = np.array([18.44444444,25,25.77777778,24.22222222,17.88888889,17.77777778,24.33333333,26.33333333,26.33333333,19])
# dycast_shd_std = np.array([9.662195645,7.760297818,5.788451679,3.18948891,4.039924214,4.184037863,4.268749492,6.271629241,6.599663291,5.734883511])
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 5))
#
# axs[0].plot(x, dycausal_tpr_mean, '-D', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[0].fill_between(x, dycausal_tpr_mean-dycausal_tpr_std, dycausal_tpr_mean+dycausal_tpr_std, color='green', alpha=0.2)
# axs[0].plot(x, dynotears_tpr_mean, '-v', color='orange', linewidth='2', markersize=10, label='DYNO')
# axs[0].fill_between(x, dynotears_tpr_mean-dynotears_tpr_std, dynotears_tpr_mean+dynotears_tpr_std, color='orange', alpha=0.2)
# axs[0].plot(x, ntsnotears_tpr_mean, '-^', color='blue', linewidth='2', markersize=10, label='NTS-NO')
# axs[0].fill_between(x, ntsnotears_tpr_mean-ntsnotears_tpr_std, ntsnotears_tpr_mean+ntsnotears_tpr_std, color='blue', alpha=0.2)
# axs[0].plot(x, dycast_tpr_mean, '-o', color='red', linewidth='2', markersize=10, label='DYCAST')
# axs[0].fill_between(x, dycast_tpr_mean-dycast_tpr_std, dycast_tpr_mean+dycast_tpr_std, color='red', alpha=0.2)
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks(x)
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
# axs[1].plot(x, dycausal_fdr_mean, '-D', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[1].fill_between(x, dycausal_fdr_mean-dycausal_fdr_std, dycausal_fdr_mean+dycausal_fdr_std, color='green', alpha=0.2)
# axs[1].plot(x, dynotears_fdr_mean, '-v', color='orange', linewidth='2', markersize=10, label='DYNO')
# axs[1].fill_between(x, dynotears_fdr_mean-dynotears_fdr_std, dynotears_fdr_mean+dynotears_fdr_std, color='orange', alpha=0.2)
# axs[1].plot(x, ntsnotears_fdr_mean, '-^', color='blue', linewidth='2', markersize=10, label='NTS-NO')
# axs[1].fill_between(x, ntsnotears_fdr_mean-ntsnotears_fdr_std, ntsnotears_fdr_mean+ntsnotears_fdr_std, color='blue', alpha=0.2)
# axs[1].plot(x, dycast_fdr_mean, '-o', color='red', linewidth='2', markersize=10, label='DYCAST')
# axs[1].fill_between(x, dycast_fdr_mean-dycast_fdr_std, dycast_fdr_mean+dycast_fdr_std, color='red', alpha=0.2)
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks(x)
# axs[1].set_ylabel('FDR', fontsize=30, fontweight='bold')
# axs[2].plot(x, dycausal_f1_mean, '-D', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[2].fill_between(x, dycausal_f1_mean-dycausal_f1_std, dycausal_f1_mean+dycausal_f1_std, color='green', alpha=0.2)
# axs[2].plot(x, dynotears_f1_mean, '-v', color='orange', linewidth='2', markersize=10, label='DYNO')
# axs[2].fill_between(x, dynotears_f1_mean-dynotears_f1_std, dynotears_f1_mean+dynotears_f1_std, color='orange', alpha=0.2)
# axs[2].plot(x, ntsnotears_f1_mean, '-^', color='blue', linewidth='2', markersize=10, label='NTS-NO')
# axs[2].fill_between(x, ntsnotears_f1_mean-ntsnotears_f1_std, ntsnotears_f1_mean+ntsnotears_f1_std, color='blue', alpha=0.2)
# axs[2].plot(x, dycast_f1_mean, '-o', color='red', linewidth='2', markersize=10, label='DYCAST')
# axs[2].fill_between(x, dycast_f1_mean-dycast_f1_std, dycast_f1_mean+dycast_f1_std, color='red', alpha=0.2)
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks(x)
# axs[2].set_ylabel('F1', fontsize=30, fontweight='bold')
# axs[3].plot(x, dycausal_shd_mean, '-D', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[3].fill_between(x, dycausal_shd_mean-dycausal_shd_std, dycausal_shd_mean+dycausal_shd_std, color='green', alpha=0.2)
# axs[3].plot(x, dynotears_shd_mean, '-v', color='orange', linewidth='2', markersize=10, label='DYNO')
# axs[3].fill_between(x, dynotears_shd_mean-dynotears_shd_std, dynotears_shd_mean+dynotears_shd_std, color='orange', alpha=0.2)
# axs[3].plot(x, ntsnotears_shd_mean, '-^', color='blue', linewidth='2', markersize=10, label='NTS-NO')
# axs[3].fill_between(x, ntsnotears_shd_mean-ntsnotears_shd_std, ntsnotears_shd_mean+ntsnotears_shd_std, color='blue', alpha=0.2)
# axs[3].plot(x, dycast_shd_mean, '-o', color='red', linewidth='2', markersize=10, label='DYCAST')
# axs[3].fill_between(x, dycast_shd_mean-dycast_shd_std, dycast_shd_mean+dycast_shd_std, color='red', alpha=0.2)
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks(x)
# axs[3].set_ylabel('SHD', fontsize=30, fontweight='bold')
#
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower right', bbox_to_anchor=(0.3, 1), ncol=10)
# plt.savefig('partial_dynamic_results.pdf')
# plt.show()

# fully dynamic evaluation in each time step
# x = np.linspace(1, 10, 10)
# dycausal_tpr_mean = np.array([92.96111111,84.81,89.15444444,86.48,92.50333333,93.14555556,86.29555556,87.85,85.30111111,89.22666667]) / 100
# dycausal_tpr_std = np.array([3.293503519,7.298164153,5.42230601,5.992938437,4.566233556,4.112182743,7.312122524,6.687105336,6.579992307,3.50990978]) / 100
# dynotears_tpr_mean = np.array([9.176,35.42,37.365,45.189,62.152,62.152,45.189,37.365,35.42,9.176]) / 100
# dynotears_tpr_std = np.array([8.339724456,7.54183532,7.793312839,7.072727126,9.242759112,9.242759112,7.072727126,7.793312839,7.54183532,8.339724456]) / 100
# ntsnotears_tpr_mean = np.array([7.072222222,16.85333333,18.33111111,21.26,26.70555556,26.70555556,21.26,18.33111111,16.85333333,7.072222222]) / 100
# ntsnotears_tpr_std = np.array([5.788787587,3.547863207,3.606082653,4.527952689,4.656186115,4.656186115,4.527952689,3.606082653,3.547863207,5.788787587]) / 100
# dycast_tpr_mean = np.array([25.98,33.94857143,36.43142857,37.03857143,50.87571429,51.25428571,37.33857143,35.38142857,32.30714286,24.15]) / 100
# dycast_tpr_std = np.array([10.3274295,7.968062013,8.381865508,10.8013272,11.28725559,10.15196513,9.474871169,8.267691729,6.084196659,8.965079874]) / 100
#
# dycausal_fdr_mean = np.array([6.074444444,3.092222222,2.535555556,2.428888889,0.555555556,1.174444444,1.317777778,2.758888889,4.676666667,9.665555556]) / 100
# dycausal_fdr_std = np.array([4.865175824,2.492726209,2.613082943,2.852852157,1.571348403,1.788749477,2.408691566,3.714920201,3.873376362,3.799947693]) / 100
# dynotears_fdr_mean = np.array([90.715,38.179,32.488,33.496,36.785,36.785,33.496,32.488,38.179,90.715]) / 100
# dynotears_fdr_std = np.array([5.816176149,9.666435175,10.1934526,10.3097645,10.67785582,10.67785582,10.3097645,10.1934526,9.666435175,5.816176149]) / 100
# ntsnotears_fdr_mean = np.array([87.88777778,60.11888889,55.58888889,57.61555556,62.50444444,62.50444444,57.61555556,55.58888889,60.11888889,87.88777778]) / 100
# ntsnotears_fdr_std = np.array([10.93527704,8.524459506,10.47368602,10.60059444,11.58543733,11.58543733,10.60059444,10.47368602,8.524459506,10.93527704]) / 100
# dycast_fdr_mean = np.array([65.54285714,21.51142857,16.03714286,19.93428571,22.81285714,22.37571429,20.53428571,19.87714286,23.93857143,64.31142857]) / 100
# dycast_fdr_std = np.array([10.59163513,10.19444306,8.020715526,7.494207014,9.233752858,10.74475401,9.314190184,10.23042202,7.261344678,10.85884554]) / 100
#
# dycausal_f1_mean = np.array([93.40333333,90.30444444,93.07333333,91.63777778,95.76777778,95.84777778,91.96,92.24,89.97222222,89.72]) / 100
# dycausal_f1_std = np.array([3.668802408,4.744913326,3.98276286,4.469274805,2.334322542,2.41392616,5.027038006,5.104570936,5.166298434,2.91270016]) / 100
# dynotears_f1_mean = np.array([8.992,44.072,47.147,53.073,61.654,61.654,53.073,47.147,44.072,8.992]) / 100
# dynotears_f1_std = np.array([6.805069875,5.623660374,5.961199628,6.110851086,6.589138335,6.589138335,6.110851086,5.961199628,5.623660374,6.805069875]) / 100
# ntsnotears_f1_mean = np.array([8.74,23.27,25.52777778,27.95,30.21444444,30.21444444,27.95,25.52777778,23.27,8.74]) / 100
# ntsnotears_f1_std = np.array([7.39905099,4.091897142,4.410061168,5.574463601,4.207768242,4.207768242,5.574463601,4.410061168,4.091897142,7.39905099]) / 100
# dycast_f1_mean = np.array([29.51428571,47.11857143,50.42,50.14571429,61.12285714,61.66,50.56857143,48.87285714,45.22857143,28.64428571]) / 100
# dycast_f1_std = np.array([10.67414079,9.298227832,9.226989913,11.25614608,10.9073353,10.60422423,10.38937153,9.485650387,7.073955104,9.874719319]) / 100
#
# dycausal_shd_mean = np.array([4.666666667,10.44444444,8,8,3.222222222,3.222222222,7.666666667,9,10.88888889,7.333333333])
# dycausal_shd_std = np.array([2.624669291,4.192880503,3.771236166,3.62092683,1.685083432,1.872477727,4.18993503,5.477225575,4.556910368,2])
# dynotears_shd_mean = np.array([71.6,55.1,53.1,42,28.4,28.4,42,53.1,55.1,71.6])
# dynotears_shd_std = np.array([10.33634365,9.104394543,9.126335519,11.90798052,11.21784293,11.21784293,11.90798052,9.126335519,9.104394543,10.33634365])
# ntsnotears_shd_mean = np.array([61.33333333,66.22222222,65.11111111,55.77777778,42.88888889,42.88888889,55.77777778,65.11111111,66.22222222,61.33333333])
# ntsnotears_shd_std = np.array([12.87547194,13.04503122,13.34536494,15.1641227,10.08237675,10.08237675,15.1641227,13.34536494,13.04503122,12.87547194])
# dycast_shd_mean = np.array([45.42857143,42.57142857,41.28571429,36.85714286,23,22.85714286,36.85714286,42.85714286,44.14285714,44.14285714])
# dycast_shd_std = np.array([7.208271892,4.865538962,6.67006716,8.236305889,7.634508123,7.845445839,7.95394909,7.434063904,4.421653583,6.749149606])
#
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 20
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(1, 4, figsize=(35, 5))
#
# axs[0].plot(x, dycausal_tpr_mean, '-D', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[0].fill_between(x, dycausal_tpr_mean-dycausal_tpr_std, dycausal_tpr_mean+dycausal_tpr_std, color='green', alpha=0.2)
# axs[0].plot(x, dynotears_tpr_mean, '-v', color='orange', linewidth='2', markersize=10, label='DYNO')
# axs[0].fill_between(x, dynotears_tpr_mean-dynotears_tpr_std, dynotears_tpr_mean+dynotears_tpr_std, color='orange', alpha=0.2)
# axs[0].plot(x, ntsnotears_tpr_mean, '-^', color='blue', linewidth='2', markersize=10, label='NTS-NO')
# axs[0].fill_between(x, ntsnotears_tpr_mean-ntsnotears_tpr_std, ntsnotears_tpr_mean+ntsnotears_tpr_std, color='blue', alpha=0.2)
# axs[0].plot(x, dycast_tpr_mean, '-o', color='red', linewidth='2', markersize=10, label='DYCAST')
# axs[0].fill_between(x, dycast_tpr_mean-dycast_tpr_std, dycast_tpr_mean+dycast_tpr_std, color='blue', alpha=0.2)
# axs[0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0].set_xticks(x)
# axs[0].set_ylabel('TPR', fontsize=30, fontweight='bold')
#
# axs[1].plot(x, dycausal_fdr_mean, '-D', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[1].fill_between(x, dycausal_fdr_mean-dycausal_fdr_std, dycausal_fdr_mean+dycausal_fdr_std, color='green', alpha=0.2)
# axs[1].plot(x, dynotears_fdr_mean, '-v', color='orange', linewidth='2', markersize=10, label='DYNO')
# axs[1].fill_between(x, dynotears_fdr_mean-dynotears_fdr_std, dynotears_fdr_mean+dynotears_fdr_std, color='orange', alpha=0.2)
# axs[1].plot(x, ntsnotears_fdr_mean, '-^', color='blue', linewidth='2', markersize=10, label='NTS-NO')
# axs[1].fill_between(x, ntsnotears_fdr_mean-ntsnotears_fdr_std, ntsnotears_fdr_mean+ntsnotears_fdr_std, color='blue', alpha=0.2)
# axs[1].plot(x, dycast_fdr_mean, '-o', color='red', linewidth='2', markersize=10, label='DYCAST')
# axs[1].fill_between(x, dycast_fdr_mean-dycast_fdr_std, dycast_fdr_mean+dycast_fdr_std, color='red', alpha=0.2)
# axs[1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1].set_xticks(x)
# axs[1].set_ylabel('FDR', fontsize=30, fontweight='bold')
#
# axs[2].plot(x, dycausal_f1_mean, '-D', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[2].fill_between(x, dycausal_f1_mean-dycausal_f1_std, dycausal_f1_mean+dycausal_f1_std, color='green', alpha=0.2)
# axs[2].plot(x, dynotears_f1_mean, '-v', color='orange', linewidth='2', markersize=10, label='DYNO')
# axs[2].fill_between(x, dynotears_f1_mean-dynotears_f1_std, dynotears_f1_mean+dynotears_f1_std, color='orange', alpha=0.2)
# axs[2].plot(x, ntsnotears_f1_mean, '-^', color='blue', linewidth='2', markersize=10, label='NTS-NO')
# axs[2].fill_between(x, ntsnotears_f1_mean-ntsnotears_f1_std, ntsnotears_f1_mean+ntsnotears_f1_std, color='blue', alpha=0.2)
# axs[2].plot(x, dycast_f1_mean, '-o', color='red', linewidth='2', markersize=10, label='DYCAST')
# axs[2].fill_between(x, dycast_f1_mean-dycast_f1_std, dycast_f1_mean+dycast_f1_std, color='red', alpha=0.2)
# axs[2].grid(linestyle='--', linewidth=1, color='gray')
# axs[2].set_xticks(x)
# axs[2].set_ylabel('F1', fontsize=30, fontweight='bold')
#
# axs[3].plot(x, dycausal_shd_mean, '-D', color='green', linewidth='2', markersize=10, label='DyCausal')
# axs[3].fill_between(x, dycausal_shd_mean-dycausal_shd_std, dycausal_shd_mean+dycausal_shd_std, color='green', alpha=0.2)
# axs[3].plot(x, dynotears_shd_mean, '-v', color='orange', linewidth='2', markersize=10, label='DYNO')
# axs[3].fill_between(x, dynotears_shd_mean-dynotears_shd_std, dynotears_shd_mean+dynotears_shd_std, color='orange', alpha=0.2)
# axs[3].plot(x, ntsnotears_shd_mean, '-^', color='blue', linewidth='2', markersize=10, label='NTS-NO')
# axs[3].fill_between(x, ntsnotears_shd_mean-ntsnotears_shd_std, ntsnotears_shd_mean+ntsnotears_shd_std, color='blue', alpha=0.2)
# axs[3].plot(x, dycast_shd_mean, '-o', color='red', linewidth='2', markersize=10, label='DYCAST')
# axs[3].fill_between(x, dycast_shd_mean-dycast_shd_std, dycast_shd_mean+dycast_shd_std, color='red', alpha=0.2)
# axs[3].grid(linestyle='--', linewidth=1, color='gray')
# axs[3].set_xticks(x)
# axs[3].set_ylabel('SHD', fontsize=30, fontweight='bold')
#
# handles, labels = axs[0].get_legend_handles_labels()
# plt.legend(handles, labels, loc='lower right', bbox_to_anchor=(0.3, 1), ncol=10)
# plt.savefig('dynamic_full_results.pdf')
# plt.show()

# real dataset dynamic structures
# mean_W1 = np.load('mean_W1.npy')
# mean_W2 = np.load('mean_W2.npy')
# mean_W = np.concatenate((mean_W1[:18], mean_W2[:18]), axis=0)
# plt.rcParams['font.family'] = 'Times New Roman'
# plt.rcParams['font.size'] = 15
# plt.rcParams['font.weight'] = 'bold'
# fig, axs = plt.subplots(2, 4, figsize=(25, 5))
#
# x = np.linspace(1, 36, 36)
# axs[0, 0].plot(x, mean_W[:, 6, 4], '-', color='green', linewidth='2', markersize=10, label='x6->x4')
# axs[0, 0].grid(linestyle='--', linewidth=1, color='gray')
# axs[0, 0].legend(loc='upper right', fontsize=15)
# axs[0, 1].plot(x, mean_W[:, 4, 19], '-', color='red', linewidth='2', markersize=10, label='x4->x19')
# axs[0, 1].grid(linestyle='--', linewidth=1, color='gray')
# axs[0, 1].legend(loc='upper right', fontsize=15)
# axs[0, 2].plot(x, mean_W[:, 6, 19], '-', color='blue', linewidth='2', markersize=10, label='x6->x19')
# axs[0, 2].grid(linestyle='--', linewidth=1, color='gray')
# axs[0, 2].legend(loc='upper right', fontsize=15)
# axs[0, 3].plot(x, mean_W[:, 15, 7], '-', color='m', linewidth='2', markersize=10, label='x15->x7')
# axs[0, 3].grid(linestyle='--', linewidth=1, color='gray')
# axs[0, 3].legend(loc='upper right', fontsize=15)
# axs[1, 0].plot(x, mean_W[:, 4, 8], '-', color='black', linewidth='2', markersize=10, label='x4->x8')
# axs[1, 0].grid(linestyle='--', linewidth=1, color='gray')
# axs[1, 0].legend(loc='upper right', fontsize=15)
# axs[1, 0].set_xlabel('Time step', fontsize=20, fontweight='bold')
# axs[1, 1].plot(x, mean_W[:, 19, 4], '-', color='orange', linewidth='2', markersize=10, label='x19->x4')
# axs[1, 1].grid(linestyle='--', linewidth=1, color='gray')
# axs[1, 1].legend(loc='upper right', fontsize=15)
# axs[1, 1].set_xlabel('Time step', fontsize=20, fontweight='bold')
# axs[1, 2].plot(x, mean_W[:, 19, 6], '-', color='purple', linewidth='2', markersize=10, label='x19->x6')
# axs[1, 2].grid(linestyle='--', linewidth=1, color='gray')
# axs[1, 2].legend(loc='upper right', fontsize=15)
# axs[1, 2].set_xlabel('Time step', fontsize=20, fontweight='bold')
# axs[1, 3].plot(x, mean_W[:, 16, 10], '-', color='brown', linewidth='2', markersize=10, label='x16->x10')
# axs[1, 3].grid(linestyle='--', linewidth=1, color='gray')
# axs[1, 3].legend(loc='upper right', fontsize=15)
# axs[1, 3].set_xlabel('Time step', fontsize=20, fontweight='bold')
# # plt.savefig('real_dynamic_graph.pdf')
# plt.show()