1决策树(Decision Trees)的优缺点

  • 决策树的优点:

一、 决策树易于理解和解释.人们在通过解释后都有能力去理解决策树所表达的意义。
二、 对于决策树,数据的准备往往是简单或者是不必要的.其他的技术往往要求先把数据一般化,比如去掉多余的或者空白的属性。
三、 能够同时处理数据型和常规型属性。其他的技术往往要求数据属性的单一。
四、 决策树是一个白盒模型。如果给定一个观察的模型,那么根据所产生的决策树很容易推出相应的逻辑表达式。
五、 易于通过静态测试来对模型进行评测。表示有可能测量该模型的可信度。
六、 在相对短的时间内能够对大型数据源做出可行且效果良好的结果。
七、 可以对有许多属性的数据集构造决策树。
八、 决策树可很好地扩展到大型数据库中,同时它的大小独立于数据库的大小。

  • 决策树的缺点:

一、 对于那些各类别样本数量不一致的数据,在决策树当中,信息增益的结果偏向于那些具有更多数值的特征。
二、 决策树处理缺失数据时的困难。
三、 过度拟合问题的出现。
四、 忽略数据集中属性之间的相关性。

2 人工神经网络的优缺点

  • 人工神经网络的优点:

分类的准确度高,并行分布处理能力强,分布存储及学习能力强,对噪声神经有较强的鲁棒性和容错能力,能充分逼近复杂的非线性关系,具备联想记忆的功能等。

  • 人工神经网络的缺点:

神经网络需要大量的参数,如网络拓扑结构、权值和阈值的初始值;不能观察之间的学习过程,输出结果难以解释,会影响到结果的可信度和可接受程度;学习时间过长,甚至可能达不到学习的目的。

3 遗传算法的优缺点

  • 遗传算法的优点:

一、 与问题领域无关切快速随机的搜索能力。
二、 搜索从群体出发,具有潜在的并行性,可以进行多个个体的同时比较,鲁棒性好。
三、 搜索使用评价函数启发,过程简单。
四、 使用概率机制进行迭代,具有随机性。
五、 具有可扩展性,容易与其他算法结合。

  • 遗传算法的缺点:

一、 遗传算法的编程实现比较复杂,首先需要对问题进行编码,找到最优解之后还需要对问题进行解码,
二、 另外三个算子的实现也有许多参数,如交叉率和变异率,并且这些参数的选择严重影响解的品质,而目前这些参数的选择大部分是依靠经验.没有能够及时利用网络的反馈信息,故算法的搜索速度比较慢,要得要较精确的解需要较多的训练时间。
三、 算法对初始种群的选择有一定的依赖性,能够结合一些启发算法进行改进。

4 KNN算法(K-Nearest Neighbour) 的优缺点

  • KNN算法的优点:

一、 简单、有效。
二、 重新训练的代价较低(类别体系的变化和训练集的变化,在Web环境和电子商务应用中是很常见的)。
三、 计算时间和空间线性于训练集的规模(在一些场合不算太大)。
四、 由于KNN方法主要靠周围有限的邻近的样本,而不是靠判别类域的方法来确定所属类别的,因此对于类域的交叉或重叠较多的待分样本集来说,KNN方法较其他方法更为适合。
五、 该算法比较适用于样本容量比较大的类域的自动分类,而那些样本容量较小的类域采用这种算法比较容易产生误分。

  • KNN算法缺点:

一、 KNN算法是懒散学习方法(lazy learning,基本上不学习),一些积极学习的算法要快很多。
二、 类别评分不是规格化的(不像概率评分)。
三、 输出的可解释性不强,例如决策树的可解释性较强。
四、 该算法在分类时有个主要的不足是,当样本不平衡时,如一个类的样本容量很大,而其他类样本容量很小时,有可能导致当输入一个新样本时,该样本的K个邻居中大容量类的样本占多数。该算法只计算“最近的”邻居样本,某一类的样本数量很大,那么或者这类样本并不接近目标样本,或者这类样本很靠近目标样本。无论怎样,数量并不能影响运行结果。可以采用权值的方法(和该样本距离小的邻居权值大)来改进。
五、 计算量较大。目前常用的解决方法是事先对已知样本点进行剪辑,事先去除对分类作用不大的样本。

5 支持向量机(SVM)的优缺点

  • SVM的优点:

一、 可以解决小样本情况下的机器学习问题。
二、 可以提高泛化性能。
三、 可以解决高维问题。
四、 可以解决非线性问题。
五、 可以避免神经网络结构选择和局部极小点问题。

  • SVM的缺点:

一、 对缺失数据敏感。
二、 对非线性问题没有通用解决方案,必须谨慎选择Kernelfunction来处理。

6 朴素贝叶斯的优缺点

  • 优点:

一、 朴素贝叶斯模型发源于古典数学理论,有着坚实的数学基础,以及稳定的分类效率。
二、 NBC模型所需估计的参数很少,对缺失数据不太敏感,算法也比较简单。

  • 缺点:

一、 理论上,NBC模型与其他分类方法相比具有最小的误差率。但是实际上并非总是如此,这是因为NBC模型假设属性之间相互独立,这个假设在实际应用中往往是不成立的(可以考虑用聚类算法先将相关性较大的属性聚类),这给NBC模型的正确分类带来了一定影响。在属性个数比较多或者属性之间相关性较大时,NBC模型的分类效率比不上决策树模型。而在属性相关性较小时,NBC模型的性能最为良好。
二、 需要知道先验概率。
三、 分类决策存在错误率

7 Adaboosting方法的优点

  • 优点

一、 adaboost是一种有很高精度的分类器。
二、 可以使用各种方法构建子分类器,Adaboost算法提供的是框架。
三、 当使用简单分类器时,计算出的结果是可以理解的。而且弱分类器构造极其简单。
四、 简单,不用做特征筛选。
五、 不用担心overfitting。

8 Rocchio的优点

  • 优点

Rocchio算法的突出优点是容易实现,计算(训练和分类)特别简单,它通常用来实现衡量分类系统性能的基准系统,而实用的分类系统很少采用这种算法解决具体的分类问题。

9 随机森林算法:

  • 优点:

一 在数据集上表现良好,两个随机性的引入,使得随机森林不容易陷入过拟合。
二 在当前的很多数据集上,相对其他算法有着很大的优势,两个随机性的引入,使得随机森林具有很好的抗噪声能力。
三 它能够处理很高维度(feature很多)的数据,并且不用做特征选择,对数据集的适应能力强:既能处理离散型数据,也能处理连续型数据,数据集无需规范化。
四 在训练过程中,能够检测到feature间的互相影响。
五 对于不平衡的数据,它可以平衡误差。

  • 缺点:

一 在某些噪音较大的分类或回归问题上会产生过拟合现象。
二 对于有不同取值的属性的数据,取值划分较多的属性会对随机森林产生更大的影响,所以随机森林在这种数据上产出的属性权值是不可行的。

机器学习中各类算法的优缺点比较相关推荐

  1. 机器学习中分类算法的优缺点

    决策树 一.  决策树优点 1.决策树易于理解和解释,可以可视化分析,容易提取出规则. 2.可以同时处理标称型和数值型数据. 3.测试数据集时,运行速度比较快. 4.决策树可以很好的扩展到大型数据库中 ...

  2. AI:人工智能概念之机器学习中常用算法的思维导图集合(非常经典、建议收藏)之详细攻略

    AI:人工智能概念之机器学习中常用算法的思维导图集合(非常经典.建议收藏)之详细攻略 目录 机器学习算法的思维导图集合 1.ML算法思维图 2.ML算法思维导图 相关文章:ML/DL:关于算法模型的选 ...

  3. 机器学习中的算法(2)-支持向量机(SVM)基础

    版权声明: 本文由LeftNotEasy发布于http://leftnoteasy.cnblogs.com, 本文可以被全部的转载或者部分使用,但请注明出处,如果有问题,请联系wheeleast@gm ...

  4. 机器学习中的算法-支持向量机(SVM)基础

    机器学习中的算法-支持向量机(SVM)基础 版权声明: 本文由LeftNotEasy发布于http://leftnoteasy.cnblogs.com, 本文可以被全部的转载或者部分使用,但请注明出处 ...

  5. 机器学习中的算法:支持向量机(SVM)基础

    前言: 最近一段时间看了看关于SVM(Support Vector Machine)的文章,觉得SVM是一个非常有趣,而且自成一派的方向,所以今天准备写一篇关于关于SVM的文章. 关于SVM的论文.书 ...

  6. 机器学习算法优缺点_用于机器学习的优化算法的优缺点

    机器学习算法优缺点 A deep-dive into Gradient Descent and other optimization algorithms 深入研究梯度下降和其他优化算法 Optimi ...

  7. 机器学习中的算法:决策树模型组合之随机森林(Random Forest)

    基础知识 [关于决策树的基础知识参考:http://blog.csdn.net/holybin/article/details/22914417] 在机器学习中,随机森林由许多的决策树组成,因为这些决 ...

  8. 机器学习中的算法(1)-决策树模型组合之随机森林与GBDT

    版权声明: 本文由LeftNotEasy发布于http://leftnoteasy.cnblogs.com, 本文可以被全部的转载或者部分使用,但请注明出处,如果有问题,请联系wheeleast@gm ...

  9. 【机器学习算法专题(蓄力计划)】十二、机器学习中KNN算法

    文章目录 原理 基本步骤 算法关键点 K值的选择 距离的选择 决策原则 距离度量的实现方法 蛮力实现 KD 树 算法优缺点 优点 缺点 sklearn用法 应用举例 源码实现 K近邻法(KNN)是一种 ...

最新文章

  1. 进程、线程和上下文切换
  2. [BZOJ4556][Tjoi2016Heoi2016]字符串 主席树+二分+倍增+后缀自动机
  3. 【BIRT】使用rptlibrary设置统一数据源
  4. Asp.Net MVC5入门学习系列⑤
  5. gitlab提交代码
  6. C程序设计--排序(冒泡、选择、插入)--冒泡
  7. zebra 斑马打印机 打印图片
  8. C语言函数取大,C语言函数大全(部分)
  9. 菲尼克斯电源维修QUINT4-UPS/24DC/24DC
  10. 无法定位程序输入点于动态链接库kernel32
  11. 安卓/苹果/支付宝sdk拉起支付宝h5/app支付
  12. 牛年第一瓜!阿里女员工被初中文化男子骗走 500 多万元。。。
  13. 银联支付更换正式环境后报错存在风险而关闭了订单
  14. 十余省份高速人工通道实现支付宝收费 与ETC互为补充
  15. 拉依达准则去除异常数据
  16. 夜深模拟器不能连接 adb shell 解决方案
  17. 机器人植入情感芯片利与弊_未来机器人或具备情感 专家:要考虑伦理问题
  18. 基于XC2V1000型FPGA的FIR抽取滤波器的设计
  19. 怎么提高代码质量?-来自Google的研发经验总结
  20. 神经网络量化入门--Folding BN ReLU

热门文章

  1. MPEG-2TS码流编辑的原理及其应用(转载
  2. eclipse关闭讨厌的菜单
  3. vscode 编辑器快捷键
  4. FreeSql (二十六)贪婪加载 Include、IncludeMany、Dto、ToList
  5. python内建函数和工厂函数的整理
  6. 基于 Token 的身份验证方法
  7. linux中操作数据库的使用命令记录
  8. Machine Learning 学习笔记1 - 基本概念以及各分类
  9. enumerate()使用
  10. 170821-关于SpringMVC的知识点