python线性回归_python如何实现线性回归

Python语言实现线性回归的步骤有:导入所要用到的库,读取数据并进行预处理。分析数据以及建立线性回归模型,并进行模型训练检验模型效果

通过使用python语言来实现线性回归是非常方便的,因为它提供了多个现成的库,比如可以使用numpy.linalog.lstsq,pandas.ols以及

scipy.stats.linregress等,在本文中将使用sklearn库的linear_model.LinearRegression,它支持任意维度,非常好用。

5caad8815048f740.jpg

二维直线

例:线性方程y=a∗x+b;y=a∗x+b 表示平面一直线

在下面的例子中,我们将建立线性回归模型,通过给出房屋的面积来预测房屋的价格import pandas as pd

from io import StringIO

from sklearn import linear_model

import matplotlib.pyplot as plt

# 房屋面积与价格历史数据(csv文件)

csv_data = 'square_feet,price\n150,6450\n200,7450\n250,8450\n300,9450\n350,11450\n400,15450\n600,18450\n'

# 读入dataframe

df = pd.read_csv(StringIO(csv_data))

print(df)

# 建立线性回归模型

regr = linear_model.LinearRegression()

# 拟合

regr.fit(df['square_feet'].reshape(-1, 1), df['price']) # 注意此处.reshape(-1, 1),因为X是一维的!

# 不难得到直线的斜率、截距

a, b = regr.coef_, regr.intercept_

# 给出待预测面积

area = 238.5

# 方式1:根据直线方程计算的价格

print(a * area + b)

# 方式2:根据predict方法预测的价格

print(regr.predict(area))

# 画图

# 1.真实的点

plt.scatter(df['square_feet'], df['price'], color='blue')

# 2.拟合的直线

plt.plot(df['square_feet'], regr.predict(df['square_feet'].reshape(-1,1)), color='red', linewidth=4)

plt.show()

效果图:

5caac5e18cb43296.jpg

三维平面

线性方程z=a∗x+b∗y+c;z=a∗x+b∗y+c 表示空间一平面import numpy as np

from sklearn import linear_model

from mpl_toolkits.mplot3d import Axes3D

import matplotlib.pyplot as plt

xx, yy = np.meshgrid(np.linspace(0,10,10), np.linspace(0,100,10))

zz = 1.0 * xx + 3.5 * yy + np.random.randint(0,100,(10,10))

# 构建成特征、值的形式

X, Z = np.column_stack((xx.flatten(),yy.flatten())), zz.flatten()

# 建立线性回归模型

regr = linear_model.LinearRegression()

# 拟合

regr.fit(X, Z)

# 不难得到平面的系数、截距

a, b = regr.coef_, regr.intercept_

# 给出待预测的一个特征

x = np.array([[5.8, 78.3]])

# 方式1:根据线性方程计算待预测的特征x对应的值z(注意:np.sum)

print(np.sum(a * x) + b)

# 方式2:根据predict方法预测的值z

print(regr.predict(x))

# 画图

fig = plt.figure()

ax = fig.gca(projection='3d')

# 1.画出真实的点

ax.scatter(xx, yy, zz)

# 2.画出拟合的平面

ax.plot_wireframe(xx, yy, regr.predict(X).reshape(10,10))

ax.plot_surface(xx, yy, regr.predict(X).reshape(10,10), alpha=0.3)

plt.show()

效果图:

5caac5f67c645124.jpg

总结:以上就是本篇文章的全部内容了,希望对大家有所帮助

以上就是python如何实现线性回归的详细内容,更多请关注php中文网其它相关文章!

article_wechat2021.jpg?1111

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,关于使用 Python 实现线性回归算法,我可以给你一些基本的思路和代码实现。 首先,线性回归是一种用于建立两个变量之间线性关系的统计学方法。在机器学习中,我们通常使用线性回归来进行预测。下面是一个简单的例子。 假设我们有一个数据集,其中包含了房屋的面积和价格。我们想要通过这个数据集来预测房屋的价格。首先,我们需要将数据集导入到 Python 程序中,可以使用 Pandas 库来读取 CSV 文件。 ``` import pandas as pd data = pd.read_csv('data.csv') ``` 接着,我们需要将数据集分成两个部分:训练集和测试集。训练集用于训练模型,测试集用于评估模型的性能。 ``` from sklearn.model_selection import train_test_split train_data, test_data = train_test_split(data, test_size=0.2) ``` 然后,我们需要定义一个模型,用于预测房屋的价格。在这里,我们使用 scikit-learn 库提供的线性回归模型。 ``` from sklearn.linear_model import LinearRegression model = LinearRegression() ``` 接着,我们需要将训练集的特征和标签分开,并用它们来训练模型。 ``` X_train = train_data[['area']] y_train = train_data[['price']] model.fit(X_train, y_train) ``` 最后,我们可以使用测试集来评估模型的性能。 ``` X_test = test_data[['area']] y_test = test_data[['price']] score = model.score(X_test, y_test) ``` 这里的 score 表示模型的拟合程度,越接近 1 表示模型的性能越好。 以上就是使用 Python 实现线性回归算法的基本思路和代码实现。当然,实际应用中还有很多细节需要注意,例如特征工程、数据清洗等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值