繁体   English   中英

对齐两个组合图-Matplotlib

[英]Aligning two combined plots - Matplotlib

我目前在一个情节中工作,在该情节中我将显示合并数据。 我用以下代码绘制它们:

plt.figure()

# Data 1
data = plt.cm.binary(data1)
data[..., 3] = 1.0 * (data1 > 0.0)
fig = plt.imshow(data, interpolation='nearest', cmap='binary', vmin=0, vmax=1, extent=(-4, 4, -4, 4))

# Plotting just the nonzero values of data2
x = numpy.linspace(-4, 4, 11)
y = numpy.linspace(-4, 4, 11)
data2_x = numpy.nonzero(data2)[0]
data2_y = numpy.nonzero(data2)[1]

pts = plt.scatter(x[data2_x], y[data2_y], marker='s', c=data2[data2_x, data2_y])

这给了我这个情节:

在此处输入图片说明

从图像中可以看出,我的背景和前景方块未对齐。

两者的尺寸相同(20 x 20)。 我希望有一种方法,如果可能的话,将中心与中心对齐,或将角与角对齐,但要进行某种对齐。

在某些网格单元中,我似乎具有右下角对齐,在其他网格中左下角对齐,而在其他根本没有对齐,这会降低可视化效果。

任何帮助,将不胜感激。

谢谢。

作为tcaswell说,你的问题可能是最容易通过定义来解决extent关键字imshow

如果您提供extent keyword ,则最外面的像素边缘将位于该范围内。 例如:

import matplotlib.pyplot as plt
import numpy as np

fig = plt.figure()
ax = fig.add_subplot(111)
ax.imshow(np.random.random((8, 10)), extent=(2, 6, -1, 1), interpolation='nearest', aspect='auto')

在此处输入图片说明

现在很容易计算每个像素的中心。 在X方向:

  • 像素间距离是(6-2)/ 10 = 0.4像素
  • 最左侧像素的中心距左侧边缘半个像素,即2 + .4 / 2 = 2.2

同样,Y中心为-.875 + n * 0.25。

因此,通过调整extent您可以将像素中心放置在任何需要的位置。


一个具有20x20数据的示例:

import matplotlib.pyplot as plt
import numpy

# create the data to be shown with "scatter"
yvec, xvec = np.meshgrid(np.linspace(-4.75, 4.75, 20), np.linspace(-4.75, 4.75, 20))
sc_data = random.random((20,20))

# create the data to be shown with "imshow" (20 pixels)
im_data = random.random((20,20))

fig = plt.figure()
ax = fig.add_subplot(111)
ax.imshow(im_data, extent=[-5,5,-5,5], interpolation='nearest', cmap=plt.cm.gray)
ax.scatter(xvec, yvec, 100*sc_data)

在此处输入图片说明

请注意,此处的scatter (如果您查看xvec ,所有像素都相隔0.5个单位)和imshow (图像从-5拉伸到+5且有20个像素,像素相隔.5个单位)。

这是没有对齐问题的代码。

import matplotlib.pyplot as plt
import numpy

data1 = numpy.random.rand(10, 10)
data2 = numpy.random.rand(10, 10)
data2[data2 < 0.4] = 0.0

plt.figure()

# Plotting data1
fig = plt.imshow(data1, interpolation='nearest', cmap='binary', vmin=0.0, vmax=1.0)

# Plotting data2
data2_x = numpy.nonzero(data2)[0]
data2_y = numpy.nonzero(data2)[1]
pts = plt.scatter(data2_x, data2_y, marker='s', c=data2[data2_x, data2_y])

plt.show()

给出了完美对齐的组合图:

对齐地块

因此,在代码中使用其他选项可能是组合图未对齐的原因。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM