from scipy.stats import pearsonr
import numpy as np

GeneralizationGaps = [0.9571, 0.9746, 0.8762, 0.9215, 0.8704, 0.9697, 1.0049, 0.8867, 0.9446, 0.9279, 0.85239208010474, 0.8402213777622415, 0.6711273832867345, 0.73709, 0.7566928378009834, 0.8507092792827582, 0.851555306930095, 0.6851725820435689, 0.7222, 0.7716393423355232]
Moments = [0.180436710516612, 0.201649248600006, 0.473135670026143, 0.228593647480011, 0.393231391906738, 0.17836938963996, 0.195478200912476, 0.456342432234022, 0.219744775030348, 0.366114881303575]
AccGradientVariances = [2010, 2195, 2175, 2164, 2400, 2115, 2294, 2303, 2212, 2550, 2228, 2338, 2387, 2076, 2425, 2283, 2427, 2462, 2059, 2543]

GeneRatios = [0.9571/0.9697, 0.9746/1.0049, 0.8762/0.8867, 0.9215/0.9446, 0.8704/0.9279, 0.85239208010474/0.8507092792827582, 0.8402213777622415/0.851555306930095, 0.6711273832867345/0.6851725820435689, 3.6877/3.8241, 0.7566928378009834/0.7716393423355232, 0.8525/0.8506, 0.8455/0.8515, 0.6763/0.6851, 0.7181/0.7222, 0.7534/0.7716]
AccGradRatios = [2010/2115, 2195/2294, 2175/2303, 2164/2212, 2400/2550, 2228/2283, 2338/2427, 2387/2462, 10316/11035, 2425/2543, 2284/2283, 2398/2427, 2441/2462, 2021/2059, 2494/2543]
#correlation, _ = pearsonr(np.array(GeneralizationGaps), np.array(Moments))
#print("The correlation between the Generalization Gaps and Moments is {}".format(correlation))
correlation, _ = pearsonr(np.array(GeneralizationGaps), np.array(AccGradientVariances))
print("The correlation between the Generalization Gaps and Accumulated Gradient Variances is {}".format(correlation))
#correlation, _ = pearsonr(np.array(Moments), np.array(AccGradientVariances))
#print("The correlation between the Moments and the Accumulated Gradient Gaps is {}".format(correlation))
correlation, _ = pearsonr(np.array(GeneRatios[3:]), np.array(AccGradRatios[3:]))
print(correlation)


sum = 0
for i in range(12000):
    prod = 1
    for j in range(i,12000):
        prod = prod * (1+0.04*0.02) ** 2
    sum += prod

print(sum)