当前位置: 首页 > news >正文

基于pytorch实现的DenseUnet医学图像分割(腹部多脏器)

1、前言

本章将介绍将densenet的主干网络引入unet中

官方实现的代码:kits19-challenge/network at master · nitsaick/kits19-challenge (github.com)

本章实现的项目目录如下:

主要代码有train、evaluate、predict脚本

 

 

2、代码介绍

数据预处理脚本

数据的预处理放在dataset脚本中,这里参考sam模型的预处理。利用numpy和cv进行归一化、翻转、图像增强等等,而非torch中的transform

主要如下:

红色框的部分为windowing窗口化拉伸对比度,因为大多数医学数据都是CT格式,对比度很差,如果原数据对比度还行的话,可以注释掉

数据增强采用了水平和垂直翻转:

train 训练脚本

参数如下,如果image和mask的后缀格式不同,需要更改这里

使用的优化器是Adam、损失是多类别的交叉熵、学习率衰减是cos余弦退火算法

evaluate 评估模型

默认采用训练过程中生成的最好的权重

代码会在测试集上进行评估,计算mean iou、recall、precision、全局pixel准确度等等

3、项目使用

测试用的数据集为腹部多脏器的五分割:

项目下载:基于DenseUnet对腹部多脏器5类的分割实战【包含代码+数据集+训练结果】资源-CSDN文库

3.1 数据集摆放

数据集摆放如下:

--data--train---images   训练集的图像
--data--train---masks    训练集的图像标签
--data--val---images     验证集的图像
--data--val---masks      验证集的图像标签
--data--test---images    测试集的图像(如果有的话)
--data--test---masks     测试集的图像标签(如果有的话)

训练集用于训练网络、验证集用于验证模型调整超参数、测试集用于评估模型精度

3.2 训练

摆放好数据,直接运行train脚本即可,代码会计算mask的像素值,然后自动设定denseunet的输出类别个数

训练完成,会将所有结果保存在runs目录下:

预处理可视化:

因为原图是MRI格式的,所有windowing方法增强效果不明显

训练日志:

依次为epoch、train loss、train iou、val loss、val iou

学习率衰减:

3.3 评估模型

脚本是evaluate代码,这里填写测试集路径即可

代码会计算测试集的精度,保存在txt文本中(runs目录)

列表的值,是不同类别的recall、iou等

 

3.4 推理代码

predict 脚本

效果如下,会生成gt图以及image+gt的掩膜图

输入图像:

gt图:

掩膜图:

http://www.lryc.cn/news/369506.html

相关文章:

  • 富格林:正规策划实现安全做单
  • 02. 异常捕捉和处理
  • Oracle和mysql中插入时间字段
  • 注册小程序
  • 【YOLOv8改进[CONV]】使用MSBlock二次创新C2f模块实现轻量化 + 含全部代码和详细修改方式 + 手撕结构图 + 轻量化 + 涨点
  • three.js使用环境贴图或者加载hdr图
  • GPT-4o多模态大模型的架构设计
  • Facebook:社交世界的引领者
  • qt 加载字体 c++
  • Linux ldd和ldconfig
  • Python 学习flask创建项目
  • .NET集成DeveloperSharp实现图片的裁剪、缩放、与加水印
  • 阿里发布最强开源大模型通义千问Qwen2,国产最好用的LLM
  • 探索风电机组:关键软件工具全解析
  • HOW - CSS 常见效果实现
  • EI/CPCI/Scopus会议论文是啥?
  • 【递归、搜索与回溯】穷举vs暴搜vs深搜vs回溯vs剪枝
  • celery-redbeat方案(动态定时任务、异步任务)
  • js解析成语法树以及还原
  • 基于python可伸缩JSON格式列表实现
  • h5相机功能
  • IDEA | 安装通义灵码插件,开启智能编码旅程
  • 技术人员如何克服在使用行列视(RCV)过程中遇到的挑战?
  • 手把手教你安装 Vivado2019.2(附安装包)
  • Sql-labs的第一关
  • 10_1 Linunx Web服务管理
  • 苹果WWDC 2024:十三大亮点公布,一切都有关AI|TodayAI
  • Nginx访问日志
  • Java使用Hutool工具类轻松生成验证码
  • leetcode 40. 组合总和 II