所有机器学习项目都适用的检查清单

2024-06-21 08:48

本文主要是介绍所有机器学习项目都适用的检查清单,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

点击上方“AI公园”,关注公众号,选择加“星标“或“置顶”


作者:Harshit Tyagi

编译:ronghuaiyang

导读

构建端到端机器学习项目的任务检查清单。

Image for post

我正在创建一系列[有价值的项目](https://towardsdatascience.com/howto -build-an- effective-dat-scienceportfoli-56d19b885aa8),我想到了将我从别人那里学到的或在工作中开发的实践记录下来。在本博客中,我整理了在处理端到端ML项目时经常提到的任务清单。

为什么我需要一个清单?

因为在一个项目中,你需要处理许多元素(争吵、准备、问题、模型、调优等等),所以很容易失去对事情的了解。

这个清单可以引导你完成接下来的步骤,并促使你检查每一个任务是否执行成功。

有时,我们很难找到起点,清单可以帮助你从正确的来源引出正确的信息(数据),以便建立关系并揭示相关的见解。

最好的做法是让项目的每个部分都经历检查。

正如Atul Gawande在他的书“The Checklist Manifesto”中所说,

我们所知道的东西的数量和复杂性已经超出了我们个人正确、安全或可靠地利用其优点的能力。

所以,让我带你过一遍这个简单的清单,它将减少你的工作量,提高你的产出……

机器学习项目检查清单

在几乎每个ML项目中,你都必须执行8-10个步骤。其中一些步骤可以顺序互换执行。

1. 从高层次上定义问题

这是为了理解和阐明问题的业务逻辑。它会告诉你:

  • 问题的性质(监督/非监督,分类/回归),

  • 你可以开发的解决方案类型

  • 你应该用什么标准来衡量表现?

  • 机器学习是解决这个问题的正确方法吗?

  • 手动解决问题的方法。

  • 问题的固有假设

2. 确认数据来源并获取数据

在大多数情况下,如果你有了数据,并且希望围绕数据定义问题以更好地使用传入的数据,那么可以在第一步之前执行此步骤。

根据问题的定义,需要确定数据源,可以是数据库、数据存储库、传感器等。对于要部署在生产环境中的应用,应该通过开发数据管道来实现这一步的自动化,以保持传入的数据流入系统。

  • 列出你需要的数据的来源和数量。

  • 检查存储空间是否会成为一个问题。

  • 检查你是否被授权为你的目的使用数据。

  • 获取数据,并将其转换为可行的格式。

  • 检查数据类型(文本、类别、数字、时间序列、图像)

  • 取出一份样品作最终测试之用。

3. 初始的数据探索

在这一步中,你需要研究影响你的结果/预测/目标的所有特征。如果你有一个巨大的数据块,在此步骤中对其进行采样,以使分析更易于管理。步骤:

  • 使用jupyter notebooks,因为它们提供了一个简单和直观的界面,以研究数据。

  • 确定目标变量

  • 识别特征的类型(类别、数字、文本等)

  • 分析特征之间的相关性。

  • 添加一些数据可视化,方便解释每个特征对目标变量的影响。

  • 记录你的发现。

4. 进行数据探索分析来准备数据

现在可以通过定义用于数据转换、清洗、特征选择/特征工程和缩放的函数来执行前一步的发现了。

  • 编写函数转换数据和自动化处理即将到来的批数据。

  • 编写函数来清洗数据(输入缺失值和处理异常值)

  • 编写函数来选择特征和特征工程 —— 删除冗余的特征,特征格式转换,以及其他的数学变换。

  • 特征缩放 —— 特征标准化。

5. 开发一个基线模型,然后探索其他模型,选出最好的模型

创建一个非常基本的模型,作为所有其他复杂机器学习模型的基线。检查表的步骤:

  • 使用默认参数训练一些常用的ML模型,如朴素贝叶斯、线性回归、支持向量机等。

  • 度量和比较每个模型与基线以及其他模型的性能。

  • 对每个模型采用N-fold交叉验证,并计算N fold上的性能指标的平均值和标准偏差。

  • 研究对目标有最大影响的特征。

  • 分析模型在预测时出现的误差类型。

  • 以不同的方式设计特征。

  • 重复以上步骤几次(反复试验),以确保我们在正确的格式中使用了正确的特征。

  • 基于他们的度量表现选择最好的几个模型入围。

6. 调优你的入围模型并检查集成方法

这需要成为你接近最终解决方案的关键步骤之一。主要步骤应包括:

  • 使用交叉验证超参数调优。

  • 使用自动调优方法,如随机搜索或网格搜索,以找出你的最佳模型的最佳配置。

  • 测试集成方法,如投票分类器等

  • 用尽可能多的数据测试模型。

  • 一旦定稿,使用我们在开始时预留的没有见过的测试样本,检查是否过拟合或欠拟合。

7. 记录代码并交流解决方案

交流的过程是多方面的。你需要记住所有现有的和潜在的相关因素。因此,主要步骤包括:

  • 记录代码以及你的方法和整个项目过程。

  • 创建一个像voila一样的仪表盘或一个有洞察力的演示,接近自我解释的可视化。

  • 写一篇博客/报告,记录你是如何分析特征,测试不同的变换等等。

  • 获得你学到的东西(失败和有效的技术)

  • 总结主要成果及未来范围(如有)

8. 将模型部署到生产环境中,监控!

如果你的项目需要在实时数据上测试部署,那么你应该创建一个跨所有平台(web、android、iOS)使用的web应用或REST API。主要步骤(视乎项目而定)包括:

  • 保存你的最终训练模型到一个h5或pickle文件。

  • 使用web服务服务你的模型,你可以使用Flask来开发这些web服务。

  • 连接输入数据源,设置ETL管道。

  • 使用pipenv、docker/Kubernetes管理依赖关系(基于扩展性需求)

  • 你可以使用AWS、Azure或谷歌云平台部署您的服务。

  • 监控实时数据的性能或简单地让人们用他们的数据来使用你的模型。

注意:检查表可以根据项目的复杂程度进行调整

—END—

英文原文:https://towardsdatascience.com/task-cheatsheet-for-almost-every-machine-learning-project-d0946861c6d0

请长按或扫描二维码关注本公众号

喜欢的话,请给我个好看吧

这篇关于所有机器学习项目都适用的检查清单的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

《SpringBoot项目使用MDC给日志增加唯一标识的实现步骤》本文介绍了如何在SpringBoot项目中使用MDC(MappedDiagnosticContext)为日志增加唯一标识,以便于日... 目录【Java】SpringBoot项目使用MDC给日志增加唯一标识,方便日志追踪1.日志效果2.实现步

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法

《SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法》本文主要介绍了SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录方法1:更改IDE配置方法2:在Eclipse中清理项目方法3:使用Maven命令行在开发Sprin