python matplotlib用面积填充实现lmplot的代码示例

 更新时间:2023年07月18日 10:23:15   作者:微小冷  
这篇文章主要介绍了python matplotlib如何用面积填充实现lmplot,文章通过代码示例介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴可以参考阅读

示例

在绘图时经常遇到类似区域填充的问题,比如对于y = sin ⁡ x y=\sin xy=sinx函数,想填充其与X轴所围成的区间,那么就可以使用fill_between函数。

import numpy as np
import matplotlib.pyplot as plt
x = np.arange(0, 2, 0.01)
y = np.sin(2 * np.pi * x)
plt.plot(x, y, color='black')
plt.fill_between(x, y)
plt.grid()
plt.show()

效果如下

参数

fill_between参数如下,其中x, y1, y2都是数组,表示希望覆盖的范围,具体逻辑是,对于某点xi​,将对应的[y1i​,y2i​]范围内涂上颜色。在上面的示例中,只设置了xy1,而y2默认为0,所以绘制的就是y1到0范围内的值。

fill_between(x, y1, y2=0, where=None, interpolate=False, step=None, *,**kwargs)

其他参数含义如下

  • where 可以指定参与绘图的范围,一般是一个布尔型数组
  • interpolate 为True时采用插值
  • step 可选’pre’, ‘post’, ‘mid’,表示步进方案
plt.plot(x, y, color='black')
plt.fill_between(x, y, where=y > 0, facecolor='green', alpha=.5)
plt.fill_between(x, y, where=y < 0, facecolor='red', alpha=.5)
plt.show()

结果如图

回归图

有了这种填充工具,就可以做出类似seaborn中的lmplot,这种图形在数据拟合时十分有用,可以在除了拟合线之外,再将数据的分布范围标出。

首先创造一组带有误差的y = 2x + 1y=2x+1y=2x+1数据,并通过最小二乘法得到其拟合参数。

x = np.arange(0, 2, 0.02)
err = np.random.rand(100)/2
y = 2*x + 1 + err
# 构造并调用最小二乘法
A = np.array([x, np.ones_like(x)]).T
kb, res, _, _ = np.linalg.lstsq(A, y)

下面就对拟合结果进行绘制,首先根据拟合出来的k , bk, bk,b,来得到趋势线Y = kx + bY=kx+bY=kx+b,然后调用绘图函数,对原始数据、趋势线、分布区间进行绘制

Y = kb[0]*x + kb[1]
dx = (x-x.mean())**2
E = x.std() * np.sqrt(1/len(x) + dx / np.sum(dx))
plt.scatter(x, y, marker='.')   # 原始数据
plt.plot(x, Y)                  # 趋势线
plt.fill_between(x, Y - E, Y + E, alpha=0.5)
plt.show()

效果如下

到此这篇关于python matplotlib用面积填充实现lmplot的代码示例的文章就介绍到这了,更多相关python matplotlib实现lmplot内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Pytorch中accuracy和loss的计算知识点总结

    Pytorch中accuracy和loss的计算知识点总结

    在本片文章里小编给大家整理的是关于Pytorch中accuracy和loss的计算相关知识点内容,有需要的朋友们可以学习下。
    2019-09-09
  • Python用 KNN 进行验证码识别的实现方法

    Python用 KNN 进行验证码识别的实现方法

    这篇文章主要介绍了Python用 KNN 进行验证码识别的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-02-02
  • Python中win32包的安装及常见用途介绍

    Python中win32包的安装及常见用途介绍

    在Windows环境下,Python Win32模块通常随Python安装包一起安装,这篇文章主要介绍了Python中win32包的安装及常见用途的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-06-06
  • Pytorch数据类型Tensor张量操作的实现

    Pytorch数据类型Tensor张量操作的实现

    本文主要介绍了Pytorch数据类型Tensor张量操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • 详解Python中正则匹配TAB及空格的小技巧

    详解Python中正则匹配TAB及空格的小技巧

    这篇文章主要介绍了详解Python中正则匹配TAB及空格的小技巧,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • 用python实现名片管理系统

    用python实现名片管理系统

    这篇文章主要为大家详细介绍了用python实现名片管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-06-06
  • django如何实现视图重定向

    django如何实现视图重定向

    这篇文章主要介绍了django如何实现视图重定向,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-07-07
  • pandas.DataFrame.agg()方法的使用

    pandas.DataFrame.agg()方法的使用

    agg函数是一个非常强大的工具,用于对数据进行分组聚合操作,它可以沿指定轴(行或列)应用一个或多个聚合函数,常用于统计汇总分析,感兴趣的可以了解一下
    2025-05-05
  • Python中re模块的元字符使用小结

    Python中re模块的元字符使用小结

    元字符是正则表达式中具有特殊意义的专用字符,本文主要介绍了Python中re模块的元字符使用小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • 使用Python批量生成PPT版荣誉证书的示例代码

    使用Python批量生成PPT版荣誉证书的示例代码

    使用Python处理PPT文件通常需要使用第三方库来简化对PPT文件的读取、写入和修改操作,本文将给大家介绍一个小案例,使用Python批量生成PPT版荣誉证书,感兴趣的同学跟着小编一起来看看吧
    2023-08-08

最新评论