0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

使用NVIDIA DALI加速医学图像处理

星星科技指导员 来源:NVIDIA 作者:NVIDIA 2022-04-13 16:24 次阅读

深度学习模型需要大量数据才能产生准确的预测,随着模型规模和复杂性的增加,这种需求日益迫切。即使是大型数据集,例如拥有 100 多万张图像的著名 ImageNet ,也不足以在现代计算机视觉任务中实现最先进的结果。

为此,需要使用数据增强技术,通过对数据引入随机干扰(如几何变形、颜色变换、噪声添加等),人为地增加数据集的大小。这些干扰有助于生成预测更稳健的模型,避免过度拟合,并提供更好的精度。

医学成像任务中,数据扩充至关重要,因为数据集最多只包含数百或数千个样本。另一方面,模型往往会产生需要大量 GPU 内存的大激活,特别是在处理 CT 和 MRI 扫描等体积数据时。这通常会导致在小数据集上进行小批量的培训。为了避免过度拟合,需要更精细的数据预处理和扩充技术。

然而,预处理通常对系统的整体性能有重大影响。这在处理大输入的应用程序中尤其如此,例如体积图像。由于 NumPy 等库的简单性、灵活性和可用性,这些预处理任务通常在 CPU 上运行。

在某些应用中,例如医学图像的分割或检测,由于数据预处理通常在 CPU 中执行,因此训练期间的 GPU 利用率通常不理想。解决方案之一是尝试完全重叠数据处理和训练,但并不总是那么简单。

这样的性能瓶颈导致了鸡和蛋的问题。由于性能原因,研究人员避免在他们的模型中引入更高级的增强,并且由于采用率较低,库不会将精力放在优化预处理原语上。

GPU 加速解决方案

通过将数据预处理卸载到 GPU ,可以显著提高具有大量数据预处理管道的应用程序的性能。 GPU 在此类场景中通常未得到充分利用,但可用于完成 CPU 无法及时完成的工作。其结果是更好的硬件利用率,最终更快的培训。

就在最近, NVIDIA 在 MICCAI 2021 脑肿瘤分割挑战中获得 10 个顶级排名中的 3 个 ,包括获胜的解决方案。获胜的解决方案通过加快系统的 preprocessing pipeline 速度,使 GPU 利用率高达 98% ,并将总训练时间减少了约 5% ( 30 分钟)(图 1 )。

pYYBAGJWiOuAFbNCAACGWtQuEdI631.png

图 1 。 U-Net3D BraTS21 训练性能比较

当你查看NVIDIA 提交的[VZX333 ]时,这种差异变得更加显著。它使用了与BraTS21获奖解决方案相同的网络体系结构,但具有更复杂的数据加载管道和更大的输入量(KITS19数据集)。与本机管道相比,性能提升是令人印象深刻的2倍端到端培训加速(图2)。

poYBAGJWiPOAV-lAAAB-o7jgWoo280.png

图 2 。 U-Net3D MLPerf 训练 1.1 训练性能比较

这是由 NVIDIA 数据加载库( DALI ) 实现的。 DALI 提供了一组 GPU 加速构建块,使您能够构建完整的数据处理管道,包括数据加载、解码和扩充,并将其与所选的深度学习框架集成(图 3 )。

poYBAGJWiP2AY1jkAAFZV_6RYsU472.png

图 3 。 DALI 概述及其应用 在 DL 应用程序中用作加速数据加载和预处理的工具

体积图像操作

最初, DALI 是作为图像分类和检测工作流的解决方案开发的。后来,它被扩展到其他数据域,如音频视频或体积图像。有关体积数据处理的更多信息,请参阅 3D Transforms 或 NumPy 读卡器 .

DALI 支持多种图像处理操作员。有些还可以应用于体积图像。以下是一些值得一提的例子:

Resize

Warp affine

Rotate

随机对象边界框

为了展示上述的一些操作,我们使用了来自 BraTS19 数据集的一个样本,该样本由标记为脑肿瘤分割的 MRI 扫描组成。图 4 显示了从脑 MRI 扫描体积中提取的二维切片,其中较暗的区域表示标记为异常的区域。

poYBAGJWiUKAOOy8AAEFVQww9A0412.png


图 4 。来自 BraTS19 数据集样本的切片

调整大小运算符

Resize通过插值输入像素将图像放大或缩小到所需形状。可以分别为每个维度配置“高比例”或“低比例”,包括选择插值方法。

Warp affine通过线性变换将像素坐标从源映射到目标,应用几何变换。

latex.php?latex=Out%28x%2Cy%2Cz%29%3DIn%28xsrc%2Cysrc%2Czsrc%29&bg=ffffff&fg=000&s=1&c=20201002latex.php?latex=Out%28x%2Cy%2Cz%29%3DIn%28xsrc%2Cysrc%2Czsrc%29&bg=ffffff&fg=000&s=1&c=20201002

Warp affine可用于一次性执行多个变换(旋转、翻转、剪切、缩放)。

旋转运算符

Rotate允许您绕任意轴旋转体积,该轴作为矢量和角度提供。它还可以选择性地扩展画布,使整个旋转图像包含在其中。

随机对象边界框操作符

随机对象边界框是一种适合于检测和分段任务的运算符。如前所述,医疗数据集往往相当小,目标类别(如异常)占据的区域相对较小。此外,在许多情况下,输入容量远大于网络预期的容量。如果要使用随机裁剪窗口进行训练,则大多数窗口不会包含目标。这可能导致训练收敛速度减慢或使网络偏向假阴性结果。

此运算符选择可能偏向于对特定标签采样的伪随机作物。连接组件分析是在标签图上执行的一个预步骤。然后,以相同的概率随机选择一个连接的 blob 。通过这样做,操作符可以避免过度呈现较大的斑点。

您还可以选择将选择限制为最大的 K 个 blob 或指定最小 blob 大小。选择特定 blob 时,将在包含给定 blob 的范围内生成随机裁剪窗口。图 8 显示了这个裁剪窗口选择过程。

图 8 。想象 the随机对象边界框对具有一组属于三个不同类别(每个类别用不同颜色高亮显示)的对象的人造 2D 图像的操作

学习速度的提高是非常显著的。在 KITS19 数据集上, nnU Net 在使用随机对象边界框运算符的测试运行时段中, 2134 达到与 3222 个随机裁剪时段相同的精度。

通常,查找连接组件的过程很慢,但数据集中的样本数可能很小。操作员可以配置为缓存连接的组件信息,以便仅在培训的第一个历元中计算。

关于作者

Janusz Lisiecki 是 NVIDIA 的深度学习经理,致力于快速数据管道。他过去的经验涵盖从面向大众消费市场的嵌入式系统到高性能硬件软件数据处理解决方案。

Joaquin Anton Guirao 是 NVIDIA 深度学习框架团队的高级软件工程师,专注于 NVIDIA DALI

Pablo Ribalta 是 NVIDIA 的深度学习算法经理,致力于 2D 和体积数据的基于图像的模型。他的研究经验包括启发式、元启发式、优化以及深度学习的不同应用,如医学和卫星图像。

Michal Futrega 是 NVIDIA 的软件工程师,致力于医学图像分割的神经网络和药物发现的图形神经网络。他获得了华沙大学理学硕士学位和计算机科学理学士学位。

Michał Marcinkiewicz 是 NVIDIA 深度学习软件组的高级 CUDA 算法工程师,专注于医学图像分析的计算机视觉。米莎从法国蒙彼利埃大学获得博士学位,从事拓扑相变研究。获得博士学位后,他完全转向机器学习

审核编辑:郭婷

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • NVIDIA
    +关注

    关注

    14

    文章

    5097

    浏览量

    104171
  • 数据集
    +关注

    关注

    4

    文章

    1212

    浏览量

    24938
  • 深度学习
    +关注

    关注

    73

    文章

    5524

    浏览量

    121762
收藏 人收藏

    评论

    相关推荐

    NVIDIA使用加速计算与AI推动精准医学发展

    在加利福尼亚州圣克拉拉举行的精准医学世界大会上,NVIDIA 因推动了医学成像、基因组学、计算化学和 AI 驱动机器人技术的发展而受到表彰。NVIDIA 创始人兼首席执行官黄仁勋荣获“
    的头像 发表于 02-17 17:14 293次阅读

    Dali通信的工作原理 如何使用Dali通信协议

    一、引言 Dali(Digital Addressable Lighting Interface,数字可寻址照明接口)是一种用于照明控制产品之间双向通信的协议。通过Dali通信协议,可以实现对照
    的头像 发表于 01-31 10:33 399次阅读

    Dali通信模块的选择与配置

    制器 : 选择符合DALI标准的主控制器,这是整个DALI系统的核心,负责系统的控制和指令发送。 主控制器应具备强大的处理能力和稳定的通信性能,以确保系统的高效运行。 DALI智能模块
    的头像 发表于 01-10 10:55 227次阅读

    Dali通信的优势和劣势

    Dali通信的优势 1. 数字化控制 Dali通信采用数字信号传输,与传统的模拟控制相比,数字信号更稳定、抗干扰能力强,能够实现更精确的控制。 2. 可寻址性 Dali通信系统能够对每个灯具进行单独
    的头像 发表于 01-10 10:40 455次阅读

    Dali通信网络的最佳配置

    DALI(数字可寻址照明接口)通信网络的最佳配置涉及多个方面,包括网络架构、设备选择、布线要求以及功能实现等。以下是对DALI通信网络最佳配置的分析: 一、网络架构 DALI通信网络采用主从控制模型
    的头像 发表于 01-10 10:32 248次阅读

    Dali通信在智能照明中的应用

    随着科技的飞速发展,智能照明系统已经成为现代建筑的重要组成部分。Dali通信技术作为一种先进的照明控制技术,以其高效、灵活、节能的特点,在智能照明领域得到了广泛的应用。 一、Dali通信技术概述
    的头像 发表于 01-10 10:21 238次阅读

    NVIDIA加速计算如何推动医疗健康

    近日,NVIDIA 企业平台副总裁 Bob Pette 在 AI Summit 一场演讲中重点谈论了 NVIDIA 加速计算如何推动医疗健康、网络安全和制造等行业实现转型。他表示,加速
    的头像 发表于 11-20 09:10 391次阅读

    日本企业借助NVIDIA产品加速AI创新

    日本领先企业和大学正在使用 NVIDIA NeMo、NIM 微服务和 NVIDIA Isaac 加速 AI 创新。
    的头像 发表于 11-19 14:34 507次阅读

    有没有大佬知道NI vision 有没有办法通过gpu和cuda来加速图像处理

    有没有大佬知道NI vision 有没有办法通过gpu和cuda来加速图像处理
    发表于 10-20 09:14

    dali协议的详细解释和含义 带你深度了解DALI DALI驱动器选型要注意什么

    DALI 的前世今生 DALI是 “Digital Addressable Lighting Interface(数字可寻址照明接口)” 的缩写,是一个开放的全球智能照明厂商组成的联盟,它于20世纪
    的头像 发表于 08-21 09:25 4397次阅读
    <b class='flag-5'>dali</b>协议的详细解释和含义 带你深度了解<b class='flag-5'>DALI</b> <b class='flag-5'>DALI</b>驱动器选型要注意什么

    图像处理器是什么意思

    质量、提取有用信息或实现特定应用需求的目的。图像处理器在现代科技领域具有广泛的应用,包括但不限于数字摄影、电视、监控系统、医学影像、计算机视觉等,为用户提供了丰富的视觉体验和应用功能。
    的头像 发表于 08-14 09:28 1186次阅读

    卷积神经网络在图像医学诊断中的优势

    随着人工智能技术的迅猛发展,卷积神经网络(Convolutional Neural Network,简称CNN)作为一种深度学习的代表算法,在图像处理医学诊断领域展现出了巨大的潜力和优势。CNN
    的头像 发表于 07-01 15:59 1486次阅读

    利用NVIDIA的nvJPEG2000库分析DICOM医学影像的解码功能

    本文将深入分析 DICOM 医学影像的解码功能。AWS HealthImaging 利用 NVIDIA 的 nvJPEG2000 库来实现此功能。
    的头像 发表于 05-28 14:27 987次阅读
    利用<b class='flag-5'>NVIDIA</b>的nvJPEG2000库分析DICOM<b class='flag-5'>医学</b>影像的解码功能

    基于FPGA的实时边缘检测系统设计,Sobel图像边缘检测,FPGA图像处理

    算法 ,利用乒乓操作和 SDRAM 缓存图像,可以实时提取视频图像的边缘特征。文中对比了 MATLAB 和 FPGA 的处理效果,由于 FPGA 对算法采取了硬件加速,所以相较于 MA
    发表于 05-24 07:45

    常见的医学图像读取方式和预处理方法

    基于深度学习做医学图像数据分析,例如病灶检测、肿瘤或者器官分割等任务,第一步就是要对数据有一个大概的认识。但是我刚刚入门医学图像分割的时候,很迷茫不知道自己该干啥,不知道需要准备哪些知
    发表于 04-19 11:43 1058次阅读
    常见的<b class='flag-5'>医学</b><b class='flag-5'>图像</b>读取方式和预<b class='flag-5'>处理</b>方法