import random
import numpy as np
from statsmodels.nonparametric.kernel_regression import KernelReg
from skpp import ProjectionPursuitRegressor
from direpack import dicomo, ppdire
from numpy import linalg as la

i_number = 1
while True:

    n = 300
    p = 100
    N = 24000
    t = 100  # 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)

    # 测试集e
    e_test = []
    for _ in range(n):
        e_test.append(random.normalvariate(0, 0.1))
    e_test = np.array(e_test)

    #  通过模型计算出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]

    '''
    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] = np.square(x[i][0] + x[i][1] + x[i][2]) + 1+ e[i]
    '''

    # 测试集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]

    # 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])))

    # 内层e
    e1 = []
    for _ in range(n):
        e1.append(random.normalvariate(0, 0.1))
    e1 = np.array(e1)

    e1_test = []
    for _ in range(n):
        e1_test.append(random.normalvariate(0, 0.1))
    e1_test = np.array(e1_test)

    # 内层截距训练集
    b1 = []
    for _ in range(int(n * N / 20)):
        b1.append(random.normalvariate(0, 1))
    b1 = np.array(b1)
    b1 = b1.reshape(n, int(N / 20))

    # 内层截距训练集
    b2 = []
    for _ in range(int(n * N / 20)):
        b2.append(random.normalvariate(0, 1))
    b2 = np.array(b2)
    b2 = b2.reshape(n, int(N / 20))

    b3 = []
    for _ in range(int(n * N / 20)):
        b3.append(random.normalvariate(0, 1))
    b3 = np.array(b3)
    b3 = b3.reshape(n, int(N / 20))

    b4 = []
    for _ in range(int(n * N / 20)):
        b4.append(random.normalvariate(0, 1))
    b4 = np.array(b4)
    b4 = b4.reshape(n, int(N / 20))

    b5 = []
    for _ in range(int(n * N / 20)):
        b5.append(random.normalvariate(0, 1))
    b5 = np.array(b5)
    b5 = b5.reshape(n, int(N / 20))

    b6 = []
    for _ in range(int(n * N / 20)):
        b6.append(random.normalvariate(0, 1))
    b6 = np.array(b6)
    b6 = b6.reshape(n, int(N / 20))

    b7 = []
    for _ in range(int(n * N / 20)):
        b7.append(random.normalvariate(0, 1))
    b7 = np.array(b7)
    b7 = b7.reshape(n, int(N / 20))

    b8 = []
    for _ in range(int(n * N / 20)):
        b8.append(random.normalvariate(0, 1))
    b8 = np.array(b8)
    b8 = b8.reshape(n, int(N / 20))

    b9 = []
    for _ in range(int(n * N / 20)):
        b9.append(random.normalvariate(0, 1))
    b9 = np.array(b9)
    b9 = b9.reshape(n, int(N / 20))

    b10 = []
    for _ in range(int(n * N / 20)):
        b10.append(random.normalvariate(0, 1))
    b10 = np.array(b10)
    b10 = b10.reshape(n, int(N / 20))

    b11 = []
    for _ in range(int(n * N / 20)):
        b11.append(random.normalvariate(0, 1))
    b11 = np.array(b11)
    b11 = b11.reshape(n, int(N / 20))

    b12 = []
    for _ in range(int(n * N / 20)):
        b12.append(random.normalvariate(0, 1))
    b12 = np.array(b12)
    b12 = b12.reshape(n, int(N / 20))

    b13 = []
    for _ in range(int(n * N / 20)):
        b13.append(random.normalvariate(0, 1))
    b13 = np.array(b13)
    b13 = b13.reshape(n, int(N / 20))

    b14 = []
    for _ in range(int(n * N / 20)):
        b14.append(random.normalvariate(0, 1))
    b14 = np.array(b14)
    b14 = b14.reshape(n, int(N / 20))

    b15 = []
    for _ in range(int(n * N / 20)):
        b15.append(random.normalvariate(0, 1))
    b15 = np.array(b15)
    b15 = b15.reshape(n, int(N / 20))

    b16 = []
    for _ in range(int(n * N / 20)):
        b16.append(random.normalvariate(0, 1))
    b16 = np.array(b16)
    b16 = b16.reshape(n, int(N / 20))

    b17 = []
    for _ in range(int(n * N / 20)):
        b17.append(random.normalvariate(0, 1))
    b17 = np.array(b17)
    b17 = b17.reshape(n, int(N / 20))

    b18 = []
    for _ in range(int(n * N / 20)):
        b18.append(random.normalvariate(0, 1))
    b18 = np.array(b18)
    b18 = b18.reshape(n, int(N / 20))

    b19 = []
    for _ in range(int(n * N / 20)):
        b19.append(random.normalvariate(0, 1))
    b19 = np.array(b19)
    b19 = b19.reshape(n, int(N / 20))

    b20 = []
    for _ in range(int(n * N / 20)):
        b20.append(random.normalvariate(0, 1))
    b20 = np.array(b20)
    b20 = b20.reshape(n, int(N / 20))

    # 内层截距测试集
    b1_test = []
    for _ in range(int(n * N / 20)):
        b1_test.append(random.normalvariate(0, 1))
    b1_test = np.array(b1_test)
    b1_test = b1_test.reshape(n, int(N / 20))

    b2_test = []
    for _ in range(int(n * N / 20)):
        b2_test.append(random.normalvariate(0, 1))
    b2_test = np.array(b2_test)
    b2_test = b2_test.reshape(n, int(N / 20))

    b3_test = []
    for _ in range(int(n * N / 20)):
        b3_test.append(random.normalvariate(0, 1))
    b3_test = np.array(b3_test)
    b3_test = b3_test.reshape(n, int(N / 20))

    b4_test = []
    for _ in range(int(n * N / 20)):
        b4_test.append(random.normalvariate(0, 1))
    b4_test = np.array(b4_test)
    b4_test = b4_test.reshape(n, int(N / 20))

    b5_test = []
    for _ in range(int(n * N / 20)):
        b5_test.append(random.normalvariate(0, 1))
    b5_test = np.array(b5_test)
    b5_test = b5_test.reshape(n, int(N / 20))

    b6_test = []
    for _ in range(int(n * N / 20)):
        b6_test.append(random.normalvariate(0, 1))
    b6_test = np.array(b6_test)
    b6_test = b6_test.reshape(n, int(N / 20))

    b7_test = []
    for _ in range(int(n * N / 20)):
        b7_test.append(random.normalvariate(0, 1))
    b7_test = np.array(b7_test)
    b7_test = b7_test.reshape(n, int(N / 20))

    b8_test = []
    for _ in range(int(n * N / 20)):
        b8_test.append(random.normalvariate(0, 1))
    b8_test = np.array(b8_test)
    b8_test = b8_test.reshape(n, int(N / 20))

    b9_test = []
    for _ in range(int(n * N / 20)):
        b9_test.append(random.normalvariate(0, 1))
    b9_test = np.array(b9_test)
    b9_test = b9_test.reshape(n, int(N / 20))

    b10_test = []
    for _ in range(int(n * N / 20)):
        b10_test.append(random.normalvariate(0, 1))
    b10_test = np.array(b10_test)
    b10_test = b10_test.reshape(n, int(N / 20))

    b11_test = []
    for _ in range(int(n * N / 20)):
        b11_test.append(random.normalvariate(0, 1))
    b11_test = np.array(b11_test)
    b11_test = b11_test.reshape(n, int(N / 20))

    b12_test = []
    for _ in range(int(n * N / 20)):
        b12_test.append(random.normalvariate(0, 1))
    b12_test = np.array(b12_test)
    b12_test = b12_test.reshape(n, int(N / 20))

    b13_test = []
    for _ in range(int(n * N / 20)):
        b13_test.append(random.normalvariate(0, 1))
    b13_test = np.array(b13_test)
    b13_test = b13_test.reshape(n, int(N / 20))

    b14_test = []
    for _ in range(int(n * N / 20)):
        b14_test.append(random.normalvariate(0, 1))
    b14_test = np.array(b14_test)
    b14_test = b14_test.reshape(n, int(N / 20))

    b15_test = []
    for _ in range(int(n * N / 20)):
        b15_test.append(random.normalvariate(0, 1))
    b15_test = np.array(b15_test)
    b15_test = b15_test.reshape(n, int(N / 20))

    b16_test = []
    for _ in range(int(n * N / 20)):
        b16_test.append(random.normalvariate(0, 1))
    b16_test = np.array(b16_test)
    b16_test = b16_test.reshape(n, int(N / 20))

    b17_test = []
    for _ in range(int(n * N / 20)):
        b17_test.append(random.normalvariate(0, 1))
    b17_test = np.array(b17_test)
    b17_test = b17_test.reshape(n, int(N / 20))

    b18_test = []
    for _ in range(int(n * N / 20)):
        b18_test.append(random.normalvariate(0, 1))
    b18_test = np.array(b18_test)
    b18_test = b18_test.reshape(n, int(N / 20))

    b19_test = []
    for _ in range(int(n * N / 20)):
        b19_test.append(random.normalvariate(0, 1))
    b19_test = np.array(b19_test)
    b19_test = b19_test.reshape(n, int(N / 20))

    b20_test = []
    for _ in range(int(n * N / 20)):
        b20_test.append(random.normalvariate(0, 1))
    b20_test = np.array(b20_test)
    b20_test = b20_test.reshape(n, int(N / 20))

    w1 = w_norm[0:int(N / 20)]
    w2 = w_norm[int(N / 20):int(N / 20 * 2)]
    w3 = w_norm[int(N / 20 * 2):int(N / 20 * 3)]
    w4 = w_norm[int(N / 20 * 3):int(N / 20 * 4)]
    w5 = w_norm[int(N / 20 * 4):int(N / 20 * 5)]
    w6 = w_norm[int(N / 20 * 5):int(N / 20 * 6)]
    w7 = w_norm[int(N / 20 * 6):int(N / 20 * 7)]
    w8 = w_norm[int(N / 20 * 7):int(N / 20 * 8)]
    w9 = w_norm[int(N / 20 * 8):int(N / 20 * 9)]
    w10 = w_norm[int(N / 20 * 9):int(N / 20 * 10)]
    w11 = w_norm[int(N / 20 * 10):int(N / 20 * 11)]
    w12 = w_norm[int(N / 20 * 11):int(N / 20 * 12)]
    w13 = w_norm[int(N / 20 * 12):int(N / 20 * 13)]
    w14 = w_norm[int(N / 20 * 13):int(N / 20 * 14)]
    w15 = w_norm[int(N / 20 * 14):int(N / 20 * 15)]
    w16 = w_norm[int(N / 20 * 15):int(N / 20 * 16)]
    w17 = w_norm[int(N / 20 * 16):int(N / 20 * 17)]
    w18 = w_norm[int(N / 20 * 17):int(N / 20 * 18)]
    w19 = w_norm[int(N / 20 * 18):int(N / 20 * 19)]
    w20 = w_norm[int(N / 20 * 19):int(N / 20 * 20)]

    # 1
    k1 = np.dot(x, w1.T) + b1
    k1_test = np.dot(x_test, w1.T) + b1_test

    k1_kde = np.zeros(shape=[n, int(N / 20)])
    k1_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde1 = KernelReg(endog=y.reshape(-1, 1), exog=k1[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k1_kde[:, i] = kde1.fit(k1[:, i].reshape(-1, 1))[0]
        k1_kde_test[:, i] = kde1.fit(k1_test[:, i].reshape(-1, 1))[0]

    # 2
    k2 = np.dot(x, w2.T) + b2
    k2_test = np.dot(x_test, w2.T) + b2_test

    k2_kde = np.zeros(shape=[n, int(N / 20)])
    k2_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde2 = KernelReg(endog=y.reshape(-1, 1), exog=k2[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k2_kde[:, i] = kde2.fit(k2[:, i].reshape(-1, 1))[0]
        k2_kde_test[:, i] = kde2.fit(k2_test[:, i].reshape(-1, 1))[0]

    # 3
    k3 = np.dot(x, w3.T) + b3
    k3_test = np.dot(x_test, w3.T) + b3_test

    k3_kde = np.zeros(shape=[n, int(N / 20)])
    k3_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde3 = KernelReg(endog=y.reshape(-1, 1), exog=k3[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k3_kde[:, i] = kde3.fit(k3[:, i].reshape(-1, 1))[0]
        k3_kde_test[:, i] = kde3.fit(k3_test[:, i].reshape(-1, 1))[0]

    # 4
    k4 = np.dot(x, w4.T) + b4
    k4_test = np.dot(x_test, w4.T) + b4_test

    k4_kde = np.zeros(shape=[n, int(N / 20)])
    k4_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde4 = KernelReg(endog=y.reshape(-1, 1), exog=k4[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k4_kde[:, i] = kde4.fit(k4[:, i].reshape(-1, 1))[0]
        k4_kde_test[:, i] = kde4.fit(k4_test[:, i].reshape(-1, 1))[0]

    # 5
    k5 = np.dot(x, w5.T) + b5
    k5_test = np.dot(x_test, w5.T) + b5_test

    k5_kde = np.zeros(shape=[n, int(N / 20)])
    k5_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde5 = KernelReg(endog=y.reshape(-1, 1), exog=k5[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k5_kde[:, i] = kde5.fit(k5[:, i].reshape(-1, 1))[0]
        k5_kde_test[:, i] = kde5.fit(k5_test[:, i].reshape(-1, 1))[0]

    # 6
    k6 = np.dot(x, w6.T) + b6
    k6_test = np.dot(x_test, w6.T) + b6_test

    k6_kde = np.zeros(shape=[n, int(N / 20)])
    k6_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde6 = KernelReg(endog=y.reshape(-1, 1), exog=k6[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k6_kde[:, i] = kde6.fit(k6[:, i].reshape(-1, 1))[0]
        k6_kde_test[:, i] = kde6.fit(k6_test[:, i].reshape(-1, 1))[0]

    # 7
    k7 = np.dot(x, w7.T) + b7
    k7_test = np.dot(x_test, w7.T) + b7_test

    k7_kde = np.zeros(shape=[n, int(N / 20)])
    k7_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde7 = KernelReg(endog=y.reshape(-1, 1), exog=k7[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k7_kde[:, i] = kde7.fit(k7[:, i].reshape(-1, 1))[0]
        k7_kde_test[:, i] = kde7.fit(k7_test[:, i].reshape(-1, 1))[0]

    # 8
    k8 = np.dot(x, w8.T) + b8
    k8_test = np.dot(x_test, w8.T) + b8_test

    k8_kde = np.zeros(shape=[n, int(N / 20)])
    k8_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde8 = KernelReg(endog=y.reshape(-1, 1), exog=k8[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k8_kde[:, i] = kde8.fit(k8[:, i].reshape(-1, 1))[0]
        k8_kde_test[:, i] = kde8.fit(k8_test[:, i].reshape(-1, 1))[0]

    # 9
    k9 = np.dot(x, w9.T) + b9
    k9_test = np.dot(x_test, w9.T) + b9_test

    k9_kde = np.zeros(shape=[n, int(N / 20)])
    k9_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde9 = KernelReg(endog=y.reshape(-1, 1), exog=k9[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k9_kde[:, i] = kde9.fit(k9[:, i].reshape(-1, 1))[0]
        k9_kde_test[:, i] = kde9.fit(k9_test[:, i].reshape(-1, 1))[0]

    # 10
    k10 = np.dot(x, w10.T) + b10
    k10_test = np.dot(x_test, w10.T) + b10_test

    k10_kde = np.zeros(shape=[n, int(N / 20)])
    k10_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde10 = KernelReg(endog=y.reshape(-1, 1), exog=k10[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k10_kde[:, i] = kde10.fit(k10[:, i].reshape(-1, 1))[0]
        k10_kde_test[:, i] = kde10.fit(k10_test[:, i].reshape(-1, 1))[0]

    # 11
    k11 = np.dot(x, w11.T) + b11
    k11_test = np.dot(x_test, w11.T) + b11_test

    k11_kde = np.zeros(shape=[n, int(N / 20)])
    k11_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde11 = KernelReg(endog=y.reshape(-1, 1), exog=k11[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k11_kde[:, i] = kde11.fit(k11[:, i].reshape(-1, 1))[0]
        k11_kde_test[:, i] = kde11.fit(k11_test[:, i].reshape(-1, 1))[0]

    # 12
    k12 = np.dot(x, w12.T) + b12
    k12_test = np.dot(x_test, w12.T) + b12_test

    k12_kde = np.zeros(shape=[n, int(N / 20)])
    k12_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde12 = KernelReg(endog=y.reshape(-1, 1), exog=k12[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k12_kde[:, i] = kde12.fit(k12[:, i].reshape(-1, 1))[0]
        k12_kde_test[:, i] = kde12.fit(k12_test[:, i].reshape(-1, 1))[0]

    # 13
    k13 = np.dot(x, w13.T) + b13
    k13_test = np.dot(x_test, w13.T) + b13_test

    k13_kde = np.zeros(shape=[n, int(N / 20)])
    k13_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde13 = KernelReg(endog=y.reshape(-1, 1), exog=k13[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k13_kde[:, i] = kde13.fit(k13[:, i].reshape(-1, 1))[0]
        k13_kde_test[:, i] = kde13.fit(k13_test[:, i].reshape(-1, 1))[0]

    # 14
    k14 = np.dot(x, w14.T) + b14
    k14_test = np.dot(x_test, w14.T) + b14_test

    k14_kde = np.zeros(shape=[n, int(N / 20)])
    k14_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde14 = KernelReg(endog=y.reshape(-1, 1), exog=k14[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k14_kde[:, i] = kde14.fit(k14[:, i].reshape(-1, 1))[0]
        k14_kde_test[:, i] = kde14.fit(k14_test[:, i].reshape(-1, 1))[0]

    # 15
    k15 = np.dot(x, w15.T) + b15
    k15_test = np.dot(x_test, w15.T) + b15_test

    k15_kde = np.zeros(shape=[n, int(N / 20)])
    k15_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde15 = KernelReg(endog=y.reshape(-1, 1), exog=k15[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k15_kde[:, i] = kde15.fit(k15[:, i].reshape(-1, 1))[0]
        k15_kde_test[:, i] = kde15.fit(k15_test[:, i].reshape(-1, 1))[0]

    # 16
    k16 = np.dot(x, w16.T) + b16
    k16_test = np.dot(x_test, w16.T) + b16_test

    k16_kde = np.zeros(shape=[n, int(N / 20)])
    k16_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde16 = KernelReg(endog=y.reshape(-1, 1), exog=k16[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k16_kde[:, i] = kde16.fit(k16[:, i].reshape(-1, 1))[0]
        k16_kde_test[:, i] = kde16.fit(k16_test[:, i].reshape(-1, 1))[0]

    # 17
    k17 = np.dot(x, w17.T) + b17
    k17_test = np.dot(x_test, w17.T) + b17_test

    k17_kde = np.zeros(shape=[n, int(N / 20)])
    k17_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde17 = KernelReg(endog=y.reshape(-1, 1), exog=k17[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k17_kde[:, i] = kde17.fit(k17[:, i].reshape(-1, 1))[0]
        k17_kde_test[:, i] = kde17.fit(k17_test[:, i].reshape(-1, 1))[0]

    # 18
    k18 = np.dot(x, w18.T) + b18
    k18_test = np.dot(x_test, w18.T) + b18_test

    k18_kde = np.zeros(shape=[n, int(N / 20)])
    k18_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde18 = KernelReg(endog=y.reshape(-1, 1), exog=k18[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k18_kde[:, i] = kde18.fit(k18[:, i].reshape(-1, 1))[0]
        k18_kde_test[:, i] = kde18.fit(k18_test[:, i].reshape(-1, 1))[0]

    # 19
    k19 = np.dot(x, w19.T) + b19
    k19_test = np.dot(x_test, w19.T) + b19_test

    k19_kde = np.zeros(shape=[n, int(N / 20)])
    k19_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde19 = KernelReg(endog=y.reshape(-1, 1), exog=k19[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k19_kde[:, i] = kde19.fit(k19[:, i].reshape(-1, 1))[0]
        k19_kde_test[:, i] = kde19.fit(k19_test[:, i].reshape(-1, 1))[0]

    # 20
    k20 = np.dot(x, w20.T) + b20
    k20_test = np.dot(x_test, w20.T) + b20_test

    k20_kde = np.zeros(shape=[n, int(N / 20)])
    k20_kde_test = np.zeros(shape=[n, int(N / 20)])
    for i in range(int(N / 20)):
        kde20 = KernelReg(endog=y.reshape(-1, 1), exog=k20[:, i].reshape(-1, 1), var_type='c', bw=[0.75])
        k20_kde[:, i] = kde20.fit(k20[:, i].reshape(-1, 1))[0]
        k20_kde_test[:, i] = kde20.fit(k20_test[:, i].reshape(-1, 1))[0]

    # 估计alpha1
    f1 = np.linalg.inv(np.dot(k1_kde.T, k1_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k1_kde.T)
    alpha1 = np.dot(f2, y)

    # 估计alpha2
    f1 = np.linalg.inv(np.dot(k2_kde.T, k2_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k2_kde.T)
    alpha2 = np.dot(f2, y)

    # 估计alpha3
    f1 = np.linalg.inv(np.dot(k3_kde.T, k3_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k3_kde.T)
    alpha3 = np.dot(f2, y)

    # 估计alpha4
    f1 = np.linalg.inv(np.dot(k4_kde.T, k4_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k4_kde.T)
    alpha4 = np.dot(f2, y)

    # 估计alpha5
    f1 = np.linalg.inv(np.dot(k5_kde.T, k5_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k5_kde.T)
    alpha5 = np.dot(f2, y)

    # 估计alpha6
    f1 = np.linalg.inv(np.dot(k6_kde.T, k6_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k6_kde.T)
    alpha6 = np.dot(f2, y)

    # 估计alpha7
    f1 = np.linalg.inv(np.dot(k7_kde.T, k7_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k7_kde.T)
    alpha7 = np.dot(f2, y)

    # 估计alpha8
    f1 = np.linalg.inv(np.dot(k8_kde.T, k8_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k8_kde.T)
    alpha8 = np.dot(f2, y)

    # 估计alpha9
    f1 = np.linalg.inv(np.dot(k9_kde.T, k9_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k9_kde.T)
    alpha9 = np.dot(f2, y)

    # 估计alpha10
    f1 = np.linalg.inv(np.dot(k10_kde.T, k10_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k10_kde.T)
    alpha10 = np.dot(f2, y)

    # 估计alpha11
    f1 = np.linalg.inv(np.dot(k11_kde.T, k11_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k11_kde.T)
    alpha11 = np.dot(f2, y)

    # 估计alpha12
    f1 = np.linalg.inv(np.dot(k12_kde.T, k12_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k12_kde.T)
    alpha12 = np.dot(f2, y)

    # 估计alpha13
    f1 = np.linalg.inv(np.dot(k13_kde.T, k13_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k13_kde.T)
    alpha13 = np.dot(f2, y)

    # 估计alpha14
    f1 = np.linalg.inv(np.dot(k14_kde.T, k14_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k14_kde.T)
    alpha14 = np.dot(f2, y)

    # 估计alpha15
    f1 = np.linalg.inv(np.dot(k15_kde.T, k15_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k15_kde.T)
    alpha15 = np.dot(f2, y)

    # 估计alpha16
    f1 = np.linalg.inv(np.dot(k16_kde.T, k16_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k16_kde.T)
    alpha16 = np.dot(f2, y)

    # 估计alpha17
    f1 = np.linalg.inv(np.dot(k17_kde.T, k17_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k17_kde.T)
    alpha17 = np.dot(f2, y)

    # 估计alpha18
    f1 = np.linalg.inv(np.dot(k18_kde.T, k18_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k18_kde.T)
    alpha18 = np.dot(f2, y)

    # 估计alpha19
    f1 = np.linalg.inv(np.dot(k19_kde.T, k19_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k19_kde.T)
    alpha19 = np.dot(f2, y)

    # 估计alpha20
    f1 = np.linalg.inv(np.dot(k20_kde.T, k20_kde) + int(N / 20) * t / p * np.identity(int(N / 20)))
    f2 = np.dot(f1, k20_kde.T)
    alpha20 = np.dot(f2, y)

    x1 = np.dot(k1_kde, alpha1) + e1
    x2 = np.dot(k2_kde, alpha2) + e1
    x3 = np.dot(k3_kde, alpha3) + e1
    x4 = np.dot(k4_kde, alpha4) + e1
    x5 = np.dot(k5_kde, alpha5) + e1
    x6 = np.dot(k6_kde, alpha6) + e1
    x7 = np.dot(k7_kde, alpha7) + e1
    x8 = np.dot(k8_kde, alpha8) + e1
    x9 = np.dot(k9_kde, alpha9) + e1
    x10 = np.dot(k10_kde, alpha10) + e1
    x11 = np.dot(k11_kde, alpha11) + e1
    x12 = np.dot(k12_kde, alpha12) + e1
    x13 = np.dot(k13_kde, alpha13) + e1
    x14 = np.dot(k14_kde, alpha14) + e1
    x15 = np.dot(k15_kde, alpha15) + e1
    x16 = np.dot(k16_kde, alpha16) + e1
    x17 = np.dot(k17_kde, alpha17) + e1
    x18 = np.dot(k18_kde, alpha18) + e1
    x19 = np.dot(k19_kde, alpha19) + e1
    x20 = np.dot(k20_kde, alpha20) + e1

    x_inside = np.zeros(shape=[n, 20])
    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
    x_inside[:, 10] = x11
    x_inside[:, 11] = x12
    x_inside[:, 12] = x13
    x_inside[:, 13] = x14
    x_inside[:, 14] = x15
    x_inside[:, 15] = x16
    x_inside[:, 16] = x17
    x_inside[:, 17] = x18
    x_inside[:, 18] = x19
    x_inside[:, 19] = x20

    est = ppdire(projection_index=dicomo, pi_arguments={'mode': 'var'}, n_components=6, optimizer='grid',
                 optimizer_options={'ndir': 10000, 'maxiter': 100000}, trimming=0.4)
    est.fit(x_inside, y, regopt='OLS')

    x1_test = np.dot(k1_kde_test, alpha1) + e1_test
    x2_test = np.dot(k2_kde_test, alpha2) + e1_test
    x3_test = np.dot(k3_kde_test, alpha3) + e1_test
    x4_test = np.dot(k4_kde_test, alpha4) + e1_test
    x5_test = np.dot(k5_kde_test, alpha5) + e1_test
    x6_test = np.dot(k6_kde_test, alpha6) + e1_test
    x7_test = np.dot(k7_kde_test, alpha7) + e1_test
    x8_test = np.dot(k8_kde_test, alpha8) + e1_test
    x9_test = np.dot(k9_kde_test, alpha9) + e1_test
    x10_test = np.dot(k10_kde_test, alpha10) + e1_test
    x11_test = np.dot(k11_kde_test, alpha11) + e1_test
    x12_test = np.dot(k12_kde_test, alpha12) + e1_test
    x13_test = np.dot(k13_kde_test, alpha13) + e1_test
    x14_test = np.dot(k14_kde_test, alpha14) + e1_test
    x15_test = np.dot(k15_kde_test, alpha15) + e1_test
    x16_test = np.dot(k16_kde_test, alpha16) + e1_test
    x17_test = np.dot(k17_kde_test, alpha17) + e1_test
    x18_test = np.dot(k18_kde_test, alpha18) + e1_test
    x19_test = np.dot(k19_kde_test, alpha19) + e1_test
    x20_test = np.dot(k20_kde_test, alpha20) + e1_test

    x_inside_test = np.zeros(shape=[n, 20])
    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
    x_inside_test[:, 10] = x11_test
    x_inside_test[:, 11] = x12_test
    x_inside_test[:, 12] = x13_test
    x_inside_test[:, 13] = x14_test
    x_inside_test[:, 14] = x15_test
    x_inside_test[:, 15] = x16_test
    x_inside_test[:, 16] = x17_test
    x_inside_test[:, 17] = x18_test
    x_inside_test[:, 18] = x19_test
    x_inside_test[:, 19] = x20_test

    y_hat = est.predict(x_inside_test) + e_test

    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




