zoukankan      html  css  js  c++  java
  • 分类算法简介 分类: B10_计算机基础 2015-03-09 11:08 257人阅读 评论(0) 收藏



    一、决策树
    决策树是用于分类和预测的主要技术之一,决策树学习是以实例为基础的归纳学习算法,它着眼于从一组无次序、无规则的实例中 推理出以决策树表示的分类规则。构造决策树的目的是找出属性和类别间的关系,用它来预测将来未知类别的记录的类别。它采用自顶向下的递归方式,在决策树的 内部节点进行属性的比较,并根据不同属性值判断从该节点向下的分支,在决策树的叶节点得到结论。
    主要的决策树算法有ID3、C4.5(C5.0)、CART、PUBLIC、SLIQ和SPRINT算法等。它们在选择测试属性采用的技术、生成的决策树的结构、剪枝的方法以及时刻,能否处理大数据集等方面都有各自的不同之处。
    决策树的优点:
    1、 决策树易于理解和解释.人们在通过解释后都有能力去理解决策树所表达的意义。
    2、 对于决策树,数据的准备往往是简单或者是不必要的.其他的技术往往要求先把数据一般化,比如去掉多余的或者空白的属性。
    3、能够同时处理数据型和常规型属性。其他的技术往往要求数据属性的单一。
    4、决策树是一个白盒模型。如果给定一个观察的模型,那么根据所产生的决策树很容易推出相应的逻辑表达式。
    5、易于通过静态测试来对模型进行评测。表示有可能测量该模型的可信度。
    6、在相对短的时间内能够对大型数据源做出可行且效果良好的结果。
    7、可以对有许多属性的数据集构造决策树。
    8、决策树可很好地扩展到大型数据库中,同时它的大小独立于数据库的大小。
    决策树的缺点:
    1、 对于那些各类别样本数量不一致的数据,在决策树当中,信息增益的结果偏向于那些具有更多数值的特征。
    2、决策树处理缺失数据时的困难。
    3、过度拟合问题的出现。
    4、忽略数据集中属性之间的相关性。


     二、贝叶斯
    贝 叶斯(Bayes)分类算法是一类利用概率统计知识进行分类的算法,如朴素贝叶斯(Naive Bayes)算法。这些算法主要利用Bayes定理来预测一个未知类别的样本属于各个类别的可能性,选择其中可能性最大的一个类别作为该样本的最终类别。 由于贝叶斯定理的成立本身需要一个很强的条件独立性假设前提,而此假设在实际情况中经常是不成立的,因而其分类准确性就会下降。为此就出现了许多降低独立 性假设的贝叶斯分类算法,如TAN(Tree Augmented Na?ve Bayes)算法,它是在贝叶斯网络结构的基础上增加属性对之间的关联来实现的。
    优点:
    1、朴素贝叶斯模型发源于古典数学理论,有着坚实的数学基础,以及稳定的分类效率。
    2、NBC模型所需估计的参数很少,对缺失数据不太敏感,算法也比较简单。
    缺点:
    1、理论上,NBC模型与其他分类方法相比具有最小的误差率。但是实际上并非总是如此,这是因为NBC模型假设属性之间相互独立,这个假设在实际应用中 往往是不成立的(可以考虑用聚类算法先将相关性较大的属性聚类),这给NBC模型的正确分类带来了一定影响。在属性个数比较多或者属性之间相关性较大 时,NBC模型的分类效率比不上决策树模型。而在属性相关性较小时,NBC模型的性能最为良好。
    2、需要知道先验概率。
    3、分类决策存在错误率


      三、人工神经网络
    人工神经网络 (Artificial Neural Networks,ANN)是一种应用类似于大脑神经突触联接的结构进行信息处理的数学模型。在这种模型中,大量的节点(或称”神经元”,或”单元”)之 间相互联接构成网络,即”神经网络”,以达到处理信息的目的。神经网络通常需要进行训练,训练的过程就是网络进行学习的过程。训练改变了网络节点的连接权 的值使其具有分类的功能,经过训练的网络就可用于对象的识别。   
    目前,神经网络已有上百种不同的模型,常见的有BP网络、径向基RBF网 络、Hopfield网络、随机神经网络(Boltzmann机)、竞争神经网络(Hamming网络,自组织映射网络)等。但是当前的神经网络仍普遍存 在收敛速度慢、计算量大、训练时间长和不可解释等缺点。
    人工神经网络的优点:分类的准确度高,并行分布处理能力强,分布存储及学习能力强,对噪声神经有较强的鲁棒性和容错能力,能充分逼近复杂的非线性关系,具备联想记忆的功能等。
    人工神经网络的缺点:神经网络需要大量的参数,如网络拓扑结构、权值和阈值的初始值;不能观察之间的学习过程,输出结果难以解释,会影响到结果的可信度和可接受程度;学习时间过长,甚至可能达不到学习的目的。     

    四、k-近邻
    k-近邻(kNN,k-Nearest Neighbors)算法是一种基于实例的分类方法。该方法就是找出与未知样本x距离最近的k个训练样本,看这k个样本中多数属于哪一类,就把x归为那一 类。k-近邻方法是一种懒惰学习方法,它存放样本,直到需要分类时才进行分类,如果样本集比较复杂,可能会导致很大的计算开销,因此无法应用到实时性很强 的场合。
    KNN算法的优点:
    1、简单、有效。
    2、重新训练的代价较低(类别体系的变化和训练集的变化,在Web环境和电子商务应用中是很常见的)。
    3、计算时间和空间线性于训练集的规模(在一些场合不算太大)。
    4、由于KNN方法主要靠周围有限的邻近的样本,而不是靠判别类域的方法来确定所属类别的,因此对于类域的交叉或重叠较多的待分样本集来说,KNN方法较其他方法更为适合。
    5、该算法比较适用于样本容量比较大的类域的自动分类,而那些样本容量较小的类域采用这种算法比较容易产生误分。
    KNN算法缺点:
    1、 KNN算法是懒散学习方法(lazy learning,基本上不学习),一些积极学习的算法要快很多。
    2、类别评分不是规格化的(不像概率评分)。

    3、输出的可解释性不强,例如决策树的可解释性较强。

    4、该算法在分类时有个主要的不足是,当样本不平衡时,如一个类的样本容量很大,而其他类样本容量很小时,有可能导致当输入一个新样本时,该样本的K个 邻居中大容量类的样本占多数。该算法只计算“最近的”邻居样本,某一类的样本数量很大,那么或者这类样本并不接近目标样本,或者这类样本很靠近目标样本。 无论怎样,数量并不能影响运行结果。可以采用权值的方法(和该样本距离小的邻居权值大)来改进。
    5、计算量较大。目前常用的解决方法是事先对已知样本点进行剪辑,事先去除对分类作用不大的样本。


     
    五、支持向量机
    支持向量机(SVM,Support Vector Machine)是Vapnik根据统计学习理论提出的一种新的学习方法[43] ,它的最大特点是根据结构风险最小化准则,以最大化分类间隔构造最优分类超平面来提高学习机的泛化能力,较好地解决了非线性、高维数、局部极小点等问题。 对于分类问题,支持向量机算法根据区域中的样本计算该区域的决策曲面,由此确定该区域中未知样本的类别。
    SVM的优点:
    1、可以解决小样本情况下的机器学习问题。
    2、可以提高泛化性能。
    3、可以解决高维问题。
    4、可以解决非线性问题。
    5、可以避免神经网络结构选择和局部极小点问题。
    SVM的缺点:
    1、对缺失数据敏感。
    2、对非线性问题没有通用解决方案,必须谨慎选择Kernelfunction来处理。

     
    六、基于关联规则的分类
    关 联规则挖掘是数据挖掘中一个重要的研究领域。近年来,对于如何将关联规则挖掘用于分类问题,学者们进行了广泛的研究。关联分类方法挖掘形如 condset→C的规则,其中condset是项(或属性-值对)的集合,而C是类标号,这种形式的规则称为类关联规则(class association rules,CARS)。关联分类方法一般由两步组成:第一步用关联规则挖掘算法从训练数据集中挖掘出所有满足指定支持度和置信度的类关联规则;第二步使 用启发式方法从挖掘出的类关联规则中挑选出一组高质量的规则用于分类。属于关联分类的算法主要包括CBA[44] ,ADT[45] ,CMAR[46] 等。
     
    七、集成学习(Ensemble Learning)
    实际应用的复杂性和数据的多样性往往使得单一的分类方法不够有效。因此,学者们对多种分类方法的融合即集成学习进行了广泛的研究。集成学习已成为国际机器学习界的研究热点,并被称为当前机器学习四个主要研究方向之一。
    集 成学习是一种机器学习范式,它试图通过连续调用单个的学习算法,获得不同的基学习器,然后根据规则组合这些学习器来解决同一个问题,可以显著的提高学习系 统的泛化能力。组合多个基学习器主要采用(加权)投票的方法,常见的算法有装袋[47] (Bagging),提升/推进[48, 49] (Boosting)等。
    集成学习由于采用了投票平均的方法组合多个分类器,所以有可能减少单个分类器的误差,获得对问题空间模型更加准确的表示,从而提高分类器的分类准确度。
     

    八、遗传算法
    遗传算法的优点:
    1、与问题领域无关切快速随机的搜索能力。
    2、搜索从群体出发,具有潜在的并行性,可以进行多个个体的同时比较,鲁棒性好。
    3、搜索使用评价函数启发,过程简单。
    4、使用概率机制进行迭代,具有随机性。
    5、具有可扩展性,容易与其他算法结合。
    遗传算法的缺点:
    1、遗传算法的编程实现比较复杂,首先需要对问题进行编码,找到最优解之后还需要对问题进行解码,
    2、另外三个算子的实现也有许多参数,如交叉率和变异率,并且这些参数的选择严重影响解的品质,而目前这些参数的选择大部分是依靠经验.没有能够及时利用网络的反馈信息,故算法的搜索速度比较慢,要得要较精确的解需要较多的训练时间。
    3、算法对初始种群的选择有一定的依赖性,能够结合一些启发算法进行改进。

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

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



    以 上简单介绍了各种主要的分类方法,应该说其都有各自不同的特点及优缺点。对于数据库负载的自动识别,应该选择哪种方法呢?用来比较和评估分类方法的标准 [50] 主要有:
    (1)预测的准确率。模型正确地预测新样本的类标号的能力;
    (2)计算速度。包括构造模型以及使用模型进行分类的时间;
    (3)强壮性。模型对噪声 数据或空缺值数据正确预测的能力;
    (4)可伸缩性。对于数据量很大的数据集,有效构造模型的能力;
    (5)模型描述的简洁性和可解释性。模型描述愈简洁、愈 容易理解,则愈受欢迎。

     
     
  • 相关阅读:
    leetcode165
    leetcode63
    leetcode92
    leetcode86
    捣鼓Haskell
    递归操作链表
    treap(堆树)
    贪心策略 — 分数背包
    LeetCode.21
    LeetCode.94
  • 原文地址:https://www.cnblogs.com/lujinhong2/p/4637209.html
Copyright © 2011-2022 走看看