import random
import matplotlib.pyplot as plt
import numpy as np
import math

i_number = 1

while True:
    n = 300
    n_dep = 100
    p = 100
    N = 24000
    t = 0.000001  # lambda

    # 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] = np.cos(
            x[i][0] + 2 * x[i][0] * x[i][1] + np.square(x[i][2]) + np.sin(x[i][3]) + np.exp(x[i][4])) + np.exp(
            x[i][5] + x[i][6]) + np.cos(x[i][7] + x[i][8] + np.square(x[i][9])) + np.square(x[i][0] + x[i][4]) + e[i]

    
    y = np.zeros(shape=[n])
    for i in range(n):
        y[i] = np.cos(x[i][0] + np.cos(x[i][0]) + np.square(x[i][1]) + np.exp(x[i][1] / 3) + x[i][4] * x[i][2] * x[i][
            3] + np.cos(x[i][4]) + 2 * x[i][5] + np.square(x[i][6]) + x[i][7] * x[i][8] + x[i][9] + e[i])


    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]

    # w的取值（均匀分布）
    w = np.zeros(shape=[N, p])
    for i in range(N):
        w[i] = np.random.uniform(-1, 1, size=p)

    # 标准化wi 范数为1
    w_norm = np.zeros(shape=[N, p])
    for i in range(N):
        for j in range(p):
            w_norm[i][j] = w[i][j] / np.sqrt(np.sum(np.square(w[i])))

    # b的取值
    b = []
    for _ in range(n * N):
        b.append(random.normalvariate(0, 1))
    b = np.array(b)
    b = b.reshape(n, N)

    # b_test的取值
    b_test = []
    for _ in range(n * N):
        b_test.append(random.normalvariate(0, 1))
    b_test = np.array(b_test)
    b_test = b_test.reshape(n, N)

    # 测试集e
    e_test = []
    for _ in range(n):
        e_test.append(random.normalvariate(0, 0.1))
    e_test = np.array(e_test)
    # 测试集x
    # 测试集y
    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_test = np.zeros(shape=[n])
    for i in range(n):
        y_test[i] = np.cos(
            x_test[i][0] + 2 * x_test[i][0] * x_test[i][1] + np.square(x_test[i][2]) + np.sin(x_test[i][3]) + np.exp(
                x_test[i][4])) + np.exp(x_test[i][5] + x_test[i][6]) + np.cos(
            x_test[i][7] + x_test[i][8] + np.square(x_test[i][9])) + np.square(x_test[i][0] + x_test[i][4]) + e_test[i]

    y_test = np.zeros(shape=[n])
    for i in range(n):
        y_test[i] = np.cos(
            x_test[i][0] + np.cos(x_test[i][0]) + np.square(x_test[i][1]) + np.exp(x_test[i][1] / 3) + x_test[i][4] *
            x_test[i][2] * x_test[i][3] + np.cos(x_test[i][4]) + 2 * x_test[i][5] + np.square(x_test[i][6]) + x_test[i][
                7] * x_test[i][8] +
            x_test[i][9] + e_test[i])
    '''

    k = np.maximum(0, np.dot(x, w_norm.T) + b)
    k_test = np.maximum(0, np.dot(x_test, w_norm.T) + b_test)

    # 估计alpha
    f1 = np.linalg.inv(np.dot(k.T, k) + N * t / p * np.identity(N))
    f2 = np.dot(f1, k.T)
    alpha = np.dot(f2, y)

    # 估计 y hat
    y_hat = np.dot(k_test, alpha) + e_test

    # 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
