#Datawhale X 李宏毅苹果书 AI夏令营#2.实践方法论

2024-08-30 16:36

本文主要是介绍#Datawhale X 李宏毅苹果书 AI夏令营#2.实践方法论,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2.实践方法论

概览:

  • 在应用机器学习算法时,实践方法论能够帮助我们更好地训练模型。
  • 如果在Kaggle上的结果不佳,首先应检查训练数据的损失,确认模型是否在训练集上表现良好。

2.1模型偏差

模型偏差可能会影响模型训练。

  • 定义:当模型过于简单,无法捕获数据中的复杂模式时,会发生模型偏差。
  • 示例:假设模型仅能表示一组有限的函数,可以让损失变低的函数不在模 型可以描述的范围内。
  • 解决方案:重新设计一个模型,给模型更大的灵活性。
    • 增加输入特征数量,使用更多的特征。
    • 使用深度学习(更多神经元、层)来提高模型的灵活性。

2.2优化问题

一般只会用到梯度下降进行优化,这种优化的方法很多的问题。

  • 定义:即使模型具有足够的灵活性,也可能因为优化方法(如梯度下降)的问题而未能找到最优解。
  • 示例:优化过程卡在局部最小值的地方。
  • 解决方案
    • 通过比较不同的模型来判断模型现在到底够不够大。比如残差网络的例子,56层的损失比20层高,因为56层网络的优化没有做好。
    • 可以先训练一些比较浅的模型,或者是一些比较简单的模型,先知道这些简单的模型,到底可以得到什么样的损失。
    • 如果深的模型跟浅的模型比起来,深的模型明明灵活性比较 大,但损失却没有办法比浅的模型压得更低代表说优化有问题,梯度下降不给力。
    • 如果更深的网络性能没有提升,则表明可能存在优化问题。

2.3过拟合

为什么会有过拟合这样的情况呢?过拟合如何解决呢?

  • 定义:模型在训练数据上表现极佳,但在未见过的数据(测试数据)上表现较差的现象。
  • 原因:模型过度适应训练数据,学习到了噪声而非潜在的规律。
  • 解决方案
    • 增加训练数据:收集更多的训练样本或使用数据增强技术。
    • 限制模型复杂度
      • 给模型比较少的参数。如果深度学习,给他比较少的神经元的数量;,或者让模型共用参数。
      • 用比较少的特征。
      • 应用正则化、早停或丢弃法等技术。

模型复杂度的平衡:可以选一个中庸的模型,不是太复杂的,也不是太简单的,刚刚好可以在训练集上损失最低,测试损失最低。

2.4交叉验证

比较合理选择模型的方法是把训练的数据分成两半,一部分称为训练集(training set), 一部分是验证集(validation set)。

  • 目的:交叉验证是一种评估模型泛化能力的方法,用于选择最佳模型。
  • 流程
    • 将数据集分为训练集和验证集,通常比例为90%和10%。
    • 使用训练集训练模型,并使用验证集评估模型性能。
    • 根据验证集上的性能挑选模型,然后将最终选定的模型应用于整个训练集进行训练。
  • k折交叉验证(k-fold cross validation)
    • 将训练集切成k等份。
    • 重复k次,每次将其中一个折用作验证集,其余k-1个折用作训练集。
    • 计算每个模型在所有k次验证上的平均性能,选择平均性能最佳的模型。
  • 优点
    • 减少了验证集随机划分的影响。
    • 更充分地利用了数据集中的样本。

2.5不匹配

  • 定义:不匹配是指训练集和测试集之间的数据分布差异。
  • 示例
    • 使用2020年的数据作为训练集,2021年的数据作为测试集,不匹配问题可能很严重。
    • 数据背后的基础分布发生了变化,导致模型预测效果不佳。
  • 案例分析
    • 模型预测2021年2月26日的观看人数,但实际结果与预测相差甚远。
    • 模型基于过去的数据预测周五晚上观看人数较低,但实际情况相反。
  • 解决方案
    • 需要理解数据本身的生成方式,识别分布变化的原因。
    • 收集更多数据通常不能解决不匹配问题。

喜欢的小伙伴点赞收藏关注吧。

这篇关于#Datawhale X 李宏毅苹果书 AI夏令营#2.实践方法论的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121351

相关文章

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Springboot整合Redis主从实践

《Springboot整合Redis主从实践》:本文主要介绍Springboot整合Redis主从的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言原配置现配置测试LettuceConnectionFactory.setShareNativeConnect

java中Optional的核心用法和最佳实践

《java中Optional的核心用法和最佳实践》Java8中Optional用于处理可能为null的值,减少空指针异常,:本文主要介绍java中Optional核心用法和最佳实践的相关资料,文中... 目录前言1. 创建 Optional 对象1.1 常规创建方式2. 访问 Optional 中的值2.1

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

Mybatis嵌套子查询动态SQL编写实践

《Mybatis嵌套子查询动态SQL编写实践》:本文主要介绍Mybatis嵌套子查询动态SQL编写方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、实体类1、主类2、子类二、Mapper三、XML四、详解总结前言MyBATis的xml文件编写动态SQL

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事