机器学习中各类算法的优缺点比较

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间的互相影响。
五 对于不平衡的数据,它可以平衡误差。

  • 缺点:

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/456919.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在程序开发中日志级别

日志打印可以查看代码的执行情况,以及快速定位错误。 在代码中,特别是业务层逻辑的代码,适当的添加日志是必须的,一般在catch代码块中是出现异常的,如果需要打印 可以用error级别, 一般的无关紧要的日志&am…

基于Python搭建Django后台管理系统

一、博客网站的创建 创建项目 生成站点(sites)Model,这两步骤第一篇有介绍,这里就直接操作了 二、数据库配置 介绍一下数据库的配置就是在setting里面配置链接的数据库,这里系统以及配置好了,链接一个…

计算机研究所专业课,【择校必看】十三所计算机专业课只考数据结构的985院校!...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼敲黑板:本文涉及到的学校计算机专业考研只考数据结构,其中部分院校同时也会考算法、C语言等相关内容。但是,相对其他几门,无疑在专业课的复习上大大降低了难度。如果各位同学目前的专…

在Python2.7下如何安装TA-lib库

最近在做一个关于股票预测的模型,由于想要用Talib库中的方法,来提取各种金融技术指标,所以就下了这个库。但整个过程可谓是一波三折。花费了大半天才搞定这件事。 下面来给大家分享一下安装的步骤,省的大家再往这个坑里跳。。。 …

JavaScript 实现继承的5种方式

js是一个面向对象的语言,所以具备一些面向对象的方式----------例如继承。接下来介绍5种js的继承方式.注意:js 中的函数其实是对象,函数名是对 Function 对象的引用。 1.采用call方法改变函数上下文实现继承,原理是改变函数内部的…

day20 django

1、Django请求的生命周期武彦涛:路由系统 -> 试图函数(获取模板数据》渲染) -> 字符串返回给用户2、路由系统王腾:/index/ -> 函数或类.as_view()/detail/(\d) -> 函数(参数) 或 类.as_view()(参数&am…

解决Django 忘记超级管理员密码 重设密码登录教程

看到标题就知道有逗比忘了密码。。。没错就是我。 你也忘了密码? 不要着急! 00: 第一步:运行django shell python3 manage.py shell 01: 第二步:重设密码 >>> from django.contrib.auth…

计算机统计知识,计算机知识在统计工作中的重要性

计算机知识在统计工作中的重要性目前计算机已在县以上统计部门广为利用,如何注意提高统计业务人员的计算机水平,培养出既懂统计业务,又懂计算机知识的复合型统计人才,是当前急待研究和解决的重要问题。一、计算机存在的问题当前在基层统计队伍中使用计算机存在(本文共1页)阅读全…

初学者在python下使用Ta-lib库时遇到的一些问题及解决办法

由于Ta-lib是一款小众库,所以没有很好的API来说明其中各个函数的使用方法。无奈只能摸着石头过河,一个个试其中函数。期间遇到一些问题希望分享出来对大家有帮助。 问题描述:在使用Ta-lib库时用到的一些简单函数如SMA(),WMA(),EMA()这类方法时&#xff…

cocoapods-安装

下面方法解决pod setup出错(特别慢): 1.访问 https://github.com/CocoaPods/Specs,然后将Specs项目fork到自己的github账户上2. 下载GitHub Desktop, 然后clone Specs项目(客户端还是特别慢,我直接check一份…

计算机在输电线路设计中的应用研究,计算机在输电线路基础设计中的应用原稿(备份存档)...

《计算机在输电线路基础设计中的应用(原稿).doc》由会员分享,可免费在线阅读全文,更多与《计算机在输电线路基础设计中的应用(原稿)》相关文档资源请在帮帮文库(www.woc88.com)数亿文档库存里搜索。1、节省与浪费材料的情况之分。遵从相应的规则对全部可…

global全局变量

global全局变量 在不指向新的地址时,可以不调用global

C# 获取文件MD5值的方法

可用于对比文件是否相同 1 /// <summary>2 /// 获取文件MD5值3 /// </summary>4 /// <param name"fileName">文件绝对路径</param>5 /// <returns>MD5值</returns>6 public static str…

快速入门Matplotlib

以下是原文正文&#xff1a; 数据的处理、分析和可视化已经成为 Python 近年来最重要的应用之一。这种现象又进一步引出“大数据”分析等类似的话题&#xff0c;而大数据分析在人们所能预见的诸多领域内都有广泛应用&#xff0c;这其中就包含笔者个人感兴趣的机器学习。 Pytho…

谷歌开源 Python Fire:可自动生成命令行接口

为什么80%的码农都做不了架构师&#xff1f;>>> 今天我们很高兴地宣布 Python Fire 开源。Python Fire 可从任何 Python 代码生成命令行接口&#xff08;command line interfaces (CLIs)&#xff09;&#xff0c;简单地调用任意 Python 程序中的 Fire 函数以将那个…

tcp ip计算机网络协议,一篇文章带你熟悉 TCP/IP 协议-(一)

一、 计算机网络体系结构分层不难看出&#xff0c;TCP/IP 与 OSI 在分层模块上稍有区别。OSI 参考模型注重“通信协议必要的功能是什么”&#xff0c;而 TCP/IP 则更强调“在计算机上实现协议应该开发哪种程序”。二、 TCP/IP 基础1. TCP/IP 的具体含义从字面意义上讲&#xff…

远程控制python

import telnetlibdef telnetDoSomething(IP,user,passwd,command):try:# 连接服务器telnet telnetlib.Telnet(IP)# 设置调试级别telnet.set_debuglevel(2)# 读取输入用户名信息rt telnet.read_until("Login username:".encode("utf-8"))# 写入用户名tel…

Random Forest算法参数解释及调优

文章介绍了如何对随机森林模型进行参数调优 原文来自&#xff1a;http://www.analyticsvidhya.com/blog/2015/06/tuning-random-forest-model/ 为什么要调整机器学习算法&#xff1f; 一个月以前&#xff0c;我在kaggle上参加了一个名为TFI的比赛。 我第一次提交的结果在50%…

浮动问题

- 浮动很多时候是用来解决多列显示的问题- 浮动之后变为inline-block(浮动文本必须制定width)- 浮动之后会脱离文档流- 浮动后的元素不会存在margin的垂直方向的问题 - 浮动之后会影响周围元素的布局- 浮动不会超出父级元素- 浮动效果只会影响后面的元素&#xff08;包括自己的…

Servlet3.0新特性

1 Servlet3.0新特性概述 使用要求&#xff1a;MyEclipse10.0或以上版本&#xff0c;发布到Tomcat7.0或以上版本&#xff0c;创建JavaEE6.0应用&#xff01;  Servlete3.0的主要新特性如下三部分&#xff1a;    使用WebServlet、WebFilter、WebListener三个注解来替代we…