当前位置:   article > 正文

使用cv2.applyColorMap画热力图_cv2绘制热力图

cv2绘制热力图
  1. # cam1 是[c, h, w]的矩阵
  2. ss = np.min(cam1, axis=1)
  3. bb = np.max(cam1, axis=1)
  4. for i in range(len(cam1)):
  5. for j in range(len(cam1[i])):
  6. # 不能乘以255,因为一旦x255,则热力中心部分的值就是255了,也就是白色,导致热力图中间被镂空了
  7. cam1[i][j] = (cam1[i][j]-ss[i]) * 200.0 / bb[i]
  8. cam1 = cam1.reshape((c, h, w))
  9. cam_img = np.uint8(cam1)
  10. img = []
  11. for i in range(size_upsample[0]):
  12. im = []
  13. for j in range(size_upsample[1]):
  14. im.append([255, 255, 255])
  15. img.append(im)
  16. img = np.asarray(img)
  17. for i in range(len(cam_img)):
  18. heatmap = cv2.applyColorMap(cv2.resize(cam_img[i], (size_upsample[1], size_upsample[0])), cv2.COLORMAP_JET) # dsize = [w, h]
  19. heatmap = heatmap * 0.3 + img * 0.3
  20. cv2.imwrite("context_img/"+str(i)+".jpg", heatmap)

 * 200的结果

*255 的结果【中间被镂空

本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/w/小惠珠哦/article/detail/760797
推荐阅读
相关标签
  

闽ICP备14008679号