一天一图学Python可视化(1):线性回归图

现代人的时间越来越碎片化,因此我们准备抛弃那种长篇大论的教程,希望大家每天花上几分钟就可以学到一个小窍门或者某种图的绘制方法。只要每天都认真看一遍文章,有时间的时候花几分钟练习一下,一段时间之后,相信大家就都成为Python可视化的高手啦!

接下来,我们目标不大,一天学习并掌握一个实用的小案例就够了!

回归图

今天,我们学习的是使用seaborn绘制回归图。

回归图主要用于表现两个变量之间的线性关系,一般情况下,它在散点图的基础上,会增加一条直线(也有可能是曲线),这条线就是statsmodels中使用最小二乘法预测的两个变量的关系:y = ax + b

回归图有非常丰富的应用场景,比如:

  1. 我们想知道广告费和营收、净利润之间是否成正比;
  2. 我们想知道用户日均活跃时长与用户创建天数之间的关系是什么;
  3. 我们想知道用户的生命周期价值(LTV)与用户获取成本之间的关系;
  4. 我们想知道学生的日均学习时长与成绩之间的关系;
  5. ……

看来我们有更多的理由来学习回归图了,毕竟它是一个应用超广泛的图形!

我们先看一下代码和效果:

import seaborn as sns
sns.set(style="ticks")

# Load the example dataset for Anscombe's quartet
df = sns.load_dataset("anscombe")

# Show the results of a linear regression within each dataset
sns.lmplot(x="x", y="y", col="dataset", hue="dataset", data=df,
           col_wrap=2, ci=None, palette="muted", height=4,
           scatter_kws={"s": 50, "alpha": 1});

那么接下来我们就详细讨论下绘图过程的细节。

  1. x / y / data:前两个参数用于指定列名,第三个参数用于指定数据。在seaborn中,我们会经常使用pandas DataFrame格式的数据,seaborn对于pandas有极为良好的支持。
  2. col / row:用于指定图中行和列所对应的变量,比如我们用dataset变量传递给col,那么在我们的图中,由于dataset变量有四个取值,因此每个取值对应的子数据集会被绘制到单独的一列,一共四列(这里看到的不是四列,我们下边会讲到为什么)。
  3. hue:用于指定色彩变量,在我们这张图中,hue变量也是dataset,所以这四组数据会在被分到四列的同时,也被分别绘制成四种不同的颜色。
  4. col_wrap:这个参数就是明明我们的dataset变量有四种取值,但图中看起来还是两列的原因。这个参数指定了再达到多少列以后,会进行折行。我们在这里指定了2,因此我们将原本的4列转换成了2行*两列。
  5. ci:confidence interval,置信区间。这个过程是使用自助采样法,对样本多次重复抽样,得到样本均值的分布,并将其95%的置信区间绘制出来。
  6. palette:调色板,这个用于控制hue变量所展示的颜色。在分类(离散)变量中,我们一般会指定一组不同色调的颜色(针对连续变量,我们经常会使用同一个颜色的不同亮度、饱和度来表现)。
  7. height:注意,这里指的是每个子图的高度,如果还想控制宽度的话,那就要再指定aspect参数来控制宽高比。
  8. scatter_kws:字典形式,用于控制散点的更多细节。这一组参数会隐式地传入更底层的plt.scatter函数中,因此这里可以输入任何plt.scatter支持的参数。在这里,我们用sizealpha分别控制了散点的大小和透明度。

好了,今天我们学习了使用seaborn.lmplot()来绘制回归图,它用于表现两个变量之间的线性关系。

你学会了吗?

  • 11
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答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线性回归可视化以及多元线性回归三维可视化提供了一种直观的方式来呈现模型的结果,帮助我们更好地理解和分析线性回归模型。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

老Q量化投研

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

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

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

打赏作者

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

抵扣说明:

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

余额充值