gpt4 book ai didi

python - 颜色条限制不遵守 plt.contourf 中的设置 vmin/vmax。如何更明确地设置颜色条限制?

转载 作者:行者123 更新时间:2023-11-28 20:37:24 25 4
gpt4 key购买 nike

在使用 contourf 绘图时尝试调整数据范围时得到一个奇怪的结果

import matplotlib
import numpy as np
import matplotlib.cm as cm
import matplotlib.mlab as mlab
import matplotlib.pyplot as plt

delta = 0.025
x = np.arange(-3.0, 3.0, delta)
y = np.arange(-2.0, 2.0, delta)
X, Y = np.meshgrid(x, y)
Z1 = mlab.bivariate_normal(X, Y, 1.0, 1.0, 0.0, 0.0)
Z2 = mlab.bivariate_normal(X, Y, 1.5, 0.5, 1, 1)
# difference of Gaussians
Z = 10.0 * (Z2 - Z1)

plt.figure()
CS = plt.contourf(X, Y, Z, vmin = 0, vmax = 3)
plt.title('Simplest default with labels')
plt.colorbar()

plt.show()

我的结果是: enter image description here

这就像颜色与我设置的 vmin/vmax 相匹配,但颜色栏上显示的数字范围仍然是没有设置 vmin/vmax 时的数字范围。

在这种情况下,我希望最终结果有一个范围从 0 到 3 的颜色条。

最佳答案

首先,标记为答案的响应是错误的(请参阅我上面的评论),但帮助我提出了另外两个解决方案。

正如 JulianBauer 在下面的评论中指出的那样,OP 使用的函数 mlab.bivariate_normal 不再可用。为了提供生成可与其他答案进行比较的输出的功能代码,我调用了以下函数,其中定义了从 matplotlib repository 复制的 bivariate_normal :

def myfunction():

def bivariate_normal(X, Y, sigmax=1.0, sigmay=1.0, mux=0.0, muy=0.0, sigmaxy=0.0):
"""copied from here: https://github.com/matplotlib/matplotlib/blob/81e8154dbba54ac1607b21b22984cabf7a6598fa/lib/matplotlib/mlab.py#L1866"""
Xmu = X-mux
Ymu = Y-muy
rho = sigmaxy/(sigmax*sigmay)
z = Xmu**2/sigmax**2 + Ymu**2/sigmay**2 - 2*rho*Xmu*Ymu/(sigmax*sigmay)
denom = 2*np.pi*sigmax*sigmay*np.sqrt(1-rho**2)
return np.exp(-z/(2*(1-rho**2))) / denom

delta = 0.025
x = np.arange(-3.0, 3.0, delta)
y = np.arange(-2.0, 2.0, delta)
X, Y = np.meshgrid(x, y)
Z1 = bivariate_normal(X, Y, 1.0, 1.0, 0.0, 0.0)
Z2 = bivariate_normal(X, Y, 1.5, 0.5, 1, 1)
Z = 10.0 * (Z2 - Z1)
return X,Y,Z

<强>1。一个简单直接的解决方案

在提供自定义级别时使用扩展命令:

import numpy as np
import matplotlib
import matplotlib.cm as cm
import matplotlib.pyplot as plt

X,Y,Z = myfunction()

plt.figure()
plt.title('Simplest default with labels')
levels = np.linspace(0.0, 3.0, 7)
CS = plt.contourf(X, Y, Z, levels=levels, cmap=cm.coolwarm, extend='min')

colorbar = plt.colorbar(CS)

plt.show()

output method 1

<强>2。更复杂的解决方案

已在上面的答案中提供,但它需要根据特定情况进行调整,并且很容易以颜色条结束,其级别与实际图中的级别不同。我发现这很危险,所以我试图将它包装在一个可以在任何上下文中安全调用的函数中:

def clippedcolorbar(CS, **kwargs):
from matplotlib.cm import ScalarMappable
from numpy import arange, floor, ceil
fig = CS.ax.get_figure()
vmin = CS.get_clim()[0]
vmax = CS.get_clim()[1]
m = ScalarMappable(cmap=CS.get_cmap())
m.set_array(CS.get_array())
m.set_clim(CS.get_clim())
step = CS.levels[1] - CS.levels[0]
cliplower = CS.zmin<vmin
clipupper = CS.zmax>vmax
noextend = 'extend' in kwargs.keys() and kwargs['extend']=='neither'
# set the colorbar boundaries
boundaries = arange((floor(vmin/step)-1+1*(cliplower and noextend))*step, (ceil(vmax/step)+1-1*(clipupper and noextend))*step, step)
kwargs['boundaries'] = boundaries
# if the z-values are outside the colorbar range, add extend marker(s)
# This behavior can be disabled by providing extend='neither' to the function call
if not('extend' in kwargs.keys()) or kwargs['extend'] in ['min','max']:
extend_min = cliplower or ( 'extend' in kwargs.keys() and kwargs['extend']=='min' )
extend_max = clipupper or ( 'extend' in kwargs.keys() and kwargs['extend']=='max' )
if extend_min and extend_max:
kwargs['extend'] = 'both'
elif extend_min:
kwargs['extend'] = 'min'
elif extend_max:
kwargs['extend'] = 'max'
return fig.colorbar(m, **kwargs)

函数中的主要命令对应于 kilojoules 在他/她的回答中提出的内容,但需要更多行来通过从 contourf 对象中提取所有信息来避免所有显式和潜在错误的分配。

用法:

OP 要求从 0 到 3 的级别。最深的蓝色表示低于 0 的值,因此我发现扩展标记很有用。

import numpy as np
import matplotlib
import matplotlib.cm as cm
import matplotlib.pyplot as plt

X,Y,Z = myfunction()

plt.figure()
plt.title('Simplest default with labels')
CS = plt.contourf(X, Y, Z, levels=6, vmin=0.0, vmax=3.0, cmap=cm.coolwarm)

colorbar = clippedcolorbar(CS)

plt.show()

output

可以通过调用 clippedcolorbar(CS, extend='neither') 而不是 clippedcolorbar(CS) 来禁用扩展标记。

output with extend='neither'

关于python - 颜色条限制不遵守 plt.contourf 中的设置 vmin/vmax。如何更明确地设置颜色条限制?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43150687/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com