gpt4 book ai didi

python-2.7 - 使用 numpy.histogram2d 和 matplotlib 绘制二维直方图时遇到问题

转载 作者:行者123 更新时间:2023-12-01 14:01:42 24 4
gpt4 key购买 nike

我有一个庞大的数据集,我需要将我的图分割成一个网格并计算每个网格方块内的点数。我正在遵循 here 概述的方法:

下面是我的代码的精简版本:

import numpy as np
import matplotlib.pyplot as plt

x = [ 1.83259571, 1.76278254, 1.38753676, 1.6406095, 1.34390352, 1.23045712, 1.85877565, 1.26536371, 0.97738438]

y = [ 0.04363323, 0.05235988, 0.09599311, 0.10471976, 0.1134464, 0.13962634, 0.17453293, 0.20943951, 0.23561945]

gridx = np.linspace(min(x),max(x),11)
gridy = np.linspace(min(y),max(y),11)

grid, _, _ = np.histogram2d(x, y, bins=[gridx, gridy])

plt.figure()
plt.plot(x, y, 'ro')
plt.grid(True)

plt.figure()
plt.pcolormesh(gridx, gridy, grid)
plt.plot(x, y, 'ro')
plt.colorbar()

plt.show()

出现问题的地方是网格将图的元素识别为点出现的位置,但其中一些元素中没有点;类似地,在某些实际数据点出现的地方,网格不会将它们识别为实际上不存在。

什么可能导致这个问题?另外,很抱歉没有附上情节,我是新用户,我的声誉不够高。

更新
这是一个生成 100 个随机点并尝试在二维直方图中绘制它们的代码:
import numpy as np
import matplotlib.pyplot as plt

x = np.random.rand(100)

y = np.random.rand(100)

gridx = np.linspace(0,1,11)
gridy = np.linspace(0,1,11)

grid, __, __ = np.histogram2d(x, y, bins=[gridx, gridy])

plt.figure()
plt.plot(x, y, 'ro')
plt.grid(True)

plt.figure()
plt.pcolormesh(gridx, gridy, grid)
plt.plot(x, y, 'ro')
plt.colorbar()

plt.show()

然而,当我运行它时,我遇到了与以前相同的问题:点的位置和对应于点位置密度的颜色不一致。当有人为自己运行此代码时会发生这种情况吗?

第二次更新

冒着打败死马的风险,这里有一个参数图的代码:
import numpy as np
import matplotlib.pyplot as plt

t = np.linspace(0,1,100)
x = np.sin(t)
y = np.cos(t)

gridx = np.linspace(0,1,11)
gridy = np.linspace(0,1,11)

#grid, __, __ = np.histogram2d(x, y, bins=[gridx, gridy])
grid, __, __ = np.histogram2d(x, y)

plt.figure()
plt.plot(x, y, 'ro')
plt.grid(True)

plt.figure()
plt.pcolormesh(gridx, gridy, grid)
plt.plot(x, y, 'ro')
plt.colorbar()

plt.show()

这让我觉得这都是某种奇怪的缩放问题。不过还是完全迷失了……

最佳答案

我能够通过使用带插值的 imshow 而不是 pcolormesh 来使您的示例工作。请参阅下面的示例代码。

我认为问题可能在于 pcolormesh 与 plot 具有不同的起源约定。
pcolormesh的结果看起来像左上右下被翻转了。

imshow 的结果如下所示:

imshow result

示例代码:

import numpy as np
import matplotlib.pyplot as plt

def doPlot():

x = [ 1.83259571, 1.76278254, 1.38753676, 1.6406095, 1.34390352, 1.23045712, 1.85877565, 1.26536371, 0.97738438]

y = [ 0.04363323, 0.05235988, 0.09599311, 0.10471976, 0.1134464, 0.13962634, 0.17453293, 0.20943951, 0.23561945]

gridx = np.linspace(min(x),max(x),11)
gridy = np.linspace(min(y),max(y),11)

H, xedges, yedges = np.histogram2d(x, y, bins=[gridx, gridy])

plt.figure()
plt.plot(x, y, 'ro')
plt.grid(True)

#wrong origin convention for pcolormesh?
#plt.figure()
#plt.pcolormesh(gridx, gridy, H)
#plt.plot(x, y, 'ro')
#plt.colorbar()


plt.figure()
myextent =[xedges[0],xedges[-1],yedges[0],yedges[-1]]
plt.imshow(H.T,origin='low',extent=myextent,interpolation='nearest',aspect='auto')
plt.plot(x,y,'ro')
plt.colorbar()

plt.show()

if __name__=="__main__":
doPlot()

关于python-2.7 - 使用 numpy.histogram2d 和 matplotlib 绘制二维直方图时遇到问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24001361/

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