当前位置:
首页 > Python基础教程 >
-
简单Python线性回归实例
本章就介绍一个简单的Python线性回归实例,我们将使用`scikit-learn`库来实现首先,确保你已经安装了`scikit-learn`库。如果没有安装,可以通过pip进行安装:
最后,如果你对vb.net语言还有任何疑问或者需要进一步的帮助,请访问https://www.xin3721.com 本站原创,转载请注明出处:https://www.xin3721.com/Python/python49317.html
pip install scikit-learn
然后,你可以使用以下代码进行线性回归:
import numpy as np
import matplotlib.pyplot as plt
from sklearn.model_selection import train_test_split
from sklearn.linear_model import LinearRegression
from sklearn import metrics
# 创建一个简单的线性数据集
np.random.seed(0)
X = 2 * np.random.rand(100, 1)
y = 4 + 3 * X + np.random.randn(100, 1)
# 划分训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)
# 创建线性回归模型
regressor = LinearRegression()
# 使用训练数据拟合模型
regressor.fit(X_train, y_train)
# 在测试集上进行预测
y_pred = regressor.predict(X_test)
# 评估模型性能
print('Mean Absolute Error:', metrics.mean_absolute_error(y_test, y_pred))
print('Mean Squared Error:', metrics.mean_squared_error(y_test, y_pred))
print('Root Mean Squared Error:', np.sqrt(metrics.mean_squared_error(y_test, y_pred)))
# 输出模型的系数和截距
print('Coefficients: ', regressor.coef_)
print('Intercept: ', regressor.intercept_)
# 可视化结果
plt.scatter(X_test, y_test, color='gray')
plt.plot(X_test, y_pred, color='red', linewidth=2)
plt.show()
这个示例中,我们首先创建了一个简单的线性数据集,并将其划分为训练集和测试集。然后,我们创建了一个`LinearRegression`对象,并使用训练数据对其进行拟合。接着,我们在测试集上进行预测,并计算了一些评估指标来评估模型的性能。最后,我们输出了模型的系数和截距,并使用matplotlib库可视化了结果。import matplotlib.pyplot as plt
from sklearn.model_selection import train_test_split
from sklearn.linear_model import LinearRegression
from sklearn import metrics
# 创建一个简单的线性数据集
np.random.seed(0)
X = 2 * np.random.rand(100, 1)
y = 4 + 3 * X + np.random.randn(100, 1)
# 划分训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)
# 创建线性回归模型
regressor = LinearRegression()
# 使用训练数据拟合模型
regressor.fit(X_train, y_train)
# 在测试集上进行预测
y_pred = regressor.predict(X_test)
# 评估模型性能
print('Mean Absolute Error:', metrics.mean_absolute_error(y_test, y_pred))
print('Mean Squared Error:', metrics.mean_squared_error(y_test, y_pred))
print('Root Mean Squared Error:', np.sqrt(metrics.mean_squared_error(y_test, y_pred)))
# 输出模型的系数和截距
print('Coefficients: ', regressor.coef_)
print('Intercept: ', regressor.intercept_)
# 可视化结果
plt.scatter(X_test, y_test, color='gray')
plt.plot(X_test, y_pred, color='red', linewidth=2)
plt.show()
最后,如果你对vb.net语言还有任何疑问或者需要进一步的帮助,请访问https://www.xin3721.com 本站原创,转载请注明出处:https://www.xin3721.com/Python/python49317.html
栏目列表
最新更新
使用Python发送电子邮件
SpringBoot中Session的使用及说明
springboot后台session的存储与取出方式
Springboot使用ResponseBody汉字返回问号问题
Springboot下载excel文件中文名乱码问题及解
SpringBoot整合weixin-java-pay实现微信小程序支
Java Socket报错打开文件过多的问题
使用nacos实现自定义文本配置的实时刷新
解决springboot文件上传提示临时文件夹不存
Springboot如何使用外部yml启动
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比