python金融分析小知识(33)——机器学习之多元线性回归算法的使用

Hello 大家好,我是一名新来的金融领域打工人,日常分享一些python知识,都是自己在学习生活中遇到的一些问题,分享给大家,希望对大家有一定的帮助!

今天要给大家介绍一种多元线性回归的机器学习算法,适用于多种特征用于预测标签的情况,话不多说直接上案例。

1.读取数据

今天要使用到的这份数据有四个特征一个标签,我们希望通过机器学习多元线性回归来进行特征的预测。

import pandas as pd
import numpy as np
from sklearn.linear_model import LinearRegression #线性回归模型
import matplotlib.pyplot as plt

读取数据:

623466f7383f4c07b542be5600ec6809.png

简单地进行一些数据探索:

11c259d3e72348ba96410e4c1caf9714.png

f2bbcf4f0c2745a6902145a0bb2c2c16.png

2.分割特征与标签 

X = df.iloc[:,:-1] #feature
X.head()

y = df[['PE']] #target
y.head()

a1e561dbf2544d9fa4f4db0df47e5be0.png

3519579cec6142c08abd4540b577cc77.png

3. 拆分训练集和测试集

from sklearn.model_selection import train_test_split
X_train,X_test,y_train,y_test = train_test_split(X, y, random_state=1)
X_train #训练集

d56b92a5d74e43a2975a1fe8efc7358c.png 56a90a408b2d46acbdb727f3e38a0a7d.png

4.线性回归模型建模 

line = LinearRegression()
line.fit(X_train,y_train)

 通过打印截距与系数我们已经可以得到线性回归的方程:e9b6daae5a88435ba2d1da4e8b4d2951.png

 线性回归的表达式如下:7964c639eb104d89aa31f0758ed2240e.png

5.模型评价 

我们来查看预测值:

ad0c61fd23c14cce904cd96e855d9854.png

查看误差,代码以及结果如下:

from sklearn import metrics
print("MSE: ", metrics.mean_squared_error(y_test,y_pred))
print("RMSE: ", np.sqrt(metrics.mean_squared_error(y_test,y_pred)))
print('R^2: ', metrics.r2_score(y_test,y_pred))
MSE:  20.83719154722035
RMSE:  4.564777272465805
R^2:  0.9297935741511321

6.整理结果 

data = pd.concat([pd.DataFrame(y),pd.DataFrame(y_predicted)],axis=1)
data.columns = ['Measured','Predicted']
data

109986f71c344603b164f72c6bce717b.png 绘图:

import plotly_express as px
fig = px.scatter(data,x='Measured',y='Predicted',trendline='ols',trendline_color_override='red')
fig.show()

这张图横坐标是真实值,纵坐标是预测值:5e42cc53ca014413a0106aa2cb67cdc2.png我们还可以进一步查看图片的内容:

4d5d975e85fa4178865997fafcd90f95.png

这张图中甚至写出来拟合线的方程,以及R^2的大小: 

5b73bbc0478e4f9e84c6b507a1f61089.png 

总的来说,通过多元线性回归模型得到的预测值和实际值可以很好的拟合上!

好啦今天就分享到这里! 

 

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

君子以自强不息python

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值