使用python实现线性回归及可视化结果图(基于矩阵和不基于矩阵)

一、原理

       在统计学中,线性回归(Linear Regression)是利用称为线性回归方程的最小平方函数对一个或多个自变量和因变量之间关系进行建模的一种回归分析。在实际中,我们不能够找到一条直线完全拟合所用的数据,但是我们能够找到一条直线来近似的拟合数据。这条直线的预测值和真实值之间是有误差的,我们通过使预测值和真实值总误差最小,可以得到一条相对来说最好的直线来拟合所有的数据。根据上面的思路,我们可以先求得总误差,如式1-1所示:

      使Q对a和b的导数为0可得到使总误差最小时,参数a和b的大小,如式1-2和1-3所示:

 二 、不使用矩阵原理及代码

2.1原理

通过联立式1-2和式1-3可得:

 通过式1-5和1-6,我们可以由数据求得参数a和b,进而求得能够拟合数据得最佳直线。如下表1-1为伪代码:

 2.2代码

导入库:

import matplotlib.pyplot as plt
from numpy import *

求平均值

# 求平均值
def ping_jun(x):
    a = 0
    n = len(x)
    for i in x:
        a += i
    return a / n

求参数

# 求参数a
def param_w(x, y):
    x_ = ping_jun(x)
    n = len(x)
    a = 0
    b = 0
    c = 0
    for i in range(n):
        a += y[i] * (x[i] - x_)
        b += x[i] ** 2
        c += x[i]
    return a / (b - c ** 2 / n)

求参数b,并画图

# 不依靠数组进行编程
# 求参数b,并画图
def linear1(x, y):
    a = 0
    n = len(x)
    w = param_w(x, y)
    b = ping_jun(y) - w * ping_jun(x)

    y_hat = w * x + b
    plt.scatter(x, y, c='r')
    plt.plot(x, y_hat, c='b')
    plt.show()

    return w, b

三、使用矩阵原理及代码

3.1 原理

要使损失函数最小,如式1-7最小(即1-12所示):

最小化损失函数,可得到如式1-12,有1-12可得到回归直线的参数,权重和偏置。

编程主要注意要构造出Xb矩阵,然后就是矩阵乘法,可得到theta。

3.2 代码

# 依靠数组进行编程
def linear2(x, y):
    n = len(x)
    #  构造出矩阵x_b
    x_b = np.zeros((n, 2))
    x_b[:, 0] = 1
    for i in range(n):
        x_b[i, 1] = x[i]
    param = np.dot(np.dot(np.linalg.inv(np.dot(x_b.T, x_b)), x_b.T), np.mat(y).T)
    y_hat = x_b * param
# 画图
    plt.scatter(x, y, c='r')
    plt.plot(x, y_hat, 'b')
    plt.show()

    return param

 注意求得的参数a,b都包含在param中

四、可视化结果图

4.1 不基于矩阵可视化结果图

 4.2 不基于矩阵可视化结果图

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 可以使用Python中的matplotlib包进行可视化。以下是一个多元线性回归并在三维空间进行可视化的示例代码: ```python import numpy as np from mpl_toolkits.mplot3d import Axes3D import matplotlib.pyplot as plt # 生成随机数据 np.random.seed(42) x1 = np.random.rand(50) * 10 x2 = np.random.rand(50) * 5 y = 2 * x1 + 3 * x2 + 5 + np.random.randn(50) # 构建设计矩阵 X = np.column_stack((x1, x2, np.ones(len(x1)))) # 计算最小二乘估计 beta_hat = np.linalg.inv(X.T.dot(X)).dot(X.T).dot(y) # 计算模型预测值 y_pred = X.dot(beta_hat) # 三维可视化 fig = plt.figure() ax = fig.add_subplot(111, projection='3d') ax.scatter(x1, x2, y, c='r', marker='o') ax.scatter(x1, x2, y_pred, c='b', marker='^') ax.set_xlabel('X1') ax.set_ylabel('X2') ax.set_zlabel('Y') plt.show() ``` 其中,np.random.rand()函数用于生成指定形状的随机数,np.column_stack()函数用于将数组按列堆叠,np.linalg.inv()函数用于计算矩阵的逆,X.T.dot(X)和X.T.dot(y)用于计算最小二乘估计的系数,X.dot(beta_hat)用于计算模型的预测值。在三维可视化中,ax.scatter()函数用于绘制散点,c参数用于指定颜色,marker参数用于指定标记类型,ax.set_xlabel()、ax.set_ylabel()和ax.set_zlabel()函数用于设置坐标轴标签。 ### 回答2: Python中有多种库可以进行线性回归可视化和多元线性回归的三维可视化。 对于线性回归可视化,可以使用matplotlib库进行绘。首先,我们需要导入需要的库和数据集,使用sklearn库中的datasets模块可以方便地获取一些经典的数据集,如波士顿房价数据集。 ```python import matplotlib.pyplot as plt from sklearn import datasets # 导入数据集 boston = datasets.load_boston() X = boston.data[:, 5:6] # 只选取数据集中的一个特征,这里选择房屋平均房间数 y = boston.target # 绘制散点 plt.scatter(X, y) plt.xlabel("Average number of rooms per dwelling") plt.ylabel("House price") plt.show() ``` 对于多元线性回归的三维可视化,可以使用mpl_toolkits库中的mplot3d模块,并结合matplotlib库进行绘。同样,我们可以使用sklearn库中的datasets模块获取数据集。 ```python import numpy as np import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import Axes3D from sklearn import datasets # 导入数据集 boston = datasets.load_boston() X = boston.data[:, 5:7] # 选取数据集中的两个特征,这里选择房屋平均房间数和房屋年龄 y = boston.target # 绘制三维散点 fig = plt.figure() ax = Axes3D(fig) ax.scatter(X[:, 0], X[:, 1], y) ax.set_xlabel("Average number of rooms per dwelling") ax.set_ylabel("House age") ax.set_zlabel("House price") plt.show() ``` 通过以上的代码,我们可以实现线性回归可视化和多元线性回归的三维可视化。这些可视化可以帮助我们更直观地理解数据集特征和目标变量之间的关系,为模型的分析和进一步改进提供参考。 ### 回答3: Python线性回归可视化是指使用Python编程语言中的相关库(如matplotlib)将线性回归模型的结果进行可视化展示。线性回归是一种用于建立输入特征与输出变量之间线性关系的模型,可用于预测或分析变量之间的关系。 在Python中,可以使用scikit-learn等机器学习库来实现线性回归模型的训练和预测。一旦模型训练完成并得到了相关的系数和截距,就可以使用matplotlib库绘制拟合曲线或直线来可视化模型的结果。 对于简单的线性回归(只包含一个输入特征),可视化可以通过绘制输入特征与输出变量的散点和拟合曲线来展示模型的拟合情况。通过比较散点中的实际数据点与拟合曲线,可以直观地了解模型的拟合程度。 当涉及到多元线性回归(包含多个输入特征)时,可以通过绘制不同输入特征与输出变量之间的散点来观察它们之间的关系。可以使用散点矩阵来同时展示多个输入特征与输出变量的关系。 如果想要对多元线性回归进行三维可视化,可以利用matplotlib的3D绘功能。可以绘制输入特征与输出变量之间的散点,并使用平面或曲面来表示模型的拟合结果。这样可以更清晰地观察多元线性回归的拟合效果,并更好地理解输入特征与输出变量之间的关系。 总之,Python线性回归可视化以及多元线性回归三维可视化提供了一种直观的方式来呈现模型的结果,帮助我们更好地理解和分析线性回归模型

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值