深度学习系统工程指南

0 / 1237

众所周知,深度学习模型仅仅只是构建 AI 产品的重要步骤,但并不是全部。一个互联网产品(如 APP)想要集成深度学习能力,往往还需要走完很多设计、开发和测试方面的工作。如何部署深度学习往往成为了系统设计中更关键的问题。

近日,GitHub 上有这样一个项目,专门介绍了如何将深度学习算法和模型融入到互联网产品中。项目基本以流程、架构图为主,目前仍在完善中,适合产品经理和开发者学习。

项目地址:https://github.com/alirezadir/Production-Level-Deep-Learning

原作者:Alireza Dirafzoon 翻译自:https://github.com/alirezadir/Production-Level-Deep-Learning/blob/master/README.md

译者:Liu Yun 链接:https://github.com/liuyun1217/Production-Level-Deep-Learning

[NOTE: 本文还在逐步完善中,欢迎反馈和贡献 😊]

部署产品级的深度学习模型充满挑战,其难度远远超过训练一个性能不俗的模型。为了部署一个产品级的深度学习系统,还需要设计和开发以下几个部分(见下图):

本文可以作为一篇工程指南去构建一个产品级的深度学习系统,并且该系统可以部署在真实的生产环境中。 本文借鉴了如下文章: Full Stack Deep Learning Bootcamp (by Pieter Abbeel at UC Berkeley, Josh Tobin at OpenAI, and Sergey Karayev at Turnitin), TFX workshop by Robert Crowe, and Pipeline.ai's Advanced KubeFlow Meetup by Chris Fregly.

Machine Learning Projects 机器学习项目

[译者注]原作者在文中既使用了Mechine Learning(机器学习),又使用了Deep Learning(深度学习,大部分工具可以两者都适用)

有趣的真相 😳 fact: 85%的AI项目会失败. 1 潜在的原因如下:

  • 技术上不可行,或者无法广泛应用
  • 没能转化为产品
  • 不清晰的成功标准或指标
  • 糟糕的团队管理

1. ML Projects lifecycle 机器学习项目的生命周期

  • 了解你所在领域的技术现状的重要性:
    • 可以知道什么是可能可以实现的
    • 可以知道下一步尝试的方向

2. Mental Model for ML project 机器学习项目的心智模型

当对机器学习项目的重要性和紧急性排序时,需要考虑两个重要的因素:

  • 高收益:
    • 工作流中的复杂部分
    • 快速进行”廉价预测“(小的数据量,标签,计算量情况下,得到小模型进行简单的预测,能给工作开个好头)
    • 将复杂的手动处理过程进行自动化很有用
  • 低成本:
    • 成本主要由以下几部分决定:
      • 获得有效的数据
      • 高性能需求:成本随着精确度要求超线性增长
      • 问题的难度:
        • 一些高难度的问题包括:非监督学习,增强学习,某些类别的监督学习

Full stack pipeline 全栈流水线

下图高度概括了产品级深度学习系统相关的各个不同的组成模块:

接下来,我们将会讲解每一个模块,以及从实践者出发推荐的适合该模块的工具集和框架。 ## 1. Data Management 数据管理

1.1 Data Sources 数据来源

  • 监督深度学习需要大量的打标签数据
  • 对自己的数据打标签是很昂贵的!
  • 下面是一些可供选择的数据来源:
    • 开源数据(适合入门,但不适合进阶)
    • 数据增强(对于机器视觉是必选,对于NLP可选)
    • 合成数据(入门首选,尤其是NLP领域)

1.2 Data Labeling 数据标记

  • 要求:独立的软件栈(标签平台),临时工,以及质量控制
  • 人工打标签:
    • 众包:便宜,可扩展,可靠性较差,需要质量控制
    • 招聘数据标记人员:质量较好,昂贵,扩展很慢
    • 数据标记服务公司:
  • 标记平台:
    • Diffgram: 训练数据软件(机器视觉)
    • Prodigy: 基于主动学习active learning实现(由Spacy的开发者编写),针对文字和图片构成的标记注释工具
    • HIVE: 针对机器视觉的AI服务平台
    • Supervisely: 功能全面的机器视觉平台
    • Labelbox: 针对机器视觉
    • Scale AI数据平台(针对机器学习和自然语言处理)

1.3. Data Storage 数据存储

  • 可供选择的数据存储方案有:
    • 对象存储: 存储二进制数据(图片,声音文件,压缩的文本)
    • 数据库: 存储元数据(文件路径,标签,用户行为等).
      • Postgres Postgresql对于大多数应用来说是正确的选择,它有着一流的SQL语言支持,以及对非结构化JSON格式的最佳支持。
    • 数据湖: 用以聚合无法从数据库获得的特征(比如日志数据)
    • 特征存储: 存储,访问,以及分享机器学习的特征 (特征提取的计算成本很高,并且几乎无法扩展,因此能够在不同模型和团队之间复用特征是提高效能的关键)。
  • 建议: 在训练阶段,复制数据到本地文件系统或者NFS1

1.4. Data Versioning 数据版本管理

  • 对于已部署的机器学习模型,“必须”有其对应的训练数据版本:已部署的机器学习模型,由数据和代码共同组成.1 没有数据版本的管理,就意味着没有模型版本的管理。
  • 数据版本管理平台:
    • DVC: 针对机器学习项目的开源版本管理系统
    • Pachyderm: 针对数据的版本管理
    • Dolt: 针对SQL数据库的版本管理

1.5. Data Processing 数据处理工作流

  • 对于模型的训练数据可能来自于不同的数据源,包括:存储在数据库的数据, 包括存储在数据库的数据,日志数据, 和其他分类模型的输出.
  • 在任务和任务之间有依赖,一个任务的开启需要另外一个任务的完结。比如,在一个新的日志数据上训练任务,必须在某个预处理流程之后进行。
  • Makefiles用来完成此工作比较流缺乏伸缩性,在这个场景下,工作流管理工具十分重要。
  • 工作流编排:
    • Luigi by Spotify
    • Airflow 来自Airbnb,动态的,可扩展的,优雅的,具有伸缩性(最广泛应用的特性)的工作流管理工具。
      • DAG workflow
      • 鲁棒的按条件执行:当失败时进行重试
      • pusher支持tensorflow serving镜像
      • 可以在单一的python文件中实现完整的工作流

2. Development, Training, and Evaluation 开发,训练,模型评估

2.1. Software engineering 软件工程

  • 编程语言大赢家:Python
  • 编辑器:
    • Vim
    • Emacs
    • VS Code (作者推荐): 内建 git staging 和diff, Lint code, 可通过ssh远程打开项目
    • Notebooks: 项目开启阶段最完美的选择,但是很难扩展(令人高兴的是:Netflix的notebook体系是一个例外,它完全基于nteract实现nteract suites).
      • nteract: 针对Jupyter的下一代基于React的UI
      • Papermill: 基于nteract库构建的,针对调参评估分析的"Jupyter"
      • Commuter: 另外一个nteract项目,可以提供只读展示(比如来自S3的文件)
    • Streamlit: 基于applets的交互式数据科学工具
  • 电脑建议1:
    • 针对个人开发者或者创业公司
      • 模型开发:一台4块图灵架构GPU的PC(目前图灵架构的GPU有RTX2080Ti(本文主要指这款),Tesla T4(企业数据中心使用,搭载在服务器),Quodro RTX5/6/8000(多用于图形渲染工作站))
      • 训练/评估:使用同样的4卡GPU的PC, 当运行很多任务时,也可以使用共享计算资源或者使用云服务。
    • 对于大公司:
      • 开发:为每位机器学习科学及购买一台4卡图灵架构的PC,或者给他们上V100的机器。
      • 训练/评估:使用云服务,有充分的资源供应和故障处理
  • 使用云服务:
    • GCP: 可以选择将任何实例运行在GPU上,并且有TPU资源
    • AWS:

2.2. Resource Management 资源管理

  • 给程序分配任意的计算资源
  • 如果选择计算资源管理,有如下选项:
    • 传统的集群任务调度策略 ( e.g.Slurm workload manager )
    • Docker + Kubernetes
    • Kubeflow
    • Polyaxon

2.3. DL Frameworks 深度学习框架

  • 除非有着充分的理由,否则建议使用Tensorflow/Keras或者Pytorch.1
  • 下图基于*“易开发性”“产品表现”*两个维度,展示了不同的深度学习框架对比图。

2.4. Experiment management 实验管理

  • 开发,训练,以及评估策略:
    • 简单的方法快速开始
      • 以小批量数据训练一个小的模型,如果有效果,扩展到更大的数据和模型,以及进行超参数调优。
    • 实验管理工具:
    • Tensorboard
      • 提供可视化以及机器学习实验相关的工具
    • Losswise (可以对机器学习进行监控)
    • Comet: 可以追踪代码,实验,以及机器学习项目的结果
    • Weights & Biases: 记录和可视化你与同事协同研究中的所有细节
    • MLFlow Tracking: 记录参数,代码版本,指标,输出文件,以及结果的可视化
      • 在python中用一行代码进行自动化的实验追踪
      • 实验之间的比对
      • 超参调优
      • 支持K8S

2.5. Hyperparameter Tuning 超参调优

  • 策略
    • 网格搜索
    • 随机搜索
    • 贝叶斯优化
    • HyperBand (以及ASHA,Asynchronous Successive Halving Algorithm 异步减半算法)

[译者注]Hyperband算法对 Jamieson & Talwlkar(2015)提出的SuccessiveHalving算法做了扩展。SuccessiveHalving算法:假设有nn组超参数组合,然后对这nn组超参数均匀地分配预算并进行验证评估,根据验证结果淘汰一半表现差的超参数组,然后重复迭代上述过程直到找到最终的一个最优超参数组合。 * Population-based Training(兼顾并行调优和串行调优)

  • Platforms: 超参调优平台
    • RayTune: RayTune是一个Python库,能够在任何规模下进行超参调优(主要专注深度学习和增强学习)。支持几乎任何机器学习框架,包括PyTorch, XGBoost, MXNet, 和Keras等.
    • Katib: 针对超参调优和神经网络架构搜索的K8S原生系统, 受这篇论文启发 Google vizier research.google.com/ja//pubs/archive/ bcb15507f4b52991a0783013df4222240e942381.pdf),并且支持多种机器学习框架(比如Tensorflo