-1

我有一个希望在 python 中执行的简单空间分析。但是,我还没有完全弄清楚如何让 python 做我想做的事情。

我有一个包含 3 个关键列的 CSV 文件:命中或未命中、X 位置、Y 位置。每行是发生命中或未命中的实例,以及该命中或未命中的 x 和 y 坐标是什么(例如,“hit, 10, 58”)。

为了给你一个更好的画面,想象有成千上万个这样的点,它们都落在一个 100 x 100 的网格内(其中 0,0 = 左下角,100,100 = 右上角)。命中和未命中分布在网格中,在某些位置,命中和未命中重叠,有些位置只有命中或只有未命中,有些位置两者都没有。

我的最终目标是生成一个热图,以可视化整个网格的相对准确度(命中/(命中+未命中))。

我能想到的最好的主意是在同一个散点图上绘制命中和未命中,降低点的不透明度,让点的密度决定色调,然后代表相对准确度...... .但这看起来很糟糕....

我的下一个想法是制作垃圾箱。因此,网格将被分成 50 个 2x2 箱,我将让我的程序对每个箱执行精度分析(命中/(命中+未命中))。但是,唉,我不知道该怎么做。

有没有人有任何想法?

谢谢!

4

1 回答 1

0

您可以使用 scipy.stats 中的核密度估计器。我认为这应该做你想要的。它将显示数据倾向于聚集的位置。KDE 将建立二维概率密度的估计。然后,您在 100x100 网格上评估该 KDE 估计器。您可以使用计数器图绘制结果。

您的代码可能如下所示:

import numpy as np
from scip.stats import kde
import matplotlib.pyplot as plt

ndiv = 101
xr = np.linspace(0.0, 100.0 ndiv)
yr = np.linspace(0.0, 100.0 ndiv)
x,y = np.meshgrid(xr, yr)

# points here would be your 'hits' or 'miss' subset
estimator = kde.gaussian_kde(points)

# this turns the grid into a list of points that will
# be used by the KDE for evaluation
grid_coords = np.append(x.reshape(-1, 1), y.reshape(-1, 1), axis=1)
z = estimator(grid_coords.T)
z = z.reshape(ndiv, ndiv)

# you can specify contour levels
lvls = np.array([.05, .5, .75, 1.0]) * z.max()  
cfset = plt.contourf(x, y, z, cmap='jet', levels=lvls)
于 2016-06-17T16:20:35.193 回答