使用matplotlib在多线图中显示误差线

如何解决使用matplotlib在多线图中显示误差线

我已经使用marplot lib创建了多线图,现在我想在X轴上显示每个参数的最小-最大值。我的代码如下:

import numpy as np
import pandas as pd
from pandas import DataFrame
import matplotlib.pyplot as plt
from matplotlib import pyplot as plt
import seaborn as sns

df = pd.DataFrame({'Time': ['D=0','D=2','D=5','D=X'],'Latency': [74.92,75.32,79.64,100],'Delay': [18.2,80,82,84]
   })

  plt.plot( 'Time','Latency',data=df,marker='s',color='black',markersize=4,linewidth=1,linestyle='--')
  plt.plot( 'Time','Delay',marker='o',linestyle='-')

   plt.legend()
   plt.xlabel("Time")
   plt.ylabel("Average Score (%)")
   plt.ylim(0,100)
   plt.xlim('D=0','D=X')
   plt.savefig('Fig2.png',dpi=300,bbox_inches='tight')
   plt.show()

我要添加的最小-最大间隔为:

Latency: 
D=0 => {73.3,76}
D=2 => {73.3,80}
D=5 => {75,83.3}
D=X => {100}
Delay:
D=0 => {0,50}
D=2 => {50,100}
D=5 => {68,90}
D=X => {75,90}

非常感谢

解决方法

plt.errorbar()绘制带有误差线的线图。它的参数与plt.plot()非常相似。 xlim的宽度需要稍宽一些,以免误差线被绘图边界所割断。

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt

df = pd.DataFrame({'Time': ['D=0','D=2','D=5','D=X'],'Latency': [74.92,75.32,79.64,100],'Delay': [18.2,80,82,84]})
latency_min_max = np.array([(73.3,76),(73.3,80),(75,83.3),(100,100)]).T
latency_err = np.abs(latency_min_max - df['Latency'].to_numpy())
delay_min_max = np.array([(0,50),(50,100),(68,90),90)]).T
delay_err = np.abs(delay_min_max - df['Delay'].to_numpy())

plt.errorbar('Time','Latency',yerr=latency_err,data=df,marker='s',capsize=2,color='black',markersize=4,linewidth=1,linestyle='--')
plt.errorbar('Time','Delay',yerr=delay_err,marker='o',capsize=4,linestyle='-')
plt.legend()
plt.xlabel("Time")
plt.ylabel("Average Score (%)")
plt.ylim(0,100)
plt.xlim(-0.2,3.2)
plt.savefig('Fig2.png',dpi=300,bbox_inches='tight')
plt.show()

enter image description here

另一种方法是使用plt.fill_between创建误差带:

plt.fill_between(df['Time'],latency_min_max[0,:],latency_min_max[1,color='red',alpha=0.2,label='Latency error')
plt.fill_between(df['Time'],delay_min_max[0,delay_min_max[1,color='blue',label='Delay error')

example plot

,

首先将错误值放在列表中:

latency_lower_err = [73.3,73.3,75,100]
latency_upper_err = [76,83.3,100]

然后从这些值中减去数据点,因为matplotlib需要误差极限到相应数据点的距离(以绝对单位为单位):

latency_lower_err = (latency_lower_err - df['Latency']).abs() 
latency_upper_err = (latency_upper_err - df['Latency']).abs()

将结果值放入列表中,其中第一个元素是较低的错误,第二个元素是较高的错误:

yerr = [latency_lower_err,latency_upper_err]

然后将呼叫从plt.plot更改为plt.errorbar,并添加yerr参数:

plt.errorbar('Time',yerr=yerr,capsize=5,... )

其余参数与之前用于plt.plot的参数相同。

结果:

enter image description here

也为Delay修改了相同的逻辑,以获取该变量的错误。

,

您应该使用plt.errorbar而不是plt.plot,然后将数据点与上下限之间的差的绝对值指定为上下误差值(numpy具有方便的矢量化功能,可以做这个)。为避免误差线的上限重叠而造成混淆,我建议使用不同的颜色并更新图例。

从表示的角度看,在轴周围有一些空白可能看起来更好,因此数据看起来不会被切断-您可以相应地设置plt.xlimplt.ylim。首先要感谢@JohanC。

import numpy as np
import pandas as pd
from pandas import DataFrame
import matplotlib.pyplot as plt
from matplotlib import pyplot as plt
import seaborn as sns

df = pd.DataFrame({'Time': ['D=0',84]
   })

latency_limits = np.array([[73.3,[76,100]])
delay_limits = np.array([[0,50,68,75],[50,100,90,90]])

latency_errors = abs(df.Latency.values - latency_limits)
delay_errors = abs(df.Delay.values - delay_limits)

yerr = np.array([[1,1,1],[5,5,5]])

fig = plt.figure()
Latency = plt.errorbar(
  x=df.Time,y=df.Latency,yerr=latency_errors,linestyle='--')

Delay = plt.errorbar(
  x=df.Time,y=df.Delay,yerr=delay_errors,linestyle='-')

plt.legend((Latency,Delay),("Latency","Delay"))
plt.xlabel("Time")
plt.ylabel("Average Score (%)")
## widen both limits to give some whitespace to the plot
plt.ylim(-5,105)
plt.xlim(-0.2,3.2)
# plt.savefig('Fig2.png',bbox_inches='tight')
plt.margins(5,5)
plt.show()

enter image description here

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 <select id="xxx"> SELECT di.id, di.name, di.work_type, di.updated... <where> <if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 <property name="dynamic.classpath" value="tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-