1

在数据着色器中绘制一组数据时,如果 X 轴具有离散数字和欠采样,则会在可以看到背景的列之间留下间隙。

我一直试图通过尝试设置更大的点大小或使用 dynspread 传递函数来解决这个问题。不走运——很可能是我不知道应用这些的正确方法。

这是重现我的意思的示例代码:

import pandas as pd
import numpy as np

import datashader as ds, colorcet
import holoviews as hv
from holoviews.operation.datashader import datashade
from holoviews import opts

# generate random dataset 0 - 10000
image = np.random.randn(250, 1024, 1024) + 10000
z, x, y = image.shape
print("z, x, y =", z, x, y)
    
# rearrange data to 'z' + 'value' array and convert to dataframe
arr = np.column_stack((np.repeat(np.arange(z),y*x), image.ravel()))
df = pd.DataFrame(arr, columns = ['X', 'Y'])

### Plot using in datashader
map = ds.Canvas(plot_width=800, plot_height=800)
agg = map.points(df, 'X', 'Y' )
pts = ds.tf.shade(agg, cmap=colorcet.fire)
ds.tf.set_background(pts, 'white')

当然,使用 bokeh 绘制相同的集合会显示相同的内容。更糟糕的是,如果你放大:

hv.extension("bokeh")
datashade(hv.Points(df), cmap=colorcet.fire).relabel('Value heatmap').opts(height=700, width=800)
4

1 回答 1

0

在这种情况下,Datashader 按设计工作。当将点渲染到栅格网格中时,它会向您显示可用的实际点数据,直至像素网格可以显示的限制。如果一个像素中有多个数据点,则会汇总它们的计数或值。如果某些像素中没有数据,则不显示数据。

听起来您想要一种与数据着色像素热图不同的绘图。也许:

  • 如果您的数据代表来自底层栅格或四边形网格的常规样本,请使用数据阴影hv.Imagehv.Quadmesh图(或直接调用 canvas.raster 或 canvas.quadmesh),而不是 hv.Points 或 canvas.points 图
  • 如果您的数据表示来自基础连续分布的任意位置的样本,您可以在计算 Delaunay 或其他类型的三角剖分以定义表面后,使用数据阴影hv.TriMesh或 canvas.trimesh 图在点之间填充。
  • 如果您的数据代表来自非连续分布的任意位置的样本,但您仍想用连续函数对其进行近似,则可以使用(非数据阴影)hv.Bivariate图,它计算平滑的核密度估计,有效地“连接正如您所描述的那样,这些点也可以消除局部密度差异。

这些选项都不能完全满足您在这里的要求,但我认为 TriMesh 的行为最符合您的建议,同时在缩小的情况下仍然表现类似。

于 2021-03-03T02:34:04.180 回答