分割模型部件——将gt用边界在原始图像上展示,将pred用掩膜在原始图像上展示

目的

在论文可视化结果时,简介明了的展示我们自己模型的分割结果与gt的区别是十分重要的,因此这里记录一下自己的可视化方式。
踩坑:
因为大多数操作都是基于cv2进行的,因此你需要保持输入图像的h,w,c的顺序,RGB的顺序等。
建议:
没办法贴全自己的所有代码,因此以下代码建议各位借助Chat-GTP学透了再使用,不可盲目使用。

代码

示例代码:

'''
Descripttion:  
Author: Philo
Date: 2024-05-16 09:34:23
LastEditors: Philo
LastEditTime: 2024-05-16 09:34:23
'''import cv2
import numpy as np# 分割网络的模块,因此label和pred的通道数都是1,img通道数是3
# 传入的img维度为(3, h, w), label(1, h, w), pred(1, h, w)
def Fusion(img, label, pred):# pixel_mean = [123.675, 116.28, 103.53] # 根据数据预处理进行选择性使用# pixel_std = [58.395, 57.12, 57.375]# print("数据检查", img.shape, label.shape, pred.shape, np.unique(label), np.unique(pred))if len(np.unique(label)) > 2: # 因为findContours函数接受的必须是二值图,因此将label进行二值化label_np = np.asarray(label).copy()label_np[label_np <= 0.5] = 0label_np[label_np > 0.5] = 1label = label_nplabel = label.astype(np.uint8)[0] # 整数型 (h, w)格式pred = pred[0] # (h, w)格式kernel = cv2.getStructuringElement(cv2.MORPH_RECT, (3, 3))  # 创建了一个结构元素(kernel),结构元素是用于形态学操作(如膨胀、腐蚀等)的一个模板label = cv2.erode(label, kernel) # 该行代码对图像进行腐蚀操作。腐蚀是一种形态学操作,用于减小图像中的白色区域(前景),通常用于去除图像中的噪声或者分离物体contours, _ = cv2.findContours(label, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) # 找到边界img = np.transpose(img, (1, 2, 0)).copy() # 因为都是cv2中操作,需要保证图像的格式是(h,w,c)# img = (img * pixel_std) + pixel_meanimg = img.astype(np.uint8).copy()# print(type(img), img.shape)img = cv2.cvtColor(img, cv2.COLOR_RGB2BGR) # 转化成BGR格式for cnt in contours:cv2.drawContours(img, [cnt], 0, (0, 0, 255), 1)  # 画边界框if len(np.unique(pred)) > 2:pred_np = np.asarray(pred).copy()pred_np[pred_np <= 0.5] = 0pred_np[pred_np > 0] = 1pred = pred_npoverlay = np.zeros_like(img)  # 生成一个和原始img一样大小的numpyoverlay[pred != 0] = [0, 255, 255]  # BGR颜色通道设置为淡黄色# 将淡黄色的色块叠加在原始图像上img = cv2.addWeighted(img, 1, overlay, 0.3, 0)return img

结果:
在这里插入图片描述
把框忽略了就是这个代码的输出哦

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/706555.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java入门——异常

异常的背景 初识异常 我们曾经的代码中已经接触了一些 "异常" 了. 例如: //除以 0 System.out.println(10 / 0); // 执行结果 Exception in thread "main" java.lang.ArithmeticException: / by zero //数组下标越界 int[] arr {1, 2, 3}; System.out.…

ROS从入门到精通4-3:制作Docker镜像文件Dockerfile

目录 0 专栏介绍1 为什么需要Dockerfile&#xff1f;2 Dockerfile书写原则3 Dockerfile常用指令3.1 FROM3.2 MAINTAINER3.3 RUN3.4 ADD3.5 COPY3.6 CMD3.7 ENV3.8 EXPOSE3.9 WORKDIR3.10 ARG 4 Dockerfile构建ROS工程实例 0 专栏介绍 本专栏旨在通过对ROS的系统学习&#xff0…

2024 Google I/O Android 相关内容汇总

2024 Google I/O Android 相关内容汇总 本次 Google I/O 的核心虽然是 AI &#xff0c;但是 Android 也是作为主要议题出现&#xff0c; Android 部分可以简单分为产品和开发相关内容&#xff0c;接下来主要介绍这两部分的相关更新。 重点开始开发相关&#xff0c;内容不少 产…

Leetcode—1953. 你可以工作的最大周数【中等】

2024每日刷题&#xff08;138&#xff09; Leetcode—1953. 你可以工作的最大周数 算法思想 实现代码 class Solution { public:long long numberOfWeeks(vector<int>& milestones) {long long ans 0;int mx ranges::max(milestones);long long sum accumulate(…

如何进行事务处理

1、问题背景 在数据库存储系统中&#xff0c;事务处理是一种保证多个数据库操作作为单个逻辑单元执行的技术。事务处理可以确保数据的一致性、完整性和隔离性。 在使用 Google Cloud Datastore 时&#xff0c;可以使用 datastore.transaction() 函数来进行事务处理。datastor…

在Linux中设置除root之外的所有用户都禁止删除文件目录(sudoers文件配置)

sudoers文件配置 在Linux系统中&#xff0c;/etc/sudoers配置文件主要用来配置用户是否可以使用sudo权限以及是否需要输入密码。 一般不会直接修改/etc/sudoers配置文件&#xff0c;而是在/etc/sudoers.d目录下创建一个单独的配置文件test。 第一步&#xff0c;配置用户jerr…

SpringCloudAlibaba5.2sentinel配置流控

概述 简介 监控应用流量的QPS或并发线程数&#xff0c;当达到指定的阈值时对流量进行控制 规则 1.资源名&#xff1a;请求路径 2.针对来源&#xff1a;配置该规则微服务&#xff0c;一般填写调用方的微服务名称&#xff0c;多个用","分割 3.阈值类型&#xff1a;二…

Linux开机报错:XFS:Internal error XFS_WANT_CORRUPTED_RETURN at line…

Linux开机报错:XFS:Internal error XFS_WANT_CORRUPTED_RETURN at line… 无法开机处理办法 报错如下图&#xff1a; 1、grub 菜单 按e 在rhgb quiet 后面添加rd.break 加完按CtrlX 执行 2、umount /sysroot 因为我dm-0是系统盘&#xff0c;所以卸载/sysroot 3、修复XFS x…

使用numpy或pytorch校验两个张量是否相等

文章目录 1、numpy2、pytorch 做算法过程中&#xff0c;如果涉及到模型落地&#xff0c;那必然会将原始的深度学习的框架训练好的模型转换成目标硬件模型的格式&#xff0c;如onnx,tensorrt,openvino,tflite;那么就有对比不同格式模型输出的一致性&#xff0c;从而判断模型转换…

【面试干货】 两个有序数组的合并排序

【面试干货】 两个有序数组的合并排序 1、实现思想2、代码实现 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 1、实现思想 使用两个指针分别指向两个数组的起始位置&#xff0c;然后逐个比较两个指针所指向的元素&#xff0c;将较小的元素…

视觉叙事的艺术:StoryDiffusion打造一致性图像/视频故事创作

论文&#xff1a;https://arxiv.org/pdf/2405.01434 主页&#xff1a;StoryDiffusion: Consistent Self-Attention for Long-Range Image and Video Generation 一、摘要总结 本文提出了一种名为StoryDiffusion的新方法&#xff0c;用于生成一系列内容一致的图像和视频&#…

[vue] nvm use时报错 exit status 1:一堆乱码,exit status 5

报错exit status 5&#xff1a;&#xfffd;ܾ&#xfffd;&#xfffd;&#xfffd;&#xfffd;ʡ&#xfffd; 原因&#xff1a;因为当前命令提示符窗口是user权限&#xff0c; 解决&#xff1a;cmd使用管理员方式打开就可以 参考&#xff1a; vm use时报错 exit status 1…