译者 | 布加迪
审校 | 孙淑娟
目前,没有用于构建和管理机器学习(ML)应用程序的标准实践。机器学习项目组织得不好,缺乏可重复性,而且从长远来看容易彻底失败。因此,我们需要一套流程来帮助自己在整个机器学习生命周期中保持质量、可持续性、稳健性和成本管理。
图1. 机器学习开发生命周期流程
使用质量保证方法开发机器学习应用程序的跨行业标准流程(CRISP-ML(Q))是CRISP-DM的升级版,以确保机器学习产品的质量。
CRISP-ML(Q)有六个单独的阶段:
1. 业务和数据理解
2. 数据准备
3. 模型工程
4. 模型评估
5. 模型部署
6. 监控和维护
这些阶段需要不断迭代和探索,以构建更好的解决方案。即使框架中有顺序之分,后一阶段的输出可以决定我们要不要重新检查前一阶段。
图2. 每个阶段的质量保证
质量保证方法被引入到框架的每个阶段。这套方法有要求和约束,比如性能指标、数据质量要求和稳健性。它有助于降低影响机器学习应用程序成功的风险。它可以通过持续监控和维护整个系统来实现。
比如说:在电子商务企业,数据和概念漂移会导致模型退化;如果我们没有部署系统来监控这些变化,公司就会蒙受损失,即失去客户。
开发流程一开始,我们需要确定项目范围、成功标准和ML应用程序的可行性。之后,我们开始数据收集和质量验证过程。这个过程漫长而又充满挑战。
范围:我们希望通过使用机器学习流程实现的目标。是留住客户,还是通过自动化降低运营成本?
成功标准:我们必须定义清晰和可衡量的业务、机器学习(统计指标)和经济(KPI)成功指标。
可行性:我们需要确保数据可用性、机器学习应用程序的适用性、法律约束、稳健性、可扩展性、可解释性和资源需求。
数据收集:通过收集数据,对其进行版本控制以实现可重复性,并确保源源不断的真实数据和生成数据。
数据质量验证:通过维护数据描述、要求和验证来确保质量。
为了确保质量和可重复性,我们需要记录数据的统计属性和数据生成过程。
第二阶段很简单。我们将为建模阶段准备数据。这包括数据选择、数据清洗、特征工程、数据增强和规范化。
1. 我们从特征选择、数据选择以及通过过采样或欠采样来处理不平衡类入手。
2. 然后,专注于减少噪音和处理缺失值。出于质量保证的目的,我们将添加数据单元测试,以减少错误值。
3. 视模型而定,我们执行特征工程和数据增强,比如独热编码和聚类。
4. 规范化和扩展数据。这可降低特征有偏差的风险。
为了确保可重复性,我们创建了数据建模、转换和特征工程管道。
业务和数据理解阶段的约束和要求将决定建模阶段。我们需要了解业务问题以及我们将如何开发机器学习模型来解决这些问题。我们将专注于模型选择、优化和训练,将确保模型性能指标、稳健性、可扩展性、可解释性,并优化存储和计算资源。
1. 模型架构和类似业务问题方面的研究。
2. 定义模型性能指标。
3. 模型选择。
4. 通过整合专家来了解领域知识。
5. 模型训练。
6. 模型压缩和集成。
为确保质量和可重复性,我们将存储模型元数据并进行版本控制,比如模型架构、训练和验证数据、超参数以及环境描述。
最后,我们将跟踪ML试验,并创建ML管道,以创建可重复的训练流程。
这是我们测试并确保模型已准备好部署的阶段。
为了质量保证,评估阶段的每一步都被记录下来。
模型部署是我们将机器学习模型集成到现有系统中的阶段。该模型可以部署在服务器、浏览器、软件和边缘设备上。来自模型的预测可用于BI仪表板、API、Web应用程序和插件。
模型部署流程:
生产环境中的模型需要持续监控和维护。我们将监控模型时效性、硬件性能和软件性能。
持续监控是流程的第一部分;如果性能降到阈值以下,自动做出决定,针对新数据重新训练模型。此外,维护部分不仅限于模型的重新训练。它需要决策机制,获取新数据、更新软硬件以及根据业务用例改进ML流程。
简而言之,就是持续集成、训练和部署ML模型。
训练和验证模型是ML应用程序的一小部分。将最初的想法变成现实需要几个过程。我们在本文中介绍了CRISP-ML(Q) 以及它如何侧重风险评估和质量保证。
我们先定义业务目标、收集和清理数据、构建模型、拿测试数据集验证模型,然后将其部署到生产环境中。
该框架的关键组件是持续监控和维护。我们将监控数据和软硬件指标,以确定是重新训练模型还是升级系统。
如果您不熟悉机器学习操作,想了解更多信息,请阅读DataTalks.Club评述的免费MLOps课程。您将获得所有六个阶段的上手经验,了解CRISP-ML的实际实施。
原文标题:Making Sense of CRISP-ML(Q): The Machine Learning Lifecycle Process,作者:Abid Ali Awan
以上是解读CRISP-ML(Q):机器学习生命周期流程的详细内容。更多信息请关注PHP中文网其他相关文章!