from matplotlib import pyplot as plt
import tkinter as tk
from tkinter import filedialog
import numpy as np
from pathlib import Path
from matplotlib import pyplot as plt, cm
import numpy as np
from scipy.cluster.vq import kmeans, vq
from glob import glob
from keras.models import *
from keras.layers import *
import random

i_number =1
while True:
    n = 300
    p = 100
    n_dep = 100

    # x随机取值
    mean = np.zeros(shape=[p])

    cov = np.load(r'E:/Code/cov_cs.npy')

    size = (n, 1)
    x_solo = np.random.multivariate_normal(mean, cov, size)
    x = np.zeros(shape=[n, p])
    for i in range(n):
        x[i] = x_solo[i]

    # e随机取值
    e = []
    for _ in range(n):
        e.append(random.normalvariate(0, 0.1))
    e = np.array(e)

    #  通过模型计算出y的取值
    '''
    y = np.zeros(shape=[n])
    for i in range(n):
        y[i] = 2 * x[i][0] + x[i][1] + 3 * x[i][2] + e[i]
    '''
    y = np.zeros(shape=[n])
    for i in range(n):
        y[i] = np.square(x[i][0] + x[i][1] + x[i][2]) + 1 + e[i]


    model = Sequential()
    model.add(Dense(90, input_dim=100, kernel_initializer='normal', activation='relu'))
    model.add(Dense(1, input_dim=90, kernel_initializer='normal', activation='relu'))
    #model.add(Dense(1, input_dim=60, kernel_initializer='normal', activation='relu'))
    model.compile(loss='mean_squared_error', optimizer='adam')

    model.fit(x, y,epochs=150, batch_size= 5,verbose=0)

    e_test = []
    for _ in range(n):
        e_test.append(random.normalvariate(0, 0.1))
    e_test = np.array(e_test)

    x_test = np.load(r'E:/Code/x_test_corr_cs.npy')

    y_test = np.zeros(shape=[n])
    for i in range(n):
        y_test[i] = np.square(x_test[i][0] + x_test[i][1] + x_test[i][2]) + 1 + e_test[i]

    y_hat = model.predict(x_test).T
    '''
    MSE = np.sqrt(np.sum(np.square((y_test - y_hat) / ((y_test) / 2))) / 300)
    print(MSE)
    '''
    MSE = np.sqrt(np.sum(np.square((y_test - y_hat) / ((y_test) / 2))) / 300)
    print(MSE)

    i_number += 1
    if i_number > 100:
        break

