dynamic-Echonet左心室语义分割——学习记录

news2024/11/18 2:23:48

1简单介绍

1.1 论文简介

论文地址Video-based AI for beat-to-beat assessment of cardiac function
数据集地址:here获取好像还挺麻烦的。需要在网站上填写并申请数据集,斯坦福那边会发邮件并拉入一个box组,就可以访问公开的超声心动数据集了。

对心功能的准确评估对于心血管疾病的诊断、心脏毒性的筛查以及对危重症患者的临床管理的决策至关重要。然而,人类对心功能的评估集中在有限的心脏周期抽样上,尽管经过多年的训练,但观察者间存在相当大的差异性。在这里,为了克服这一挑战,我们提出了一种基于视频的深度学习算法——EchoNet-Dynamic——它在分割左心室、估计射血分数和评估心肌病等关键任务上超过了人类专家的表现。

通过超声心动图视频的训练,我们的模型以骰子相似度为0.92精确分割左心室,预测射血分数的平均绝对误差为4.1%,并可靠地分类射血分数降低的心力衰竭(曲线下面积为0.97)。在来自另一个医疗保健系统的外部数据集中,EchoNet动力学预测射血分数的平均绝对误差为6.0%,并将射血分数降低的心力衰竭的曲线下面积分类为0.96。

通过重复的人类测量进行的前瞻性评估认为,该模型的方差与人类专家相当或更小。通过利用多个心脏周期的信息,我们的模型可以快速识别射血分数的细微变化,比人类评估更具有可重复性,并为实时精确诊断心血管疾病奠定了基础。作为促进进一步创新的资源,我们还公开了一个包含10,030个带注释的超声心动图视频的大型数据集。

注意:这个代码有三个任务,我们先学习左心室的分割。
先看一下分割与评估的结果:
在这里插入图片描述

1.2 代码目录

1、代码克隆:

git clone https://github.com/echonet/dynamic.git
cd dynamic

(如果不清楚可以去学并且安装一下git,也可以直接到github下载下来打开)
我就是下载之后打开的
2、目录介绍
在这里插入图片描述

a4c-vedio-dir: 用于训练、验证、测试的数据集。下面有三个文件:vedios——处理过的avi视频文件;FileList.csv——训练、验证需要的视频信息;VolumeTracings.csv——视频的一些信息要素。
doc: 说明文档。
echonet: 核心代码,将被打包成库运行。
output: 输出路径。因为运行结果已经保存在这里,我们运行的时候可以先将这个目录移除。
scripts: 一些工具文件。

2 代码运行

1、首先需要运行setup.py文件,安装必要的包以及将echonet打包成库。

python setup.py install

2、左心室分割(Frame-by-frame Semantic Segmentation of the Left Ventricle)

echonet segmentation --save_video

它会创建一个保存目录是output/segmentation/deeplabv3_resnet50_random/

我之前在这里,运行遇到了问题,可以尝试修改echonet里的文件,再运行setup.py文件。
比如我这里报错:numpy没有属性int,我将echonet/utils/segmentation.py下的np.int全部修改成了np.int_。
可能是我的numpy版本是1.23

因为运行结果已经保存在output这里,我们运行的时候可以先将这个目录移除。要不然可能看不到进度条。

出现下面这样的进度条,说明运行成功
在这里插入图片描述运行完之后,会生成如下文件:
在这里插入图片描述

log.csv:培训和验证损失
checkpoint.pt:检查点
best.pt:具有最低验证损失的模型的权重检查点
size.csv:每帧左心室的估计大小和心跳开始的指示符
vedios:包含具有分段覆盖的视频的目录

3数据集介绍

默认情况下,EchoNet Dynamic假设数据副本保存在此目录中名为a4c-video-dir/的文件夹中。可以通过创建名为echonet.cfg的配置文件来更改此路径(示例配置文件为example.cfg)。
在这里插入图片描述

3.1论文中的介绍

作者分享了一组10030张超声心动图图像,用于训练EchoNet Dynamic。使用OpenCV和pydicom对这些图像进行了预处理,包括从DICOM格式到AVI格式的视频的识别和转换。更多信息请访问https://echonet.github.io/dynamic/.

超声心动图视频:标准的完整静息超声心动图研究包括一系列视频和图像,从不同角度、位置和图像采集技术可视化心脏。该数据集包含 10,030 个顶端 4 腔超声心动图视频,这些视频来自 2016 年至 2018 年期间接受成像的个人,作为斯坦福大学医院常规临床护理的一部分。

使用自动化预处理工作流程来删除识别信息并消除意外的人类标签。随后的每个视频都被裁剪和屏蔽,以删除文本、心电图和呼吸计信息以及扫描扇区以外的其他信息。生成的方形图像为 600 × 600 或 768 × 768 像素,具体取决于超声机器,并使用 OpenCV 通过三次插值向下采样为标准化的 112 × 112 像素视频。

3.2 详情介绍

数据集的文件目录如下:
在这里插入图片描述
a4c-vedio-dir: 用于训练、验证、测试的数据集。
下面有三个文件:
vedios——处理过的avi视频文件;
FileList.csv——训练、验证需要的视频信息;
VolumeTracings.csv——视频的一些信息要素。

我们先不管视频是如何处理成这种形式的,先了解一下用于训练、验证的数据格式。
首先vedios是文件夹,下面存放的是avi视频文件。
FileList.csv
在这里插入图片描述文件名 | 射血分数 | 收缩末容量 | 舒张末容量 | 帧长 | 帧宽| 帧率 | 帧编号 | 分割成训练集、验证集还是测试集

应该是每个视频提取出的一帧,目前认为是人工提取的一帧。
其中包括10030行,训练集7465个,验证集1288,测试集1277。其中大约75% 个用于训练,12.5% 个用于验证,12.5% 个用于测试。

VolumeTracings.csv
在这里插入图片描述文件名 | X1坐标 | Y1坐标 |X2坐标 | Y2坐标 | 帧?

4模型介绍

对于每位患者,EchoNet-Dynamic使用标准的心尖四腔视图超声心动图视频作为输入。该模型首先使用具有残差连接的时空卷积预测每个心动周期的射血分数,并使用专家人类追踪的弱监督生成左心室的帧级语义分割。这些输出组合在一起,以创建射血分数的逐搏预测,并预测射血分数降低时是否存在心力衰竭。AUC,曲线下面积。
在这里插入图片描述
EchoNet-Dynamic有三个关键组件。首先,我们构建了一个具有空洞卷积的CNN模型,用于左心室的帧级语义分割。atrous卷积技术使模型能够捕获更大的模式,并且之前已被证明在非医学成像数据集上表现良好。估计射血分数的标准人体临床工作流程需要在收缩末期和舒张末期手动分割左心室。我们用弱监督方法概括这些标签,使用atrous卷积,以在整个心动周期中生成帧级语义分割,与原始视频中的帧以1:1的配对。自动分割用于识别心室收缩,并提供模拟临床工作流程的临床医生可解释的中介。

其次,我们训练了一个CNN模型,该模型具有残差连接和跨帧的时空卷积,以预测射出分数。与以前的用于医学图像机器学习的CNN架构相比,我们的方法在我们的网络卷积中集成了空间和时间信息。时空卷积(包含二维空间信息以及三维空间信息)以前已用于非医学视频分类任务29,30.然而,鉴于标记的医疗视频相对稀缺,这种方法以前没有用于医疗数据。我们还执行了模型架构搜索,以确定最佳的基础架构(扩展数据图)。

最后,我们对射血分数进行视频级预测,以估计心脏功能的逐搏估计。鉴于心脏功能的变化可能是由各种心脏条件下负荷条件和心率的变化引起的,建议对最多五个心动周期的射血分数进行估计;然而,鉴于计算的繁琐和费力的性质,这并不总是在临床实践中完成。我们的模型识别每个心动周期,生成一个 32 帧的剪辑,并平均每个心跳的射血分数的剪辑水平估计值作为测试时间增强。EchoNet-Dynamic是使用在斯坦福医学院常规临床实践过程中获得的10,030个顶端四腔超声心动图视频开发的。

5代码解读

参考

翻译与学习,源自:https://www.nature.com/articles/s41586-020-2145-8

您的鼓励是我源源不断创作的动力~

感谢观看哦!

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

图解LeetCode——剑指 Offer 26. 树的子结构

一、题目 输入两棵二叉树A和B,判断B是不是A的子结构。(约定空树不是任意一个树的子结构) B是A的子结构, 即:A中有出现和B相同的结构和节点值。 二、示例 2.1> 示例 1: 【输入】A [1,2,3], B [3,1] 【输出】false 2.2> 示…

数字化转型的成功模版,珠宝龙头曼卡龙做对了什么?

2月11日,曼卡龙(300945.SZ)发布2022年业绩快报,报告期内,公司实现营业收入16.11亿元,同比增长28.63%。来源:曼卡龙2022年度业绩快报曼卡龙能在2022年实现营收增长尤为不易。2022年受疫情影响&am…

c语言操作文件

1、文件缓冲区 文件缓冲区的目的:提高访问效率 提高磁盘使用寿命 刷新就是将当前缓冲区数据全部提交。 不刷新时,程序在崩溃时缓冲区内容无法输出(有些情形会带来错误) 文件缓冲区的四种刷新方式 行刷新(遇到换行符…

CSS3新增属性( 过渡、变形和动画)

文章目录一、过渡1、transition-property2、transition-duration3、transition-timing-function4、transition-delay二、变形1、transform2、2D变形2.1、平移(translate)2.2、缩放(scale)2.3、倾斜(shew)2.…

【记录】smartctl|Linux如何通过smartctl查看有没有坏的磁盘?以及使用时长、电源周期、故障记录等

smartctl是一个用于监测和分析硬盘健康状态的工具,可以用于检测是否存在坏的磁盘。以下是使用smartctl检查磁盘健康状态的步骤: 安装smartctl软件 在Linux系统中,smartctl通常包含在smartmontools软件包中。如果您还没有安装smartmontools&am…

Mr. Cappuccino的第38杯咖啡——Kubernetes中Pod、Namespace、Label、Deployment、Service之间的关系

Kubernetes中Pod、Namespace、Label、Deployment、Service之间的关系Pod、Namespace、Label、Deployment、Service之间的关系NamespacePod1. 创建一个namespace并运行一个pod2. 查看pod3. 删除pod4. 删除pod控制器Label1. 创建yaml文件(nginx-pod.yaml)2…

【数据结构与算法】二分查找 移除元素

今日任务 数组理论基础 704.二分查找 27.移除元素 1.数组理论基础 (1)数组是存放在连续内存空间上的相同类型数据的集合。 注意: 数组下标都是从0开始的数组内存空间的地址是连续的 (2)正因为数组在内存空间的…

【C语言】字符串处理函数及典例(2)

接上:【C语言】字符串处理函数及典例(1) 之前在(1)中讨论的函数如strcpy,strcmp,strcat ,都是长度不受限制函数,即不管参数的大小,关键点都是找到 \0 &…

ChatGPT爆火出圈,高质量文本标注数据成关键

“2022年11月30日,OpenAI发布了ChatGPT——一个对话式AI,上线仅五天,注册用户数突破100万,爆火出圈,成为社会热议话题。截止今年1月末,ChatGPT的月活用户数量破亿,成为史上用户数增长最快的消费…

Java字节流

4 字节流 字节流抽象基类 InputStream:这个抽象类是表示字节输入流的所有类的超类OutputStream:这个抽象类是表示字节输出流的所有类的超类子类名特点:子类名称都是以其父类名作为子类名的后缀 4.1 IO流概述和分类 IO流概述: …

Spring之基于xml的自动装配、基于Autowired注解的自动装配

文章目录基于xml的自动装配①注解②扫描③新建Maven Module④创建Spring配置文件⑤标识组件的常用注解⑥创建组件⑦扫描组件⑧测试⑨组件所对应的bean的id基于注解的自动装配①场景模拟②Autowired注解③Autowired注解其他细节④Autowired工作流程Autowire 注解的原理Qualifier…

深圳的商户们有福啦!小微企业、个体工商户的扶持举措又来了!

深圳的商户们有福啦!近日,深圳8部门联合印发《关于进一步支持中小微企业纾困及高质量发展的若干措施》,从纾困和高质量发展的角度,在降低企业生产经营成本、有效扩大市场需求、支持中小企业创新发展、促进中小企业转型升级4个方面…

2.Visual Studio下载和安装

Visual Studio 是微软提供的一个集成开发环境(IDE),主要用于为 Windows 系统开发应用程序。Visual Studio 提供了构建 .Net 平台应用程序的一站式服务,可以使用 Visual Studio 开发、调试和运行应用程序。 1、Visual Studio下载 …

ESP-C3入门9. 创建TCP Server

ESP-C3入门9. 创建TCP Server一、ESP32 IDF的TCP/IP协议栈二、BSD套接字API介绍三、创建TCP Server的步骤1. 引用TCP/IP协议栈2. 创建 TCP套接字拼绑定端口3. 接收客户端请求4. 启动服务四、完整代码1. wifi.h2. wifi.c3. tcpServer.h4. tcpServer.c5. main.c6. CmakeLists.txt…

BNB Greenfield 成存储赛道“新贵”,BNB 生态的野心与破局

“从BNB Beacon Chain,到BNB Chain,再到BNB Greenfield ,三位一体的 BNB 生态格局正式形成。 ”在今年的2月1日,币安发布了分布式存储链BNB Greenfield,根据白皮书信息,它的特别之处在于其不仅具备基于SP&a…

完成四种方式的MySQL安装

1.仓库安装 1.1查看版本和安装mysql包 [rootlocalhost ~]# cat /etc/redhat-release Red Hat Enterprise Linux release 9.1 (Plow) [rootlocalhost ~]# rpm -ivh https://repo.mysql.com/mysql80-community-release-el9-1.noarch.rpm1.2装包 [rootlocalhost ~]# dnf instal…

千峰jquery【案例】

滑动选项卡&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta http-equiv"X-UA-Compatible" content"IEedge" /><meta name"viewport" content"widt…

RabbitMQ学习(六):发布确认

一、发布确认的原理生产者将信道设置成 confirm 模式&#xff0c;一旦信道进入 confirm 模式&#xff0c;所有在该信道上面发布的 消息都将会被指派一个唯一的 ID(从 1 开始)&#xff0c;一旦消息被投递到所有匹配的队列之后&#xff0c;broker 就会发送一个确认给生产者(包含消…

V4l2框架基础知识(一)

V4L2框架-v4l2 device V4l2视频设备驱动基础 1.V4L2是专门为linux设备设计的整套视频框架&#xff08;其主要核心在linux内核&#xff0c;相当于操作系统上层的视频源捕获驱动框架&#xff09;&#xff0c;为上层访问系统底层的视频设备提供了一个统一的标准接口&#xff0c;…

【LeetCode】剑指 Offer 05. 替换空格 p50 -- Java Version

题目链接&#xff1a; https://leetcode.cn/problems/ti-huan-kong-ge-lcof/ 1. 题目介绍&#xff08;05. 替换空格&#xff09; 请实现一个函数&#xff0c;把字符串 s 中的每个空格替换成"%20"。 【测试用例】&#xff1a; 示例1&#xff1a; 输入&#xff1a;s …