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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用Python自定义创建的Log日志模块

    使用Python自定义创建的Log日志模块

    这篇文章主要介绍了使用Python自定义创建的Log日志模块,日志文件是用于记录系统操作事件的文件集合,可分为事件日志和消息日志。具有处理历史数据、诊断问题的追踪以及理解系统的活动等重要作用,需要的朋友可以参考下
    2023-07-07
  • python如何随机生成高强度密码

    python如何随机生成高强度密码

    这篇文章主要为大家详细介绍了python随机生成高强度密码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • Numpy 中的矩阵求逆实例

    Numpy 中的矩阵求逆实例

    今天小编就为大家分享一篇Numpy 中的矩阵求逆实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-08-08
  • python去掉字符串中重复字符的方法

    python去掉字符串中重复字符的方法

    这篇文章主要介绍了python去掉字符串中重复字符的方法,需要的朋友可以参考下
    2014-02-02
  • 一键搞定python连接mysql驱动有关问题(windows版本)

    一键搞定python连接mysql驱动有关问题(windows版本)

    这篇文章主要介绍了对于mysql驱动问题折腾了一下午,现共享出解决方案,需要的朋友可以参考下
    2016-04-04
  • Python开发.exe小工具的详细步骤

    Python开发.exe小工具的详细步骤

    这篇文章主要介绍了Python开发.exe小工具的详细步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • 使用Python编写一个简单的tic-tac-toe游戏的教程

    使用Python编写一个简单的tic-tac-toe游戏的教程

    这篇文章主要介绍了使用Python编写一个简单的tic-tac-toe游戏的教程,有利于Python初学者进行上手实践,需要的朋友可以参考下
    2015-04-04
  • Python3中多线程编程的队列运作示例

    Python3中多线程编程的队列运作示例

    这篇文章主要介绍了Python3中多线程编程的队列运作示例,文中用一个简单的例子展示了Python下尝试多线程时队列的进站出站是如何运作的,需要的朋友可以参考下
    2015-04-04
  • python3.5绘制随机漫步图

    python3.5绘制随机漫步图

    这篇文章主要为大家详细介绍了python3.5绘制随机漫步图,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • Python简单定义与使用二叉树示例

    Python简单定义与使用二叉树示例

    这篇文章主要介绍了Python简单定义与使用二叉树,结合实例形式分析了Python定义二叉树及节点插入相关操作技巧,需要的朋友可以参考下
    2018-05-05

最新评论