Python机器学习—算法总结

作者:风信子AI 时间:2024-01-10 阅读:2644

机器学习算法太多了,分类、回归、聚类、推荐、图像识别领域等等,要想找到一个合适算法真的不容易,所以在实际应用中,我们一般都是采用启发式学习方式来实验。通常最开始我们都会选择大家普遍认同的算法,诸如SVM,GBDT,Adaboost,现在深度学习很火热,神经网络也是一个不错的选择。假如你在乎精度(accuracy)的话,最好的方法就是通过交叉验证(cross-validation)对各个算法一个个地进行测试,进行比较,然后调整参数确保每个算法达到最优解,最后选择最好的一个。但是如果你只是在寻找一个足够好的算法来解决你的问题,或者这里有些技巧可以参考,下面来分析下各个算法的优缺点,基于算法的优缺点,更易于我们去选择它。

偏差&方差

在统计学中,一个模型好坏,是根据偏差和方差来衡量的,所以我们先来普及一下偏差和方差:

从一个训练集中随机选取一部分样本进行训练得到一个模型。重复上面的工作,得到k个模型。


Python机器学习—算法总结


Python机器学习—算法总结


如果是小训练集,高偏差/低方差的分类器(例如,朴素贝叶斯NB)要比低偏差/高方差大分类的优势大(例如,KNN),因为后者会过拟合。但是,随着你训练集的增长,模型对于原数据的预测能力就越好,偏差就会降低,此时低偏差/高方差分类器就会渐渐的表现其优势(因为它们有较低的渐近误差),此时高偏差分类器此时已经不足以提供准确的模型了。

从上面的过程我们可以理解,从不同采样数据集进行模型训练,结果越相似越好,也就是说模型对不同的数据集不敏感,那么对于待测数据也会同等对待,也就不容易过拟合。

偏差 (bias) 定义为:为模型的期望预测与真实值之间的差异。

方差 (variance) 定义为衡量模型对不同数据集D的敏感程度,也可以认为是衡量模型的不稳定性。若方差大,则表示数据的微小变动就能导致学习出的模型产生较大差异。可能的情形是在训练集上拟合的很好,到了测试集上由于数据的改变致使准确率下降很多,这是典型的过拟合。

为什么bagging类集成学习能降低过拟合?


Python机器学习—算法总结

偏差方差的感性认识

Python机器学习—算法总结

当然,你也可以认为这是生成模型(NB)与判别模型(KNN)的一个区别。

为什么说朴素贝叶斯是高偏差低方差?

以下内容引自知乎:

首先,假设你知道训练集和测试集的关系。简单来讲是我们要在训练集上学习一个模型,然后拿到测试集去用,效果好不好要根据测试集的错误率来衡量。但很多时候,我们只能假设测试集和训练集的是符合同一个数据分布的,但却拿不到真正的测试数据。这时候怎么在只看到训练错误率的情况下,去衡量测试错误率呢?

由于训练样本很少(至少不足够多),所以通过训练集得到的模型,总不是真正正确的。(就算在训练集上正确率100%,也不能说明它刻画了真实的数据分布,要知道刻画真实的数据分布才是我们的目的,而不是只刻画训练集的有限的数据点)。而且,实际中,训练样本往往还有一定的噪音误差,所以如果太追求在训练集上的完美而采用一个很复杂的模型,会使得模型把训练集里面的误差都当成了真实的数据分布特征,从而得到错误的数据分布估计。这样的话,到了真正的测试集上就错的一塌糊涂了(这种现象叫过拟合)。但是也不能用太简单的模型,否则在数据分布比较复杂的时候,模型就不足以刻画数据分布了(体现为连在训练集上的错误率都很高,这种现象较欠拟合)。过拟合表明采用的模型比真实的数据分布更复杂,而欠拟合表示采用的模型比真实的数据分布要简单。

在统计学习框架下,大家刻画模型复杂度的时候,有这么个观点,认为Error = Bias + Variance。这里的Error大概可以理解为模型的预测错误率,是有两部分组成的,一部分是由于模型太简单而带来的估计不准确的部分(Bias),另一部分是由于模型太复杂而带来的更大的变化空间和不确定性(Variance)。

所以,这样就容易分析朴素贝叶斯了。它简单的假设了各个数据之间是无关的,是一个被严重简化了的模型。所以,对于这样一个简单模型,大部分场合都会Bias部分大于Variance部分,也就是说高偏差而低方差。

在实际中,为了让Error尽量小,我们在选择模型的时候需要平衡Bias和Variance所占的比例,也就是平衡over-fitting和under-fitting。

Python机器学习—算法总结

当模型复杂度上升的时候,偏差会逐渐变小,而方差会逐渐变大。

常见算法优缺点

1.朴素贝叶斯

朴素贝叶斯属于生成式模型(关于生成模型和判别式模型,主要还是在于是否是要求联合分布),非常简单,你只是做了一堆计数。如果注有条件独立性假设(一个比较严格的条件),朴素贝叶斯分类器的收敛速度将快于判别模型,如逻辑回归,所以你只需要较少的训练数据即可。即使NB条件独立假设不成立,NB分类器在实践中仍然表现的很出色。它的主要缺点是它不能学习特征间的相互作用,用mRMR中R来讲,就是特征冗余。引用一个比较经典的例子,比如,虽然你喜欢Brad Pitt和Tom Cruise的电影,但是它不能学习出你不喜欢他们在一起演的电影。

优点:

缺点:

2.Logistic Regression(逻辑回归)

属于判别式模型,有很多正则化模型的方法(L0, L1,L2,etc),而且你不必像在用朴素贝叶斯那样担心你的特征是否相关。与决策树与SVM机相比,你还会得到一个不错的概率解释,你甚至可以轻松地利用新数据来更新模型(使用在线梯度下降算法,online gradient descent)。如果你需要一个概率架构(比如,简单地调节分类阈值,指明不确定性,或者是要获得置信区间),或者你希望以后将更多的训练数据快速整合到模型中去,那么使用它吧。

Sigmoid函数:


g(x)=11+exp(−x)g(x)=11+exp(−x)


优点

缺点

3.线性回归

线性回归是用于回归的,而不像Logistic回归是用于分类,其基本思想是用梯度下降法对最小二乘法形式的误差函数进行优化,当然也可以用normal equation直接求得参数的解,结果为:

而在LWLR(局部加权线性回归)中,参数的计算表达式为:

由此可见LWLR与LR不同,LWLR是一个非参数模型,因为每次进行回归计算都要遍历训练样本至少一次。

优点: 实现简单,计算简单;

缺点: 不能拟合非线性数据.

4.最近邻算法KNN

KNN即最近邻算法,其主要过程为:

计算训练样本和测试样本中每个样本点的距离(常见的距离度量有欧式距离,马氏距离等); 2. 对上面所有的距离值进行排序; 3. 选前k个最小距离的样本; 4. 根据这k个样本的标签进行投票,得到最后的分类类别;

如何选择一个最佳的K值,这取决于数据。一般情况下,在分类时较大的K值能够减小噪声的影响。但会使类别之间的界限变得模糊。一个较好的K值可通过各种启发式技术来获取,比如,交叉验证。另外噪声和非相关性特征向量的存在会使K近邻算法的准确性减小。

近邻算法具有较强的一致性结果。随着数据趋于无限,算法保证错误率不会超过贝叶斯算法错误率的两倍。对于一些好的K值,K近邻保证错误率不会超过贝叶斯理论误差率。

KNN算法的优点

缺点

5.决策树

易于解释。它可以毫无压力地处理特征间的交互关系并且是非参数化的,因此你不必担心异常值或者数据是否线性可分(举个例子,决策树能轻松处理好类别A在某个特征维度x的末端,类别B在中间,然后类别A又出现在特征维度x前端的情况)。它的缺点之一就是不支持在线学习,于是在新样本到来后,决策树需要全部重建。另一个缺点就是容易出现过拟合,但这也就是诸如随机森林RF(或提升树boosted tree)之类的集成方法的切入点。另外,随机森林经常是很多分类问题的赢家(通常比支持向量机好上那么一丁点),它训练快速并且可调,同时你无须担心要像支持向量机那样调一大堆参数,所以在以前都一直很受欢迎。

决策树中很重要的一点就是选择一个属性进行分枝,因此要注意一下信息增益的计算公式,并深入理解它。

信息熵的计算公式如下:


Python机器学习—算法总结


其中的n代表有n个分类类别(比如假设是2类问题,那么n=2)。分别计算这2类样本在总样本中出现的概率p1和p2,这样就可以计算出未选中属性分枝前的信息熵。

现在选中一个属性xixi用来进行分枝,此时分枝规则是:如果xi=vxi=v的话,将样本分到树的一个分支;如果不相等则进入另一个分支。很显然,分支中的样本很有可能包括2个类别,分别计算这2个分支的熵H1和H2,计算出分枝后的总信息熵H=p1H1+p2H2,则此时的信息增益ΔH=H−H。以信息增益为原则,把所有的属性都测试一边,选择一个使增益最大的属性作为本次分枝属性。

决策树自身的优点

缺点

5.1 Adaboosting

Adaboost是一种加和模型,每个模型都是基于上一次模型的错误率来建立的,过分关注分错的样本,而对正确分类的样本减少关注度,逐次迭代之后,可以得到一个相对较好的模型。是一种典型的boosting算法。下面是总结下它的优缺点。

优点

缺点:

5.2 xgboost

这是一个近年来出现在各大比赛的大杀器,夺冠选手很大部分都使用了它。

高准确率高效率高并发,支持自定义损失函数,既可以用来分类又可以用来回归

可以像随机森林一样输出特征重要性,因为速度快,适合作为高维特征选择的一大利器

在目标函数中加入正则项,控制了模型的复杂程度,可以避免过拟合

支持列抽样,也就是随机选择特征,增强了模型的稳定性

对缺失值不敏感,可以学习到包含缺失值的特征的分裂方向

另外一个广受欢迎的原因是支持并行,速度杠杠的

用的好,你会发现他的全部都是优点

6.SVM支持向量机

高准确率,为避免过拟合提供了很好的理论保证,而且就算数据在原特征空间线性不可分,只要给个合适的核函数,它就能运行得很好。在动辄超高维的文本分类问题中特别受欢迎。可惜内存消耗大,难以解释,运行和调参也有些烦人,而随机森林却刚好避开了这些缺点,比较实用。

优点

缺点

7. 人工神经网络的优缺点

人工神经网络的优点:

人工神经网络的缺点:

8、K-Means聚类

关于K-Means聚类的文章,链接:机器学习算法-K-means聚类。关于K-Means的推导,里面有着很强大的EM思想。

优点

算法选择参考

之前翻译过一些国外的文章,有一篇文章中给出了一个简单的算法选择技巧:

首当其冲应该选择的就是逻辑回归,如果它的效果不怎么样,那么可以将它的结果作为基准来参考,在基础上与其他算法进行比较;

然后试试决策树(随机森林)看看是否可以大幅度提升你的模型性能。即便最后你并没有把它当做为最终模型,你也可以使用随机森林来移除噪声变量,做特征选择;

如果特征的数量和观测样本特别多,那么当资源和时间充足时(这个前提很重要),使用SVM不失为一种选择。

通常情况下:【XGBOOST>=GBDT>=SVM>=RF>=Adaboost>=Other】,现在深度学习很热门,很多领域都用到,它是以神经网络为基础的,目前我自己也在学习,只是理论知识不是很厚实,理解的不够深,这里就不做介绍了。

算法固然重要,但好的数据却要优于好的算法,设计优良特征是大有裨益的。假如你有一个超大数据集,那么无论你使用哪种算法可能对分类性能都没太大影响(此时就可以根据速度和易用性来进行抉择)

上一篇:瓷砖的贴法教学视频(瓷砖美缝一般什么时候

下一篇:厨房门口两边柜子图(冰箱放在进厨房的门边

猜你喜欢

室内涂料哪个品牌(普罗蒙蒂艺术漆属于几线品牌)

室内涂料哪个品牌(普罗蒙蒂艺术漆属于几线品牌)

资讯 2023-11-03 1832
老挝大红酸枝收藏价值(老挝大红酸枝中老料到底有什么好处)

老挝大红酸枝收藏价值(老挝大红酸枝中老料到底有什么好处)

知识 2023-11-05 4098
取暖器哪个牌子好用节能型(加热器哪种好用又省电)

取暖器哪个牌子好用节能型(加热器哪种好用又省电)

资讯 2023-11-05 2187
海尔整体厨房加盟店选址(海尔集团的子公司都有哪些)

海尔整体厨房加盟店选址(海尔集团的子公司都有哪些)

资讯 2023-11-06 821
精品酒店设计标准(芒市设计公司有做精品酒店比较擅长的吗)

精品酒店设计标准(芒市设计公司有做精品酒店比较擅长的吗)

知识 2023-11-08 3481
别墅外墙砖品牌十大排名(中国地板砖品牌排行榜前二十名)

别墅外墙砖品牌十大排名(中国地板砖品牌排行榜前二十名)

知识 2023-11-12 2116
万事兴电器是几线品牌(发生过哪些令人尴尬的事)

万事兴电器是几线品牌(发生过哪些令人尴尬的事)

知识 2023-11-15 4104
装潢设计专业需要艺考吗(学美术的就业前景好吗)

装潢设计专业需要艺考吗(学美术的就业前景好吗)

知识 2023-11-16 441
幼儿园六一环境布置图片(幼儿园怎么过六一比较有仪式感)

幼儿园六一环境布置图片(幼儿园怎么过六一比较有仪式感)

资讯 2023-11-18 3204
焊条种类及型号(焊条型号要怎么选)

焊条种类及型号(焊条型号要怎么选)

知识 2023-11-18 3138
室内客厅设计手绘图片大全(客厅山水画是手绘好还是印刷好)

室内客厅设计手绘图片大全(客厅山水画是手绘好还是印刷好)

知识 2023-11-22 162
三菱空调故障码大全(三菱电机挂机空调错误代码怎么查)

三菱空调故障码大全(三菱电机挂机空调错误代码怎么查)

资讯 2023-11-25 4531
大宝漆墙面漆(大宝牌乳胶漆好不好用)

大宝漆墙面漆(大宝牌乳胶漆好不好用)

知识 2023-12-17 2874
中式沙发不要主人位 只是放两边放(中式沙发座垫什么色好看)

中式沙发不要主人位 只是放两边放(中式沙发座垫什么色好看)

资讯 2024-01-06 3363
露天花园装修效果图(家里的大露台怎样装修)

露天花园装修效果图(家里的大露台怎样装修)

资讯 2024-01-20 4912
关于锌钢阳台护栏安装知识你了解多少?

关于锌钢阳台护栏安装知识你了解多少?

知识 2024-01-22 4724
附近木板(木板与墙体连接处开裂怎么办)

附近木板(木板与墙体连接处开裂怎么办)

资讯 2024-01-25 2252
雅洁五金密码锁(家居五金十大品牌有哪些)

雅洁五金密码锁(家居五金十大品牌有哪些)

知识 2024-02-18 757
中美俄卫星数量对比:美国5534颗,俄罗斯1555颗,中国是多少呢?

中美俄卫星数量对比:美国5534颗,俄罗斯1555颗,中国是多少呢?

知识 2024-02-23 2291
洗脸盆水龙头规格(水龙头入水口尺寸)

洗脸盆水龙头规格(水龙头入水口尺寸)

知识 2024-03-09 756