sklearn之线性模型

在skearn中,可以使用sklearn.linear_model来创建线性模型

然后用fit函数去训练

然后用predict去预测

还可以用score函数去预测同时计算预测的准确度

代码

import numpy as np
import matplotlib.pyplot as plt
from sklearn import datasets
from sklearn import linear_model

#获取数据 X,Y,并画图

X, Y = datasets.make_regression(n_samples=100, n_features=1, n_targets=1, noise=1)
plt.scatter(X, Y)
plt.show()


#区分训练集和测试集
X_train = X[:-20]
X_test  = X[-20:]

Y_train = Y[:-20]
Y_test  = Y[-20:]

#选择模型
lm = linear_model.LinearRegression()


#训练,获得模型
lm.fit(X_train, Y_train)
#查看模型的参数,也就是系数
print('模型参数:', lm.coef_)


#训练集和测试集的预测值
train_pred = lm.predict(X_train)
test_pred  = lm.predict(X_test)

#输出预测的误差
print("训练集的预测均方误差:%.2f" % np.mean((train_pred-Y_train)**2))

print("测试集的预测均方误差:%.2f" % np.mean((test_pred-Y_test)**2))

print("预测score:%.2f" % lm.score(X_test, Y_test))

实验结果

这里写图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
sklearn中的线性回归模型是通过最小二乘法来进行参数估计的,它可以用来建立一个线性关系模型预测因变量与自变量之间的关系。在sklearn中,可以使用LinearRegression类来构建线性回归模型。\[1\] 在构建线性回归模型之前,需要导入必要的模块和库,例如从sklearn.linear_model中导入LinearRegression类,从sklearn.model_selection中导入train_test_split和cross_val_score函数,以及从sklearn.datasets中导入fetch_california_housing函数。然后,可以使用这些函数和数据集来进行模型的训练和评估。\[3\] 在使用线性回归模型之前,还需要注意一些问题。首先,线性回归模型要求因变量的分布服从正态分布,因此可能需要对因变量进行正态化处理,例如取对数或使用QuantileTransformer或PowerTransformer进行处理。其次,线性回归模型的性能往往取决于数据本身,而不是调参能力,因此对数据的质量有着很高的要求。\[2\] 总结来说,sklearn中的线性回归模型可以用来建立一个线性关系模型预测因变量与自变量之间的关系。在使用之前,需要导入必要的模块和库,并注意因变量的分布和数据的质量。 #### 引用[.reference_title] - *1* [sklearn线性回归](https://blog.csdn.net/luguojiu/article/details/103252707)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [使用sklearn库学习线性回归(一)](https://blog.csdn.net/qq_38163244/article/details/109442545)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [sklearn 线性回归](https://blog.csdn.net/kingsure001/article/details/113841439)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值