亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

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()

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

查看完整回答
反對 回復 2023-03-08
  • 1 回答
  • 0 關注
  • 135 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號