在实际项目中,如何选择合适的机器学习模型
在这个文章中,我们主要面向初学者或中级数据分析师,他们对识别和应用机器学习算法都非常感兴趣,但是初学者在面对各种机器学习算法时,都会遇到一个问题是 “在实际项目中,我到底应该使用哪种算法呢?”。
这个问题的答案取决于许多的因素,其中包括:
数据的维度大小,数据的质量和数据的特征属性;
你可以利用的计算资源;
你所在的项目组对该项目的时间预计;
你手上的数据能应用在哪些项目中;
即使是一位经验丰富的数据科学家,在没有对数据尝试很多种不同的算法之前,他也不能确定哪一种算法在数据上面有更好的表现。但是,我们并不主张这种方式,一个一个算法去试验。
我们希望自己有一点先验知识,可以指导我们去如何选择算法模型,帮助我们少走一点弯路。
机器学习算法表
上面的机器学习算法表可以帮助我们如何去选择一个合适的机器学习算法,对于我们特定的项目问题。这篇文章,我们主要来讲讲如何去使用这个表格。
因为这个表格是为初学者所设定的,所以我们在讨论这些算法的时候,会做一些简化的假设工作。
这里所推荐的机器学习算法是由几位数据科学家,机器学习专家和算法开发人员所共同反馈总结的。随着后续的发展,我们会收集更加全的算法来更新这张表。
如何使用这种算法表
其实阅读这种算法表非常简单,我们可以采取 如果你想要进行,那么你可以使用这种模式来读取。比如:
有时候,我们可能会有很多的条件需要去匹配算法,但有时候可能我们连一条总结的规则都没有,以至于不能去利用这个算法表。其实,这是很正常的,因为这个算法表是我们凭借工程师的经验总结处理的,因此有一些规则并不是很准确。
我和几个好朋友一起讨论过这个问题,我们一直觉得寻找最好的算法的唯一路径可能就是去尝遍所有的算法。但是这种方法非常 “蠢”。
机器学习类型
这部分我们会介绍一些最流行的机器学习模型类型。如果你对这些类别比较熟悉,那么对你以后去选择机器学习模型是非常有利的。
监督学习
监督学习算法是基于一组标记数据进行预测的。
比如,历史销售数据可以来预测未来的销售价格。应用监督学习算法,我们需要一个包含标签的训练数据集。我们可以使用这个训练数据集去训练我们的模型,从而得到一个从输入数据到输出期望数据之间的映射函数。
这个模型的推断作用是从一个数据集中学习出一种模式,可以让这个模型适应新的数据,也就是说去预测一些没有看到过的数据。
分类:当数据被用于预测一个分类时,监督学习算法也可以称为是一种分类算法。比如,我们的一张图片可以被分类标记为狗或者猫。如果我们的分类标签只有两个类别,那么我们也把这个分类称之为二分类问题。当我们需要分类的东西超过两个类别的时候,这个模型就是一个多分类模型了。
回归:当我们预测的值是一个连续值时,这个问题就变成了一个回归问题。
预测:这是根据过去和现在的一些历史数据,来预测将来的数据。最常用的一个领域就是趋势分析。比如,我们可以根现在和过去几年的销售额来预测下一年的销售额。
监督学习带来的最大挑战是标注数据,这是一项非常耗时的工程而且非常昂贵。那么如果标签的数量有限,我们应该怎么办呢?我们可以使用一些非标记的数据来加强监督学习。
由于在这种情况下我们的机器学习算法不是完全的监督学习,所有我们把该算法称之为半监督学习算法。
在半监督学习中,我们可以使用未标记的数据和一小部分的标记数据来训练我们的模型,从而来提高我们模型的准确性。
无监督学习
在使用无监督学习的时候,我们所使用的数据都是不用进行标记的。我们的算法模型会自动的去发现数据内在的一些模式,比如聚类结构,层次结构,稀疏树和图等等。
聚类:将一组数据进行分组,使得一个组里面的数据跟别的组里面的数据是有一定的区别,也就是说每一个组即使一个聚类。这种方法经常被用来做数据切分,也就是把一个大的数据集先切割成几个小的数据集,而每一个小的数据集都是一个高度相似的数据集。这样可以帮助分析者从中更好的找到数据之间的内部结构。
降维:减少数据变量中的维度。在很多的应用中,原始数据都是非常高维度的特征,但是这些维度中很多的特征都是多余的,或者说跟任务的没有相关性。降低维度可以帮助我们更好的而发现真实数据之间潜在的内部关系。
强化学习是根据环境对智能体(agent)的反馈来分析和优化智能体的行为。智能体根据不同的场景会去尝试不同的动作,然后分析不同动作所会带来什么的回报,选取其中最大回报作为所采取的最终动作。
反复试错和奖励机制是强化学习和别的算法最不同的地方。
那么如何选择这些类别的算法呢?
当我们去选择一个算法的时候,总是会考虑到很多的方面,比如:模型准确率,训练时间,可扩展性等等。这其中,最重要的可能就是准确率,但是对于初学者而言,可能最重要的是他们的熟悉程度。如果他们对一个模型很熟悉,那么第一个尝试的往往就是这个模型。
当给定一个数据集的时候,我们首先想到的应该是如何快速的得到一个结果,也就是我们常说的 demo 算法。在这个过程中,我们首先关心的并不是算法结果的好坏,而是一整个算法在数据上面运行的流程。
初学者更加倾向于去选择一些容易实现的算法,并且可以快速得到结果。这样的工作节奏是非常好的,一旦你获得了一些结果并且熟悉了数据,你可能就会愿意花更多的时候去使用更加复杂的算法来理解这些数据,从而获得更好的结果。
即使我们到了这个阶段,最好的算法可能也不是那个获得最高准确率的算法,因为对于一个算法我们需要仔细的去调整参数和长时间训练才能得到一个算法模型的最佳性能。而上面我们只是去简单的运行了一下模型,得到一个结果而已。
选择算法时的注意事项
正确率
获得最准确的答案可能不总是最必要的。有时一个近似答案也是足够了,当然这取决于你想要如何去使用你自己的算法模型。如果是这种情况,你可以采用一个近似的方法来缩短你构建模型的时间。
这种近似的处理方式还有另一个优点,就是可以帮助我们一定程度上面避免过拟合。
训练时间
训练模型所需要的时间在不同算法之间是变化很大的,有些算法可能几分钟就可以训练完成,有些算法可能需要几个小时才能训练完成。训练时间往往与模型准确率是密切相关的,简单的说,可能训练时间越长,模型的准确率就越高。
另外,有些算法可能对数值离散点数据更加敏感,而有些可能对连续数据更加敏感。如果我们的数据集非常大,而且时间非常紧,那么根据模型的训练时间来选择算法是一条非常好的路径。
线性
很多的机器学习算法是可以利用线性模型来解决的。线性分类算法假设数据是可以利用一条直线来进行分裂的。
线性回归模型假设数据遵循一条直线划分,这些假设对于一些数据分析并不是一个很坏的假设,但是在某些方面,这些假设可能就会降低很多的准确率。
对于一些非线性边界 —— 依赖于线性分类模型就会降低很多的精度了。
有些数据可能无法简单的判断数据是线性的还是非线性的,但是在实际项目中很多的数据都会有一种非线性趋势,这也是我们使用线性回归方法产生比较大的误差的一个原因。
尽管线性模型存在很多的不好方面,但是他往往是最简单的算法,我们可以进行快速开发和试错。
模型参数
参数是机器学习模型中最重要的部分。比如,模型的迭代次数,模型的规模大小等等都会影响到最后我们需要得到的结果,对算法的训练时间和准确性都是非常敏感的。
通常,具有大量参数的算法都需要我们更多的实验和调参来找到一个最好的参数组合。
当然大型的参数组合也是具有很多好处的,比如算法的灵活性会更加的强大。通常,我们可以得到一个更加好的模型结果。
个别算法的精准使用
对于个别算法,我们需要认真仔细的研究它的 “脾气”,知道这些算法的输入数据特征是什么,算法具体描述是什么,他们是如何工作的额,以及他们的输出结果是代表什么含义。接下来,我们来学习几个例子。
线性回归是利用数理统计中回归分析,来确定两种或两种以上变量间相互依赖的定量关系的一种统计分析方法。预测值 y 与变量 X 之间的关系是:
其中训练数据集是:
参数向量 β 是我们需要模型学习的。
如果因变量不是连续的,而是离散分类的,那么线性回归就需要被转换成逻辑回归。逻辑回归是一种非常简单,但是非常强大的分类算法。因此,当我们讨论二分类问题时,可以把等式写成:
在逻辑回归中,我们使用不同的假设估计来区分属于类别 “1” 的概率和属于类别 “-1” 的概率。具体的说,我们尝试学习的函数是:
其中,
决策树和集成树
决策树,随机森林和梯度提升都是基于决策树实现的算法。决策树有很多种,但是所有的变种都只做一件事 —— 将特征标签细分到特定相同的区域里面。决策树是非常容易理解的,而且非常容易实现。
然而,当我们把树的深度做的很深的时候,模型就非常容易过拟合。这时候,采用随机森林和梯度提升算法可以获得良好的性能,这两种模型也是目前比较流行的方式。
神经网络是在 20 世纪 80 年代中期由于其并行和分布式的处理能力而兴起的。近年来,由于卷积神经网络,循环神经网络和一些无监督学习算法的兴起,图形处理单元(GPU)和大规模并行处理(MPP)等越来越强大的计算能力,使得神经网络再次得到了复兴。
换句话说,以前的浅层神经网络已经演变成了深层神经网络。深度神经网络在监督学习中取得了非常好的表现,比如语音识别和图像分类领域都获得了比人类好的正确率。在无监督领域,比如特征提取,深度学习也取得了很好的效果。
一般情况下,一个神经网络主要由三方面组成:输入层,隐藏层和输出层。训练数据定义了输入层和输出层的维度大小。当我们的输出层是一些分类标签的时候,那么那么我们整个模型所处理的就是一个分类问题。当输出层是一个连续变量的时候,那么我们的整个模型所处理的就是一个回归问题。当我们的输出层和输入层相同时,那么我们的这个模型所处理的可能是提取数据内部的特征。中间的隐藏层大小决定了整个模型的复杂性和建模能力。
总结
至此,我们已经学习了几个算法的精准使用。在我们实际的项目中,我们需要做到对自己所熟悉的个别算法灵活使用。具体的算法表,可以查看下面这个:
图中标记解释:● - 表示拥有卓越的精确度,快速训练时间和线性度 ;○ - 表示良好的准确性和适中的训练时间。参数字段中的数值越大表示模型需要的参数数量越多。
数据分析咨询请扫描二维码
在准备数据分析师面试时,掌握高频考题及其解答是应对面试的关键。为了帮助大家轻松上岸,以下是10个高频考题及其详细解析,外加 ...
2024-12-20互联网数据分析师是一个热门且综合性的职业,他们通过数据挖掘和分析,为企业的业务决策和运营优化提供强有力的支持。尤其在如今 ...
2024-12-20在现代商业环境中,数据分析师是不可或缺的角色。他们的工作不仅仅是对数据进行深入分析,更是协助企业从复杂的数据信息中提炼出 ...
2024-12-20随着大数据时代的到来,数据驱动的决策方式开始受到越来越多企业的青睐。近年来,数据分析在人力资源管理中正在扮演着至关重要的 ...
2024-12-20在数据分析的世界里,表面上的技术操作只是“入门票”,而真正的高手则需要打破一些“看不见的墙”。这些“隐形天花板”限制了数 ...
2024-12-19在数据分析领域,尽管行业前景广阔、岗位需求旺盛,但实际的工作难度却远超很多人的想象。很多新手初入数据分析岗位时,常常被各 ...
2024-12-19入门数据分析,许多人都会感到“难”,但这“难”究竟难在哪儿?对于新手而言,往往不是技术不行,而是思维方式、业务理解和实践 ...
2024-12-19在如今的行业动荡背景下,数据分析师的职业前景虽然面临一些挑战,但也充满了许多新的机会。随着技术的不断发展和多领域需求的提 ...
2024-12-19在信息爆炸的时代,数据分析师如同探险家,在浩瀚的数据海洋中寻觅有价值的宝藏。这不仅需要技术上的过硬实力,还需要一种艺术家 ...
2024-12-19在当今信息化社会,大数据已成为各行各业不可或缺的宝贵资源。大数据专业应运而生,旨在培养具备扎实理论基础和实践能力,能够应 ...
2024-12-19阿里P8、P9失业都找不到工作?是我们孤陋寡闻还是世界真的已经“癫”成这样了? 案例一:本硕都是 985,所学的专业也是当红专业 ...
2024-12-19CDA持证人Louis CDA持证人基本情况 我大学是在一个二线城市的一所普通二本院校读的,专业是旅游管理,非计算机非统计学。毕业之 ...
2024-12-18最近,知乎上有个很火的话题:“一个人为何会陷入社会底层”? 有人说,这个世界上只有一个分水岭,就是“羊水”;还有人说,一 ...
2024-12-18在这个数据驱动的时代,数据分析师的技能需求快速增长。掌握适当的编程语言不仅能增强分析能力,还能帮助分析师从海量数据中提取 ...
2024-12-17在当今信息爆炸的时代,数据分析已经成为许多行业中不可或缺的一部分。想要在这个领域脱颖而出,除了热情和毅力外,你还需要掌握 ...
2024-12-17数据分析,是一项通过科学方法处理数据以获取洞察并支持决策的艺术。无论是在商业环境中提升业绩,还是在科研领域推动创新,数据 ...
2024-12-17在数据分析领域,图表是我们表达数据故事的重要工具。它们不仅让数据变得更加直观,也帮助我们更好地理解数据中的趋势和模式。相 ...
2024-12-16在当今社会,我们身处着一个飞速发展、变化迅猛的时代。不同行业在科技进步、市场需求和政策支持的推动下蓬勃发展,呈现出令人瞩 ...
2024-12-16在现代商业世界中,数据分析师扮演着至关重要的角色。他们通过解析海量数据,为企业战略决策提供有力支持。要有效完成这项任务, ...
2024-12-16在当今数据爆炸的时代,数据分析师是组织中不可或缺的导航者。他们通过从大量数据中提取可操作的洞察力,帮助企业在竞争激烈的市 ...
2024-12-16