将yerr/xerr绘制为阴影区域而不是误差条

Aus*_*son 112 python matplotlib

在matplotlib中,如何将错误绘制为阴影区域而不是错误条?

例如:

在此输入图像描述

而不是

在此输入图像描述

小智 125

忽略示例图中各点之间的平滑插值(需要进行一些手动插值,或者只是具有更高的数据分辨率),您可以使用pyplot.fill_between():

from matplotlib import pyplot as pl
import numpy as np

x = np.linspace(0, 30, 30)
y = np.sin(x/6*np.pi)
error = np.random.normal(0.1, 0.02, size=y.shape)
y += np.random.normal(0, 0.1, size=y.shape)

pl.plot(x, y, 'k-')
pl.fill_between(x, y-error, y+error)
pl.show()
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

另请参见matplotlib示例.

  • @EL_DON你的意思是你想要一个带有黑线+蓝色带的图例,并且文本将类似于“数据+ 1西格玛误差区域”? (2认同)

Bor*_*lik 115

这基本上与Evert提供的答案相同,但扩展到炫耀一些很酷的选择fill_between

在此输入图像描述

from matplotlib import pyplot as pl
import numpy as np

pl.clf()
pl.hold(1)

x = np.linspace(0, 30, 100)
y = np.sin(x) * 0.5
pl.plot(x, y, '-k')


x = np.linspace(0, 30, 30)
y = np.sin(x/6*np.pi)
error = np.random.normal(0.1, 0.02, size=y.shape) +.1
y += np.random.normal(0, 0.1, size=y.shape)

pl.plot(x, y, 'k', color='#CC4F1B')
pl.fill_between(x, y-error, y+error,
    alpha=0.5, edgecolor='#CC4F1B', facecolor='#FF9848')

y = np.cos(x/6*np.pi)    
error = np.random.rand(len(y)) * 0.5
y += np.random.normal(0, 0.1, size=y.shape)
pl.plot(x, y, 'k', color='#1B2ACC')
pl.fill_between(x, y-error, y+error,
    alpha=0.2, edgecolor='#1B2ACC', facecolor='#089FFF',
    linewidth=4, linestyle='dashdot', antialiased=True)



y = np.cos(x/6*np.pi)  + np.sin(x/3*np.pi)  
error = np.random.rand(len(y)) * 0.5
y += np.random.normal(0, 0.1, size=y.shape)
pl.plot(x, y, 'k', color='#3F7F4C')
pl.fill_between(x, y-error, y+error,
    alpha=1, edgecolor='#3F7F4C', facecolor='#7EFF99',
    linewidth=0)



pl.show()
Run Code Online (Sandbox Code Playgroud)