为了账号安全,请及时绑定邮箱和手机立即绑定

Python pcolormesh,每个箱子都有单独的 alpha 值

Python pcolormesh,每个箱子都有单独的 alpha 值

慕森卡 2023-03-08 10:03:26
可以说我有以下数据集:import numpy as npimport matplotlib.pyplot as pltx_bins = np.arange(10)y_bins = np.arange(10)z = np.random.random((9,9))我可以轻松地绘制这些数据plt.pcolormesh(x_bins, y_bins, z, cmap = 'viridis)但是,假设我现在为每个点添加一些 alpha 值:a = np.random.random((9,9))如何更改 pcolormesh 图中每个框的 alpha 值以匹配数组“a”中的相应值?
查看完整描述

1 回答

?
弑天下

TA贡献1818条经验 获得超8个赞

由 创建的网格pcolormesh对于整个网格只能有一个 alpha。要为每个单元格设置单独的 alpha,需要将单元格一个一个地创建为矩形。


下面的代码pcolormesh在左侧显示了没有 alpha 的情况,在右侧显示了具有 alpha 的矩形网格。请注意,在矩形接触的地方,半透明会导致一些不均匀的重叠。这可以通过不绘制单元格边缘 ( edgecolor='none') 或使用更长的黑线来分隔单元格来缓解。


下面的代码更改了 x 维度,以便更容易验证x并且y不会混淆。relim并且autoscale是必需的,因为对于 matplotlib 的默认行为,x 和 y 限制不会通过添加补丁来更改。


import numpy as np

import matplotlib.pyplot as plt

from matplotlib.patches import Rectangle, Patch


x_bins = np.arange(12)

y_bins = np.arange(10)

z = np.random.random((9, 11))

a = np.random.random((9, 11))


cmap = plt.get_cmap('inferno')

norm = plt.Normalize(z.min(), z.max())


fig, (ax1, ax2) = plt.subplots(ncols=2)

ax1.pcolormesh(x_bins, y_bins, z, cmap=cmap, norm=norm)

for i in range(len(x_bins) - 1):

    for j in range(len(y_bins) - 1):

        rect = Rectangle((x_bins[i], y_bins[j]), x_bins[i + 1] - x_bins[i], y_bins[j + 1] - y_bins[j],

                         facecolor=cmap(norm(z[j, i])), alpha=a[j, i], edgecolor='none')

        ax2.add_patch(rect)

# ax2.vlines(x_bins, y_bins.min(), y_bins.max(), edgecolor='black')

# ax2.hlines(y_bins, x_bins.min(), x_bins.max(), edgecolor='black')

ax2.relim()

ax2.autoscale(enable=True, tight=True)


plt.show()

//img1.sycdn.imooc.com//6407ed250001746812200625.jpg

查看完整回答
反对 回复 2023-03-08
  • 1 回答
  • 0 关注
  • 155 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号