from sklearn.ensemble import RandomForestRegressor
import pandas as pd
import numpy as np
import random


i_number =1

while True:

    n = 300
    p = 100
    N = 24000
    t = 0.0001  # 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的取值
    '''
    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]

    # 随机森林
    regressor = RandomForestRegressor(n_estimators=1000, random_state=10)
    regressor.fit(x, y)

    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_hat = regressor.predict(x_test)


    MSE = np.sqrt(np.sum(np.square((y_test - y_hat) / ((y_test) / 2))) / n)
    print(MSE)
    '''
    MSE1 = np.sum(np.square(y_test - y_hat)) / n
    print(MSE1)
    '''
    i_number += 1
    if i_number > 100:
        break