全国免费咨询:

13245491521

VR图标白色 VR图标黑色
X

中高端软件定制开发服务商

与我们取得联系

13245491521     13245491521

2018-11-17_不知道如何提升深度学习性能?我们为你整理了这份速查清单

您的位置:首页 >> 新闻 >> 行业资讯

不知道如何提升深度学习性能?我们为你整理了这份速查清单 作者 | Christopher Dossman 译者 | 姚佳灵 编辑 | Vincent AI 前线导读:我被问到最多的问题是“我如何获得更高的精度?”。机器学习工程师,无论是新手还是有经验的,都会问这个问题。 因为对业务来讲,机器学习最有价值的地方通常是它的预测能力,所以这个问题很有意义。提高预测精度是从现有系统中榨取更多价值的简单方法。 本指南将分成 4 个不同的部分,每个部分都包含一些策略。 - 数据优化(Data Optimization) - 算法调整(Algorithm tuning) - 超参数优化(Hyper-Parameter Optimization) - 合并,合并还是合并(Ensembles, Ensembles, Ensembles) 并非所有这些想法都可以提升性能,越把它们应用到同样的问题上,就越能看到有限的效果。如果尝试了它们中的一些还是没有起色?那就表明,应该重新考虑一下业务问题的核心解决方案了。本文只是一张速查单,因此,在每个部分,我都会给出更详细资源的链接。 更多优质内容请关注微信公众号“AI 前线”(ID:ai-front) 数据优化 平衡数据集(Balance your data set) 如果是分类问题,那么,提高表现不佳的深度学习模型性能的最简单方法之一是平衡数据集。真实世界的数据集通常是不平衡的,如果希望有最好的精度,那么深度学习系统要学习如何在两个类之间根据特征而不是通过复制它的分布进行选择。 常用方法包括: 二次采样多数类(Subsample Majority Class):可以通过对多数类进行二次采样来平衡类分布。 过度采样少数类(Oversample Minority Class):可以使用替换采样来提高少数类的比例。 这里有篇好文章,它详细介绍了处理这个问题的更多细节: http://amsantac.co/blog/en/2016/09/20/balanced-image-classification-r.html 更多数据 我们中的许多人都熟悉这张图。它显示了深度学习和分类机器学习方法中数据的数量和性能之间的关系。如果你不知道这个,那么试试这个清晰明了的课程。如果想要模型有更好的性能,就需要有更多数据。这取决于可以选择的预算以创建更多标签数据或收集更多没有标签的数据,并更多地训练特征提取子模型。 开源标签软件 图像(Images): https://github.com/Labelbox/Labelbox 音频(Audio): http://www.fon.hum.uva.nl/praat/ 视频(Video): http://www.anvil-software.org/ 生成更多数据 或者假装一下,直到成功。用于提高精度一个常被忽视的方法是,从已有的数据中创建新数据。以照片为例,工程师常常通过旋转和随机移动现有图像来创建更多图片。这种变换还增加了训练集的减弱过度拟合。 这里有一个创建更多数据的绝佳资源,可以用于图像问题: https://medium.com/nanonets/how-to-use-deep-learning-when-you-have-limited-data-part-2-data-augmentation-c26971dc8ced 算法调整 复制研究人员的方法 你是否正在研究一个问题,而该问题的背后有很多研究?如果是的,那么你很走运,因为可能有很多工程师已经考虑过如何为该问题获取更好的精度。读读跟这个主题有关的研究论文并注意他们用来解决问题的不同方法!甚至,他们或许已经在 GitHub 上发布了代码,而这些代码让你爱不释手。 谷歌学术搜索(Google Scholar)是开始进行搜索的绝佳地方。他们还提供很多工具帮助你寻找相关的研究。 我使用 Mendeley 来存储和组织研究论文。 算法抽查你不是失败者,你只是还没成功。无法知道哪个机器学习算法最适合用来解决问题。每当我碰到新问题时,如果新问题背后没有很多研究方法,那么我会看看一些可用的方法,并全部试上一遍。 深度学习(CNN、RNN 等等)和经典机器学习方法(随机森林、梯度提升等等)。 对所有试验结果进行排序,然后对表现最佳的算法进行加倍。 查看数据驱动方法来选择机器学习算法: https://machinelearningmastery.com/a-data-driven-approach-to-machine-learning/ 超参数优化 学习速率(Learning rates) 亚当优化算法(the Adam optimization algorithm)是经过验证的。它在所有的深度学习问题常常有令人惊讶的结果。即使它有出色的性能,但是它仍然会让你深陷局部最小问题的迷津。具有亚当优化算法的好处,并有助于消除陷入局部最小问题迷津的一个更好的算法是热重启的随机梯度下降法(Stochastic Gradient Descent with Warm Restarts)。 关于学习速率的好文章在这里: https://towardsdatascience.com/estimating-optimal-learning-rate-for-a-deep-neural-network-ce32f2556ce0 批(batch)的大小和期(epoch)的数量 标准程序使用具有大量的期的大型批来处理现代深度学习实施,但是共同的策略产生共同的结果。用你的批大小和训练期的数量来做试验。 提前停止(Early Stopping) 这是减少深度学习系统泛化错误的绝佳方法。持续训练也许会提高数据集上的精度,但是到了某一时刻,在模型尚未观察到的数据上的模型精度就会降低。为了提高真实世界的性能,试试提前停止。 提前停止的示例: https://stats.stackexchange.com/questions/231061/how-to-use-early-stopping-properly-for-training-deep-neural-network 网络架构(Network Architecture) 如果想试试一些更有趣的东西,那就试试高效的神经架构搜索(Efficient Neural Architecture Search ,简称 ENAS)。该算法将创建一个自定义网络设计,在数据集上把精度最大化,比起云机器学习用到的标准神经架构搜索更高效。 正则化(Regularization) 停止过度拟合的有效方法是使用正则化。有很多不同方法来使用正则化,可以在深度学习项目上训练。如果还没有尝试过这些方法,那么我建议在每个项目中都试试。 Dropout:在训练期间中,它们随机关闭一定比例的神经元。Dropout 有助于防止神经元组对自己的过度拟合。 权重损失 L1 和 L2(Weight penalty L1 and L2):权重在大小上失控是深度学习中的真正问题,并会降低精度。其中的一个解决方法是给所有权重添加衰减。 这些尝试保持在网络中的所有权重尽可能小,除非有大的梯度可以抵消它。除了经常提高性能之外,它还有易于理解模型的好处。 合并,合并还是合并 无法选择最好的模型来用?通常,可以把不同模型的输出组合一下,获得更好的精度。这些算法中的每一个都有两个步骤。 在原始数据的子集上生成简单机器学习模型的分布 把该分布合并成一个“聚合”模型 合并模型 / 视图(Bagging) 在这种方法中,可以在同样的数据上训练一些不同的模型,这些模型在某种程度上有所不同,然后把这些输出平均一下以创建最终输出。Bagging 可以减少模型中的变化。可以直观地把它看作具有不同背景的人对同一个问题进行思考,但是这些人具有不同的起始位置。就像在团队中一样,可以成为获得正确答案的有力工具。 堆积(Stacking) 这类似于 bagging,区别是没有经验公式来计算合并的输出。可以创建基于输入数据的元级学习器,选择如何给来自不同模型的结果赋予权重,以产生最终输出。 还有问题? 重构问题 休息一下吧。这个方案是从头开始重新考虑问题。我发现这有助于集思广益来解决问题。可以从问问自己这些简单问题开始: 分类问题是回归问题还是相反? 可以把问题分解成更小的问题吗? 有没有收集有关数据的观察结果,而这些结果可能改变问题的范围? 二进制输出是否可以变成 softmax 输出,还是相反? 是否在用最有效的方式来看待这个问题? 重新考虑问题是提高性能最难的方法,但是,它常常会产生最好的结果。和其他有深度学习经验的人聊聊,有助于找到解决问题的新方法。 阅读英文原文: https://towardsdatascience.com/deep-learning-performance-cheat-sheet-21374b9c4f45 如果你喜欢这篇文章,或希望看到更多类似优质报道,记得给我留言和点赞哦! 阅读原文

上一篇:2023-11-30_又一场AI“宫斗”要上演?盈利困难、投资人开撕CEO,Stable Diffusion背后公司被曝正寻求收购 下一篇:2021-10-25_开发人员将大多数时间花到了探究系统本身上

TAG标签:

16
网站开发网络凭借多年的网站建设经验,坚持以“帮助中小企业实现网络营销化”为宗旨,累计为4000多家客户提供品质建站服务,得到了客户的一致好评。如果您有网站建设网站改版域名注册主机空间手机网站建设网站备案等方面的需求...
请立即点击咨询我们或拨打咨询热线:13245491521 13245491521 ,我们会详细为你一一解答你心中的疑难。
项目经理在线

相关阅读 更多>>

猜您喜欢更多>>

我们已经准备好了,你呢?
2022我们与您携手共赢,为您的企业营销保驾护航!

不达标就退款

高性价比建站

免费网站代备案

1对1原创设计服务

7×24小时售后支持

 

全国免费咨询:

13245491521

业务咨询:13245491521 / 13245491521

节假值班:13245491521()

联系地址:

Copyright © 2019-2025      ICP备案:沪ICP备19027192号-6 法律顾问:律师XXX支持

在线
客服

技术在线服务时间:9:00-20:00

在网站开发,您对接的直接是技术员,而非客服传话!

电话
咨询

13245491521
7*24小时客服热线

13245491521
项目经理手机

微信
咨询

加微信获取报价