使用cv2.applyColorMap画热力图

# cam1 是[c, h, w]的矩阵

ss = np.min(cam1, axis=1)
bb = np.max(cam1, axis=1)
for i in range(len(cam1)):
    for j in range(len(cam1[i])):
        # 不能乘以255,因为一旦x255,则热力中心部分的值就是255了,也就是白色,导致热力图中间被镂空了
        cam1[i][j] = (cam1[i][j]-ss[i]) * 200.0 / bb[i]  

cam1 = cam1.reshape((c, h, w))
cam_img = np.uint8(cam1)

img = []
for i in range(size_upsample[0]):
    im = []
    for j in range(size_upsample[1]):
        im.append([255, 255, 255])
    img.append(im)
img = np.asarray(img)

for i in range(len(cam_img)):
    heatmap = cv2.applyColorMap(cv2.resize(cam_img[i], (size_upsample[1], size_upsample[0])), cv2.COLORMAP_JET)  # dsize = [w, h]
    heatmap = heatmap * 0.3 + img * 0.3
    cv2.imwrite("context_img/"+str(i)+".jpg", heatmap)

 * 200的结果

*255 的结果【中间被镂空

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值