matplot中的轮廓图显示不正确的线型

问题描述 投票:1回答:1

我正在使用轮廓图在matplotlib中绘制一个具有正值和负值的2D矩阵。应该为正值显示实线,为负值显示虚线:

loc = matplotlib.ticker.MaxNLocator(20)
Z = psi
lvls = loc.tick_values(Z.min(), Z.max())
fig, ax = plt.subplots(figsize=(7,7))
cp = plt.contour(X, Y, Z, 20, colors='k', linestyles=where(lvls >= 0, "-", "--"))
plt.xlabel('X')
plt.ylabel('Y')
plt.clabel(cp, inline=True, fontsize=10)
plt.gca().set_aspect('equal', adjustable='box')
plt.title('Stream function - Re = ' + str(Re) + ', t = {:.2f}'.format((t)*dt))
plt.savefig('SF' + '_Re' + str(Re) + '_N' + str(nx) + '_o' + str(order) + '_SF' + '.png')
plt.close()

但是,这是此代码的绘制方式:Contour plot

如您所见,应该在虚线处显示实线,而在实线中显示虚线。有什么想法吗?

编辑:下面的代码可以正常工作:

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

nx = 100
ny = 100

# Generate 2D mesh
x = 2*np.pi*np.arange(0,nx,1)/(nx)
#x = linspace(0,Lx,nx,endpoint=True)
y = 2*np.pi*np.arange(0,ny,1)/(ny)
#y = linspace(0,Ly,ny,endpoint=True)
X, Y = np.meshgrid(x, y,indexing='ij')

Z = -np.sin(X/2)*np.cos(Y**1.5)

loc = matplotlib.ticker.MaxNLocator(20)
lvls = loc.tick_values(Z.min(), Z.max())
fig, ax = plt.subplots(figsize=(7,7))
cp = plt.contour(X,Y,Z,20, colors='k', linestyles=np.where(lvls >= 0, "-", "--"))
plt.clabel(cp, inline=True, fontsize=10)
plt.gca().set_aspect('equal', adjustable='box')
plt.show()

输出:

Example

python matplotlib contour
1个回答
1
投票

您应该切换线条样式的顺序。当前,您的条件将-(实线)分配给轮廓lvls >= 0,否则它将分配--(虚线)。这就是where参数的工作方式。

以伪形式,where(condition, A, B)表示condition是否为True分配A否则分配B


您的当前代码(不需要):

linestyles=where(lvls >= 0, "-", "--")

右样式(所需样式):

linestyles=where(lvls >= 0, "--", "-")
© www.soinside.com 2019 - 2024. All rights reserved.