单变量线性回归预测幸福度

单变量线性回归来通过GDP预测国家的幸福度

环境是jupyter notebook,python3.7

导库


import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
from homemade.linear_regression import LinearRegression

导入数据,并输出看一下数据状态,有时还需要看看有没有缺失值异常值,做一下数据清洗

data = pd.read_csv('F:/MLdata/data/world-happiness-report-2017.csv')
data.head(10)

在这里插入图片描述

  • 可以看到数据里面有很多变量,但是我们想用一个变量去做回归预测幸福指数,所以我做了简单的数据分析并从里面选取了GDP为例做了单变量回归预测

特征关于幸福指数的柱状图分布

histohrams = data.hist(grid=False, figsize=(10, 10))

在这里插入图片描述

分割训练集测试集

# 将训练集拆分成8:2
train_data = data.sample(frac=0.8)
test_data = data.drop(train_data.index)

# 选取出我们想预测的向量和输入向量,分别是GDP和幸福指数
input_param_name = 'Economy..GDP.per.Capita.'
output_param_name = 'Happiness.Score'

# 将训练集测试集分别分割成x,y
x_train = train_data[[input_param_name]].values
y_train = train_data[[output_param_name]].values

x_test = test_data[[input_param_name]].values
y_test = test_data[[output_param_name]].values

# 画出训练集
plt.scatter(x_train, y_train, label='Training Dataset')
plt.scatter(x_test, y_test, label='Test Dataset')
plt.xlabel(input_param_name)
plt.ylabel(output_param_name)
plt.title('城市幸福度')
plt.legend()
plt.show()

在这里插入图片描述

  • 测试集和训练集在大致趋势上还是能保持一致的,这样预测才会准确

模型部分

部分参数说明

  • polynomial_degree - 这个参数允许我们添加其他多项式特征来使线性回归的直线弯曲。
  • num_iterations - 这是梯度下降算法寻找成本函数最小值的次数,太小会导致模型没找到最小值。太大导致模型运行时间过久,而且不会提高准确性
  • learning_rate - 这是梯度下降步骤的大小。小的学习步骤会使算法工作更长时间,并且可能需要更多的迭代才能达到成本函数的最小值。大的学习步骤可能会在新的迭代中丢失成本函数值的最小值和增长。
  • regularization_param - 将对抗过度拟合的参数。参数越高,模型就或简单
  • polynomial_degree - 附加多项式特征的次数 (x1^2 * x2, x1^2 * x2^2, ...).
  • sinusoid_degree - 附加特征(sin(x), sin(2*x), ...)正弦函数的程度。允许添加正弦分量来进行曲线预测
num_iterations = 500 
regularization_param = 0  
learning_rate = 0.01  
polynomial_degree = 0  
sinusoid_degree = 0  

linear_regression = LinearRegression(x_train, y_train, polynomial_degree, sinusoid_degree)

(theta, cost_history) = linear_regression.train(
    learning_rate,
    regularization_param,
    num_iterations
)

print('Initial cost: {:.2f}'.format(cost_history[0]))
print('Optimized cost: {:.2f}'.format(cost_history[-1]))

theta_table = pd.DataFrame({'Model Parameters': theta.flatten()})
theta_table.head()

模型训练以及线性回归cost的计算与输出

模型评价部分

模型训练之后一定要对模型进行评价分析
画出线性回归代价梯度下降的过程

plt.plot(range(num_iterations), cost_history)
plt.xlabel('Iterations')
plt.ylabel('Cost')
plt.title('Gradient Descent Progress')
plt.show()

在这里插入图片描述

  • 可以看到模型在100代的时候就接近收敛,500代的时候已经几乎不再发生变化了

画出预测直线与原数据集的对比

predictions_num = 100
x_predictions = np.linspace(x_train.min(), x_train.max(), predictions_num).reshape(predictions_num, 1);
y_predictions = linear_regression.predict(x_predictions)

plt.scatter(x_train, y_train, label='Training Dataset')
plt.scatter(x_test, y_test, label='Test Dataset')
plt.plot(x_predictions, y_predictions, 'r', label='Prediction')
plt.xlabel('Economy..GDP.per.Capita.')
plt.ylabel('Happiness.Score')
plt.title('国家幸福度')
plt.legend()
plt.show()

在这里插入图片描述

最后

输出一下回归预测的结果,并将其和原测试集数据进行比对

test_predictions = linear_regression.predict(x_test)

test_predictions_table = pd.DataFrame({
    'Economy GDP per Capita': x_test.flatten(),
    'Test Happiness Score': y_test.flatten(),
    'Predicted Happiness Score': test_predictions.flatten(),
    'Prediction Diff': (y_test - test_predictions).flatten()
})

test_predictions_table.head(10)

在这里插入图片描述
虽然近似预测了一下,还是有一些差别的,所以我再使用多变量线性回归预测一下结果看看是否会变更好

  • 多变量线性回归预测链接
好的,根据您的要求,我会为您回答这个问题。但是请注意,这个问题是一个非常复杂的数据分析任务,需要大量的数据清洗、数据转换、特征选择、模型训练和评估等步骤。因此,以下回答只是一个简要的概述,您需要深入研究这个问题,才能够完整地完成这个任务。 首先,您需要下载Happiness数据集,并对数据进行初步的探索性数据分析,包括变量的类型、分布、缺失值、异常值等情况的检查。 然后,您需要选择合适的变量进行数据清洗,包括删除不必要的变量、处理缺失值、处理异常值等。您还需要进行特征工程,对变量进行转换和组合,以提高模型的性能。 接下来,您需要将数据集划分为训练集和测试集,并对训练集进行标准化处理,以确保各个变量具有相同的尺和分布,从而提高模型的稳定性和性能。 然后,您可以选择合适的回归模型进行训练,并使用测试集进行评估。常用的回归模型包括线性回归、岭回归、Lasso回归、弹性网络回归等。您还可以使用交叉验证等技术进行模型选择和调优。 最后,您需要评估模型的性能,并输出回归结果,包括各个变量的系数、截距、R方值等指标。您可以使用均方误差、平均绝对误差、均方根误差等指标来评价模型的预测能力和泛化能力。 总之,对Happiness数据进行回归预测是一个复杂的数据分析任务,需要仔细的数据清洗、特征工程、模型选择和评估等步骤。希望我的回答能够帮助您更好地理解这个问题。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值