import random
import numpy as np


i_number = 1
while True:

    n = 300
    n_dep = 100
    p = 100
    N = 24000
    t = 0.00001  # 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.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])))

    e1 = []
    for _ in range(n):
        e1.append(random.normalvariate(0, 0.1))
    e1 = np.array(e1)

    # 测试集e
    e_test = []
    for _ in range(n):
        e_test.append(random.normalvariate(0, 0.1))
    e_test = np.array(e_test)

    e1_test = []
    for _ in range(n):
        e1_test.append(random.normalvariate(0, 0.1))
    e1_test = np.array(e1_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]

    # 内层截距训练集
    b = []
    for _ in range(int(n * N)):
        b.append(random.normalvariate(0, 1))
    b = np.array(b)
    b = b.reshape(n, int(N))

    b1 = []
    for _ in range(int(n * N / 10)):
        b1.append(random.normalvariate(0, 1))
    b1 = np.array(b1)
    b1 = b1.reshape(n, int(N / 10))

    # 内层截距训练集
    b2 = []
    for _ in range(int(n * N / 10)):
        b2.append(random.normalvariate(0, 1))
    b2 = np.array(b2)
    b2 = b2.reshape(n, int(N / 10))

    b3 = []
    for _ in range(int(n * N / 10)):
        b3.append(random.normalvariate(0, 1))
    b3 = np.array(b3)
    b3 = b3.reshape(n, int(N / 10))

    b4 = []
    for _ in range(int(n * N / 10)):
        b4.append(random.normalvariate(0, 1))
    b4 = np.array(b4)
    b4 = b4.reshape(n, int(N / 10))

    b5 = []
    for _ in range(int(n * N / 10)):
        b5.append(random.normalvariate(0, 1))
    b5 = np.array(b5)
    b5 = b5.reshape(n, int(N / 10))

    b6 = []
    for _ in range(int(n * N / 10)):
        b6.append(random.normalvariate(0, 1))
    b6 = np.array(b6)
    b6 = b6.reshape(n, int(N / 10))

    b7 = []
    for _ in range(int(n * N / 10)):
        b7.append(random.normalvariate(0, 1))
    b7 = np.array(b7)
    b7 = b7.reshape(n, int(N / 10))

    b8 = []
    for _ in range(int(n * N / 10)):
        b8.append(random.normalvariate(0, 1))
    b8 = np.array(b8)
    b8 = b8.reshape(n, int(N / 10))

    b9 = []
    for _ in range(int(n * N / 10)):
        b9.append(random.normalvariate(0, 1))
    b9 = np.array(b9)
    b9 = b9.reshape(n, int(N / 10))

    b10 = []
    for _ in range(int(n * N / 10)):
        b10.append(random.normalvariate(0, 1))
    b10 = np.array(b10)
    b10 = b10.reshape(n, int(N / 10))

    # 内层截距测试集
    b_test = []
    for _ in range(int(n * N)):
        b_test.append(random.normalvariate(0, 1))
    b_test = np.array(b_test)
    b_test = b_test.reshape(n, int(N))

    b1_test = []
    for _ in range(int(n * N / 10)):
        b1_test.append(random.normalvariate(0, 1))
    b1_test = np.array(b1_test)
    b1_test = b1_test.reshape(n, int(N / 10))

    b2_test = []
    for _ in range(int(n * N / 10)):
        b2_test.append(random.normalvariate(0, 1))
    b2_test = np.array(b2_test)
    b2_test = b2_test.reshape(n, int(N / 10))

    b3_test = []
    for _ in range(int(n * N / 10)):
        b3_test.append(random.normalvariate(0, 1))
    b3_test = np.array(b3_test)
    b3_test = b3_test.reshape(n, int(N / 10))

    b4_test = []
    for _ in range(int(n * N / 10)):
        b4_test.append(random.normalvariate(0, 1))
    b4_test = np.array(b4_test)
    b4_test = b4_test.reshape(n, int(N / 10))

    b5_test = []
    for _ in range(int(n * N / 10)):
        b5_test.append(random.normalvariate(0, 1))
    b5_test = np.array(b5_test)
    b5_test = b5_test.reshape(n, int(N / 10))

    b6_test = []
    for _ in range(int(n * N / 10)):
        b6_test.append(random.normalvariate(0, 1))
    b6_test = np.array(b6_test)
    b6_test = b6_test.reshape(n, int(N / 10))

    b7_test = []
    for _ in range(int(n * N / 10)):
        b7_test.append(random.normalvariate(0, 1))
    b7_test = np.array(b7_test)
    b7_test = b7_test.reshape(n, int(N / 10))

    b8_test = []
    for _ in range(int(n * N / 10)):
        b8_test.append(random.normalvariate(0, 1))
    b8_test = np.array(b8_test)
    b8_test = b8_test.reshape(n, int(N / 10))

    b9_test = []
    for _ in range(int(n * N / 10)):
        b9_test.append(random.normalvariate(0, 1))
    b9_test = np.array(b9_test)
    b9_test = b9_test.reshape(n, int(N / 10))

    b10_test = []
    for _ in range(int(n * N / 10)):
        b10_test.append(random.normalvariate(0, 1))
    b10_test = np.array(b10_test)
    b10_test = b10_test.reshape(n, int(N / 10))

    w1 = w_norm[0:int(N / 10)]
    w2 = w_norm[int(N / 10):int(N / 10 * 2)]
    w3 = w_norm[int(N / 10 * 2):int(N / 10 * 3)]
    w4 = w_norm[int(N / 10 * 3):int(N / 10 * 4)]
    w5 = w_norm[int(N / 10 * 4):int(N / 10 * 5)]
    w6 = w_norm[int(N / 10 * 5):int(N / 10 * 6)]
    w7 = w_norm[int(N / 10 * 6):int(N / 10 * 7)]
    w8 = w_norm[int(N / 10 * 7):int(N / 10 * 8)]
    w9 = w_norm[int(N / 10 * 8):int(N / 10 * 9)]
    w10 = w_norm[int(N / 10 * 9):int(N / 10 * 10)]

    k1 = np.maximum(0, np.dot(x, w1.T) + b1)
    k2 = np.maximum(0, np.dot(x, w2.T) + b2)
    k3 = np.maximum(0, np.dot(x, w3.T) + b3)
    k4 = np.maximum(0, np.dot(x, w4.T) + b4)
    k5 = np.maximum(0, np.dot(x, w5.T) + b5)
    k6 = np.maximum(0, np.dot(x, w6.T) + b6)
    k7 = np.maximum(0, np.dot(x, w7.T) + b7)
    k8 = np.maximum(0, np.dot(x, w8.T) + b8)
    k9 = np.maximum(0, np.dot(x, w9.T) + b9)
    k10 = np.maximum(0, np.dot(x, w10.T) + b10)

    # 估计alpha1
    f1 = np.linalg.inv(np.dot(k1.T, k1) + int(N / 10) * t / p * np.identity(int(N / 10)))
    f2 = np.dot(f1, k1.T)
    alpha1 = np.dot(f2, y)

    # 估计alpha2
    f1 = np.linalg.inv(np.dot(k2.T, k2) + int(N / 10) * t / p * np.identity(int(N / 10)))
    f2 = np.dot(f1, k2.T)
    alpha2 = np.dot(f2, y)

    # 估计alpha3
    f1 = np.linalg.inv(np.dot(k3.T, k3) + int(N / 10) * t / p * np.identity(int(N / 10)))
    f2 = np.dot(f1, k3.T)
    alpha3 = np.dot(f2, y)

    # 估计alpha4
    f1 = np.linalg.inv(np.dot(k4.T, k4) + int(N / 10) * t / p * np.identity(int(N / 10)))
    f2 = np.dot(f1, k4.T)
    alpha4 = np.dot(f2, y)

    # 估计alpha5
    f1 = np.linalg.inv(np.dot(k5.T, k5) + int(N / 10) * t / p * np.identity(int(N / 10)))
    f2 = np.dot(f1, k5.T)
    alpha5 = np.dot(f2, y)

    # 估计alpha6
    f1 = np.linalg.inv(np.dot(k6.T, k6) + int(N / 10) * t / p * np.identity(int(N / 10)))
    f2 = np.dot(f1, k6.T)
    alpha6 = np.dot(f2, y)

    # 估计alpha7
    f1 = np.linalg.inv(np.dot(k7.T, k7) + int(N / 10) * t / p * np.identity(int(N / 10)))
    f2 = np.dot(f1, k7.T)
    alpha7 = np.dot(f2, y)

    # 估计alpha8
    f1 = np.linalg.inv(np.dot(k8.T, k8) + int(N / 10) * t / p * np.identity(int(N / 10)))
    f2 = np.dot(f1, k8.T)
    alpha8 = np.dot(f2, y)

    # 估计alpha9
    f1 = np.linalg.inv(np.dot(k9.T, k9) + int(N / 10) * t / p * np.identity(int(N / 10)))
    f2 = np.dot(f1, k9.T)
    alpha9 = np.dot(f2, y)

    # 估计alpha10
    f1 = np.linalg.inv(np.dot(k10.T, k10) + int(N / 10) * t / p * np.identity(int(N / 10)))
    f2 = np.dot(f1, k10.T)
    alpha10 = np.dot(f2, y)

    x1 = np.dot(k1, alpha1) + e1
    x2 = np.dot(k2, alpha2) + e1
    x3 = np.dot(k3, alpha3) + e1
    x4 = np.dot(k4, alpha4) + e1
    x5 = np.dot(k5, alpha5) + e1
    x6 = np.dot(k6, alpha6) + e1
    x7 = np.dot(k7, alpha7) + e1
    x8 = np.dot(k8, alpha8) + e1
    x9 = np.dot(k9, alpha9) + e1
    x10 = np.dot(k10, alpha10) + e1

    x_inside = np.zeros(shape=[n, 10])
    x_inside[:, 0] = x1
    x_inside[:, 1] = x2
    x_inside[:, 2] = x3
    x_inside[:, 3] = x4
    x_inside[:, 4] = x5
    x_inside[:, 5] = x6
    x_inside[:, 6] = x7
    x_inside[:, 7] = x8
    x_inside[:, 8] = x9
    x_inside[:, 9] = x10

    # 外层w的取值（均匀分布）
    w_outside = np.zeros(shape=[N, 10])
    for i in range(N):
        w_outside[i] = np.random.uniform(-1, 1, size=10)

    # 外层标准化wi 范数为1
    w_norm_outside = np.zeros(shape=[N, 10])
    for i in range(N):
        for j in range(10):
            w_norm_outside[i][j] = w_outside[i][j] / np.sqrt(np.sum(np.square(w_outside[i])))

    k = np.maximum(0, np.dot(x_inside, w_norm_outside.T) + b)

    f3 = np.linalg.inv(np.dot(k.T, k) + N * t / 10 * np.identity(N))
    f4 = np.dot(f3, k.T)
    alpha_outside = np.dot(f4, y)

    k1_test = np.maximum(0, np.dot(x_test, w1.T) + b1_test)
    k2_test = np.maximum(0, np.dot(x_test, w2.T) + b2_test)
    k3_test = np.maximum(0, np.dot(x_test, w3.T) + b3_test)
    k4_test = np.maximum(0, np.dot(x_test, w4.T) + b4_test)
    k5_test = np.maximum(0, np.dot(x_test, w5.T) + b5_test)
    k6_test = np.maximum(0, np.dot(x_test, w6.T) + b6_test)
    k7_test = np.maximum(0, np.dot(x_test, w7.T) + b7_test)
    k8_test = np.maximum(0, np.dot(x_test, w8.T) + b8_test)
    k9_test = np.maximum(0, np.dot(x_test, w9.T) + b9_test)
    k10_test = np.maximum(0, np.dot(x_test, w10.T) + b10_test)

    x1_test = np.dot(k1_test, alpha1) + e1_test
    x2_test = np.dot(k2_test, alpha2) + e1_test
    x3_test = np.dot(k3_test, alpha3) + e1_test
    x4_test = np.dot(k4_test, alpha4) + e1_test
    x5_test = np.dot(k5_test, alpha5) + e1_test
    x6_test = np.dot(k6_test, alpha6) + e1_test
    x7_test = np.dot(k7_test, alpha7) + e1_test
    x8_test = np.dot(k8_test, alpha8) + e1_test
    x9_test = np.dot(k9_test, alpha9) + e1_test
    x10_test = np.dot(k10_test, alpha10) + e1_test

    x_inside_test = np.zeros(shape=[n, 10])
    x_inside_test[:, 0] = x1_test
    x_inside_test[:, 1] = x2_test
    x_inside_test[:, 2] = x3_test
    x_inside_test[:, 3] = x4_test
    x_inside_test[:, 4] = x5_test
    x_inside_test[:, 5] = x6_test
    x_inside_test[:, 6] = x7_test
    x_inside_test[:, 7] = x8_test
    x_inside_test[:, 8] = x9_test
    x_inside_test[:, 9] = x10_test

    # 激活函数 Relu _test
    k_test = np.maximum(0, np.dot(x_inside_test, w_norm_outside.T) + b_test)

    y_hat = np.zeros(shape=[n])
    for i in range(n):
        y_hat[i] = np.dot(alpha_outside, k_test[i]) + e_test[i]

    MSE = np.sqrt(np.sum(np.square((y_test - y_hat) / ((y_test) / 2))) / 300)
    '''
    MSE1 = np.sum(np.square(y_test - y_hat)) / n
    print(MSE1)
    '''
    print(MSE)

    i_number += 1
    if i_number > 100:
        break