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

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

3天内不再提示

如何选择合适的深度学习框架开展AI研究

NVIDIA英伟达 来源:cc 2019-02-12 10:09 次阅读

深度学习框架正如一家杂货店,当人们想要做一顿美餐的时候,想必没有几个人会亲自到菜园里种菜,而是选择从市场里购买食材。

正如想要炒菜的人不会亲自去种菜采摘一样,开发者们也不想每次搭建深度学习神经网络的时侯都从零开始。

由于深度学习模型规模庞大且结构复杂,在编写功能代码的时候,程序员不会每种功能代码都从头编写,而是会借助框架和软件库来高效地构建神经网络。顶级深度学习框架可提供专用于深度神经网络计算的代码,这些代码均经过高度优化,并支持GPU计算。

深度学习框架之间的差异

不同类型的杂货店通常都有其各自专营的特色商品。比如,当人们烹饪家常菜的时候,通常可以直接在当地市场买到所需的基础食材;可是当人们想要制作具有异域风情的高级菜品的时候,则可能更喜欢在大型超市里选购进口蔬菜,挑选未经人工催熟的有机水果;又或者,当您要为一大桌子人准备饭菜,您又有可能会选择在批发市场里采购一番。

同样道理,虽然开发者可以基于任意一种深度学习框架构建出绝大多数类型的网络(例如卷积神经网络或递归神经网络),但各个框架在可用示例的数量和更新频率方面各有差异。此外,在增添新功能方面,各个深度学习框架中贡献者的数量也彼此不同,而且框架通过API 提供功能的方式也同样各具特色。

顶级框架都是开源的,其中大部分框架的发布时间始于 2014 年,而且其开发工作一直都很活跃。

如何选择深度学习框架

在选择深度学习框架的时候,开发者们通常会有很多不同的考量,例如:框架前端与开发者专业技能的匹配程度,可获取的社区支持力度,或他们感兴趣的新功能的开发速度。

深度学习框架一般可以使用例如Python 或 C/C ++ 等编程语言中的脚本,通过命令访问接口;也可以通过类似于 NVIDIA DIGITS 的图形界面进行访问,此类界面允许开发者在更加用户友好的 Web 应用程序中构建深度神经网络。

如果您希望将您的深度学习应用程序与 NVIDIA GPU 相集成的话,请查看 NVIDIA 开发者计划以了解更多信息

如何在深度学习框架之间迁移模型

根据其所开发应用程序的需要,开发者可能会首先使用一个框架来构建和训练深度学习模型;然后再使用不同的框架对模型进行重新训练,或者在不同的框架上部署该模型,以便进行推理。

开放式神经网络交换 (ONNX) 是一种允许开发者在框架之间迁移模型的深度学习模型格式。ONNX 支持在大多数主流框架之间进行模型迁移。当深度学习应用程序已经完成了训练并可以部署时, TensorRT 软件会对NVIDIA GPU 上的高性能推理模型进行优化。TensorRT 与 TensorFlowMATLAB 高度集成,并且支持导入 ONNX 格式的深度学习模型。

以下列举了一些热门的深度学习框架,以及多家公司和研究人员如何构建用于医疗、灾难预测和细胞生物学的GPU加速应用程序的案例。

Apache MXNet

Apache MXNet 是由 Apache Software Foundation 于 2015 年创建的深度学习框架。一家位于西雅图的初创公司——Magic AI, 正在利用深度学习模型来监控马匹的健康状况,该模型基于 MXNet 构建,并运行于 NVIDIA GPU 上。该神经网络可以逐帧分析马厩内的监控视频,当出现意外状况,例如:马匹即将分娩,马匹表现出绞痛症状或陌生人进入马厩时,该神经网络会向马场主发送警报。

开发者可以将模型迁移到 ONNX 进行推理,然后使用 NVIDIA TensorRT 进行优化和部署。

Caffe

Caffe 深度学习框架于2014 年诞生在加州大学伯克利分校,并催生了 NVCaffe 等分支以及类似于 Facebook 的 Caffe2(现与 PyTorch 合并)的新型框架。肺癌是全球最常见的癌症,半数被诊断为肺癌的患者会在一年内死亡。借助深度学习和 NVIDIA GPU,位于圣路易斯的初创公司 Innovation DX利用胸部 X 光扫描对肺癌进行早期筛查。他们的早期检测工具由神经网络和 Caffe 框架提供支持,可以使肺癌患者的存活率提高两倍。

开发者可以利用 NVIDIA TensorRT 的内置 Caffe 模型导入器,对推理模型进行优化和部署。

Chainer

Chainer 诞生于 2015 年,由日本风险投资公司Preferred Networks开发。利用这款基于 Python 的框架,Preferred Networks与工业自动化巨头 FANUC 携手合作,共同参加了 2016 年的亚马逊分拣货物挑战赛 (Amazon Picking Challenge)。挑战赛的内容是让自主机器人分拣并放置物品。Preferred Networks 和 FANUC 在比赛中使用了卷积神经网络和用于笔记本电脑的NVIDIA GeForce GTX 870M GPU,并最终取得了第二名的好成绩。

开发者可以将模型迁移到 ONNX 进行推理,然后使用 NVIDIA TensorRT 进行优化和部署。

Keras

Keras 是一个可以在多个框架上运行的界面,使用高级Python API ,它可以在诸如MXNet、TensorFlow、Theano 和 Microsoft Cognitive Toolkit等不同框架之上运行。Keras 由研究人员 FrançoisChollet 于 2014 年创建,旨在让统一且抽象的 API 变得易于使用。一个韩国研究团队使用 Keras 来提高飓风预测的速度和准确性。他们使用 TensorFlow 上的 Keras 构建了深度学习模型,并在 NVIDIA GPU 上运行,可以提前几个小时预测风暴的路径和降水量。由于这些神经网络能够提前预测风暴,因此他们可以在飓风来袭之前向当地居民发出警告,争取更多的疏散时间。

MATLAB

MATLAB 允许熟悉其软件的工程师使用 MATLAB 代码来开发深度学习工具。借助MATLAB 和 NVIDIA GPU,阿尔伯塔大学的研究人员致力于帮助患者避免不必要的前列腺癌活检。该团队的深度学习模型对细胞外囊泡的生物标志物数据进行分析,从而预判是否存在癌细胞。

在推理方面,开发者可以通过 MATLAB GPU Coder 使用 TensorRT 自动生成经过优化的推理引擎。

Microsoft Cognitive Toolkit

这款由微软公司于2014年推出的深度学习框架,起初被命名为CNTK, 其主要为微软自己的AI模型(如 Cortana)提供支持。借助NVIDIA Tesla GPU和 Microsoft Cognitive Toolkit,医疗科技公司 IRIS 专注于预防糖尿病视网膜病变或糖尿病引起的失明,此类疾病只能通过眼科检查才能发现,患者很难自行判断。而IRIS 的神经网络可通过分析视网膜图像,告知患者是否需要到专业医师处就诊。

开发者可以将模型迁移到 ONNX 进行推理,然后使用 NVIDIA TensorRT 进行优化和部署。

PyTorch

PyTorch 的前身是 Torch,一种基于编程语言 Lua 的热门深度学习框架,该框架于 2011 年推出。随后,2017 年,Facebook 推出了 PyTorch,后者继承了 Torch 的功能并可以在 Python 中实施。艾伦细胞科学研究所 (Allen Institute of Cell Science) 的研究人员利用 PyTorch 开发出了首个可预测人体活细胞的3D 模型,该模型由 NVIDIA DGX 工作站和 TITAN Xp GPU 提供支持,能够让科学家在虚拟环境中以数字方式实现细胞的可视化并操纵细胞行为。这款利用卷积神经网络构建的细胞模型可以替代昂贵的荧光显微镜观测,让科学家能够以一种前所未有的方式理解和预测细胞活动。

开发者可以将模型迁移到 ONNX 进行推理,然后使用 NVIDIA TensorRT 进行优化和部署。

TensorFlow

TensorFlow 是 Google 于 2015 年创建的深度学习框架。德克萨斯大学 MD 安德森癌症中心的研究人员正在使用 TensorFlow 开发高精度放射治疗技术。放射科医师通常会检查癌症患者的扫描图像,以判断在不损害正常组织的情况下应该使用多少辐射量来进行肿瘤靶向治疗。借助 NVIDIA Tesla GPU,研究人员开发了可学习并模仿医生工作模式的深度学习模型,来识别放射目标区域。

在推理方面,开发者既可以使用 TensorFlow-TensorRT 集成功能优化 TensorFlow 中的模型;也可以导出 TensorFlow 模型,然后使用 NVIDIA TensorRT 的内置 TensorFlow 模型导入器在 TensorRT 中进行优化。。

广泛的框架生态系统

NVIDIA与上述诸多框架以及其他框架(如百度的 PaddlePaddle)合作,使深度学习应用程序得以成功实现。

新型深度学习框架正在不断地涌现,这表明神经网络得到了开发者的广泛采用。Theano 和 Torch 这类早期框架为许多深度学习应用程序提供了支持,但其创建者在 2017 年宣布,他们将不再继续开发这些框架。

NVIDIA 的深度学习框架团队直接参与了其中的多个开源项目,仅在去年,就做出了共计 800 多项贡献,提高了这些项目的易用性和性能。

NGC 容器注册表允许访客即时访问上述多种框架,并能够按照访客的需求,为其提供最佳的 GPU 加速性能。

了解更多有关深度学习框架的资源和安装信息,请访问 NVIDIA Developer 网站。该中心还为一些最常见的深度学习框架和应用程序提供示例神经网络训练脚本,例如计算机视觉、机器翻译和对象检测。在 NVIDIA GPU Cloud 目录中还提供深度学习容器套件。

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

    关注

    87

    文章

    26364

    浏览量

    263958
  • 深度学习
    +关注

    关注

    73

    文章

    5225

    浏览量

    119869

原文标题:一文教你如何选择深度学习框架开启AI研究

文章出处:【微信号:NVIDIA_China,微信公众号:NVIDIA英伟达】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    FPGA在深度学习应用中或将取代GPU

    基础设施,人们仍然没有定论。如果 Mipsology 成功完成了研究实验,许多正受 GPU 折磨的 AI 开发者将从中受益。 GPU 深度学习面临的挑战 三维图形是 GPU 拥有如此
    发表于 03-21 15:19

    AI推理框架软件ONNX Runtime正式支持龙架构

    近日,知名AI推理框架开源社区ONNX Runtime正式发布支持龙架构的版本1.17.0。
    的头像 发表于 03-12 12:23 259次阅读
    <b class='flag-5'>AI</b>推理<b class='flag-5'>框架</b>软件ONNX Runtime正式支持龙架构

    OpenHarmony AI框架开发指导

    一、概述 1、功能简介 AI业务子系统是OpenHarmony提供原生的分布式AI能力的子系统。AI业务子系统提供了统一的AI引擎框架,实
    发表于 09-19 18:54

    深度学习框架深度学习算法教程

    深度学习框架深度学习算法教程 深度学习是机器
    的头像 发表于 08-17 16:11 698次阅读

    深度学习cntk框架介绍

    ,CNTK框架是非常重要的一部分。本篇文章将介绍CNTK框架的概览、起源、结构以及应用等内容,更深入了解CNTK框架。 一、CNTK框架的概述 CNTK(Microsoft Cogni
    的头像 发表于 08-17 16:11 953次阅读

    深度学习框架连接技术

    深度学习框架连接技术 深度学习框架是一个能够帮助机器学习
    的头像 发表于 08-17 16:11 465次阅读

    深度学习框架对照表

    深度学习框架对照表  随着人工智能技术的发展,深度学习正在成为当今最热门的研究领域之一。而
    的头像 发表于 08-17 16:11 487次阅读

    深度学习算法库框架学习

    深度学习算法库框架学习 深度学习是一种非常强大的机器学习
    的头像 发表于 08-17 16:11 428次阅读

    深度学习算法的选择建议

    深度学习算法的选择建议 随着深度学习技术的普及,越来越多的开发者将它应用于各种领域,包括图像识别、自然语言处理、声音识别等等。对于刚开始
    的头像 发表于 08-17 16:11 364次阅读

    深度学习框架tensorflow介绍

    深度学习框架tensorflow介绍 深度学习框架TensorFlow简介
    的头像 发表于 08-17 16:11 1372次阅读

    深度学习框架的作用是什么

    深度学习框架的作用是什么 深度学习是一种计算机技术,它利用人工神经网络来模拟人类的学习过程。由于
    的头像 发表于 08-17 16:10 1140次阅读

    深度学习框架区分训练还是推理吗

    深度学习框架区分训练还是推理吗 深度学习框架是一个非常重要的技术,它们能够加速
    的头像 发表于 08-17 16:03 1022次阅读

    深度学习框架是什么?深度学习框架有哪些?

    高模型的精度和性能。随着人工智能和机器学习的迅猛发展,深度学习框架已成为了研究和开发人员们必备的工具之一。 目前,市场上存在许多
    的头像 发表于 08-17 16:03 1710次阅读

    深度学习框架pytorch入门与实践

    深度学习框架pytorch入门与实践 深度学习是机器学习中的一个分支,它使用多层神经网络对大量数
    的头像 发表于 08-17 16:03 1189次阅读

    ​计算机视觉深度学习训练推理框架

    PyTorch是由Facebook人工智能研究小组开发的一种基于Lua编写的Torch库的Python实现的深度学习库,也是目前使用范围和体验感最好的一款深度
    的头像 发表于 05-08 14:20 818次阅读
    ​计算机视觉<b class='flag-5'>深度</b><b class='flag-5'>学习</b>训练推理<b class='flag-5'>框架</b>