[代码]python实现三维热力图

三维空间部分点有data,如果某位置有值,mask[该位置]=1,对data进行归一化并可视化展示。

 

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D

# 生成数据
data = np.random.rand(12,36, 36)*0.001

# 归一化数据
data_norm = (data - np.min(data)) / (np.max(data) - np.min(data))

# 生成mask
mask = np.random.randint(0, 2, (12, 36, 36))

# 绘制热力图
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
colors = plt.cm.jet(data_norm)
colors[..., -1] = mask  # 设置mask
ax.voxels(mask, facecolors=colors, alpha=0.8)
cbar = plt.colorbar(plt.cm.ScalarMappable(cmap=plt.cm.rainbow))
cbar.set_label('Value')

ax.set_xlabel('X')
ax.set_ylabel('Y')
ax.set_zlabel('Z')
ax.set_title('3D Heatmap')
plt.show()

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值