版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第07章 集成学习集成学习投票法挂袋法提升法7.1 引言集成学习(Ensemble Learning)是指利用多个独立的基学习器来进行学习,组合某输入样例在各个基学习器上的输出,并由他们按照某种策略共同决定输出。集成学习的基本思想是先通过一定的规则生成一定数量的基学习器(Base Estimator),再采用某种集成策略将这些基学习器的预测结果组合起来,形成最终的结论。集成学习中,弱学习器(Weak Learner)是错误概率小于0.5的学习器;而强学习器(Strong Learner)则具有任意小的错误概率。集成学习主要包括三个部分:个体的生成方法、个体学习器(基学习器)和结论的合(集)成方
2、法。集成学习中的基学习器可以是同质的“弱学习器”,也可以是异质的“弱学习器”。目前,同质个体学习器的应用最为广泛,同质个体学习器使用最多的模型是CART决策树和神经网络。7.1.1 集成学习的概念7.1 引言集成学习主要包括三个部分:个体的生成方法个体学习器(基学习器)结论的合(集)成方法。集成学习需要很好地解决如下两个问题。(1)如何通过有效地训练,获得若干个基学习器?(2)如何选择一个组合策略,将这些基学习器集合成为一个强学习器?7.1.2 集成学习的组成7.1 引言同质个体学习器按照个体学习器之间是否存在依赖关系又可以分为两类:个体学习器之间存在着强依赖关系其代表算法是Boosting算
3、法;个体学习器之间不存在强依赖关系,可以并行生成这些个体学习器,其代表算法是Bagging和随机森林(Random Forest)算法。根据集成学习的用途不同,结论合成的方法也各不相同。集成的输出通常由各个体学习器的输出投票产生。通常采用绝对多数投票法或相对多数投票法。当集成学习用于回归估计时,集成的输出通常由各学习器的输出通过简单平均或加权平均产生。7.1.3 同质个体学习器的分类及算法7.2 Voting 假设某机器学习模型有L个基学习器 ,用dj表示基学习器Mj在给定的任意输入向量x上的估计值,即 (注:若输入向量存在多种表示 ,也就是说每个基学习器的输入各不相同,那么Mj在输入xj上的
4、预测 ),那么最终的预测值可由各个基学习器的预测计算得出: 若每个基学习器有K个输出,即基学习器Mj的输出当它们组合时,得到预测值7.2 Voting 组合函数是投票法组合函数还可以是取平均值的简单投票法(Simple Voting)、中位数(Median)、最大值(Maxmize)等,如图7-1所示。图7-1 多个基学习器通过投票方法组合而成的集成学习方式示意图7.2 Voting对于回归,可以使用简单平均、加权平均或中位数来融合基回归器的输出。中位数对噪声比平均值更加棒。 分类器组合函数规则组合函数说明平均和 相对多数表决,直观加权和 考虑学习器的投票权重中位数 对离群点的鲁棒性好最小值
5、悲观估计最大值 乐观估计乘积 每个学习器都有否决权7.2 Voting 假定dj是独立同分布的,其期望值为E(dj),方差为Var(dj),那么当wj=1/L时,输出的期望值和方差分别为:从上述推导过程可以看到,期望值没有改变,因而偏倚也不会改变。但是方差随着独立投票数量的增加而下降。对于一般情况,有可以看出,如果学习器是正相关的,则方差增加。因此,在实践中,需要使用不同算法和输入特征来减少其正相关性。如果投票者不独立,但是负相关的,那么进一步降低方差也是可能的。7.2 Votingsklearn提供了一种软投票/多数规则分类器(Soft Voting/Majority Rule Classi
6、fier),其原型如下:class sklearn.ensemble.VotingClassifier(estimators, voting=hard, weights=None, n_jobs=1, flatten_transform=None) 主要参数如下estimators:指定的估计器,该估计器必须有.fit方法进行训练。voting:字符串,可选项为“soft”和“hard”,其默认值为“hard”。如果voting取值“hard”,那么使用多数规则表决预测的类标签。否则,基于各个基学习器的预测概率之和预测类标签。weights:数组,大小等于n_classifiers(基学习器的
7、数量),缺省值为None。权值序列表示预测类标签出现(hard voting),或者平均化之前的类概率(soft voting)。示例from itertools import productimport numpy as npimport matplotlib.pyplot as pltfrom sklearn import datasetsfrom sklearn.tree import DecisionTreeClassifierfrom sklearn.neighbors import KNeighborsClassifierfrom sklearn.svm import SVCfro
8、m sklearn.ensemble import VotingClassifier# 加载鸢尾花数据集iris = datasets.load_iris()X = iris.data:, 0, 2y = iris.target7.2 Voting# 构造三个基学习器和一个集成学习器clf1 = DecisionTreeClassifier(max_depth=4)clf2 = KNeighborsClassifier(n_neighbors=7)clf3 = SVC(kernel=rbf, probability=True)eclf = VotingClassifier(estimators
9、=(dt, clf1), (knn, clf2), (svc, clf3), voting=soft, weights=3, 2, 1)# 训练学习器clf1.fit(X, y)clf2.fit(X, y)clf3.fit(X, y)eclf.fit(X, y)7.2 Voting# 生成数据网格x_min, x_max = X:, 0.min() - 1, X:, 0.max() + 1y_min, y_max = X:, 1.min() - 1, X:, 1.max() + 1xx, yy = np.meshgrid(np.arange(x_min, x_max, 0.1), np.ara
10、nge(y_min, y_max, 0.1)# 绘图f, axarr = plt.subplots(2, 2, sharex=col, sharey=row, figsize=(10, 8)for idx, clf, tt in zip(product(0, 1, 0, 1), clf1, clf2, clf3, eclf, Decision Tree (depth=4), KNN (k=7), Kernel SVM, Soft Voting): Z = clf.predict(np.c_xx.ravel(), yy.ravel() Z = Z.reshape(xx.shape)7.2 Vot
11、ing axarridx0, idx1.contourf(xx, yy, Z, alpha=0.4) axarridx0, idx1.scatter(X:, 0, X:, 1, c=y, s=20, edgecolor=k) axarridx0, idx1.set_title(tt) plt.show()7.2 Voting 首先构造三个不同的基学习器:决策树、k近邻和支持向量机,然后用软投票(soft voting)策略,将上述三个基学习器集成为一个新的学习器,使用sklearn 中的鸢尾花数据集训练上述各个学习器。7.2 Voting 运行结果如下7.3 Bagging7.3 Baggin
12、g 一个学习算法是稳定的,如果该算法在相同训练数据集的再抽样版本上多次运行导致具有高正相关性的学习器。决策树和多层感知器是不稳定的,最近邻算法是稳定的,但是精简的最近邻算法是不稳定的。一个学习算法是不稳定的,如果训练集的微小变化引起由其训练得到的学习器的很大差异,即学习算法具有高方差。Bagging的组合策略是:分类任务采取简单投票法,即每个基学习器一票;回归任务使用简单平均法,即每个基学习器的预测值取平均值。sklearn提供了典型的Bagging分类器,其原型如下:class sklearn.ensemble.BaggingClassifier(base_estimator=None, n
13、_estimators=10, max_samples=1.0, max_features=1.0, bootstrap=True, bootstrap_features=False, oob_score=False, warm_start=False, n_jobs=1, random_state=None, verbose=0)source7.3 Bagging 主要参数base_estimator:对象,默认值为None。如果是None,则默认的基学习器是决策树。n_estimator:整型,默认值为10。基学习器的数量。max_samples:整型或浮点型,默认值为1.0。从X中抽取指
14、定的样本数来训练每个基学习器。如果是整型,抽取max_samples个样本作为训练数据集;否则,抽取max_samples * X.shape0样本作为训练数据集。max_features:整型或浮点型,默认值为1.0。从X中抽取指定的属性数量来训练每个基学习器。如果是整型,抽取max_featuress个属性;否则,抽取max_features * X.shape1属性。warm_start:布尔值,默认值为False。当设置为True时,训练是在前一次集成学习的基础上,继续训练并添加更多基学习器到集成学习中来,否则,只是训练一个全新的集成学习。7.3 Bagging采取与前一节示例中一样的
15、基学习器,分别构造三个不同的基学习器以及它们相对应的挂袋集成学习器,然后使用sklearn中的鸢尾花数据集训练上述各个学习器。 挂袋法比单个基学习器的效果稍好一点。 7.3 Bagging 随机森林(Random Froest,RF)的基学习器是决策树。对于一个输入样本,N棵决策树就会有N个分类结果,随机森林集成了所有分类投票结果,将投票次数最多的类别作为最终的输出。(1)抽样产生每棵决策树的训练数据集。RF采用Bagging抽样技术从原始训练数据集中产生N个训练子集。(2)构建N棵决策树(基学习器)。每一个训练子集生成一棵决策树,从而产生N棵决策树形成森林,每棵决策树不需要剪枝处理。(3)生
16、成随机森林,以简单多数的原则决定该样本是哪个类别。使用N棵决策树对测试样本进行分类,随机森林将每棵子树的结果汇总,以简单多数的原则决定该样本是哪个类别。 随机森林的生成过程如下: 7.3 Bagging(4)从原始训练集中随机产生N个训练子集用于随机生成N颗决策树。(5)在构建具体的决策树过程中随机地选择m个属性,随机森林的生成过程中这两个随机性,可以确保不会出现过拟合(over-fitting)。 sklearn提供了RF分类器,其原型如下: class sklearn.ensemble.RandomForestClassifier(n_estimators=10, criterion=gi
17、ni, max_depth=None, min_samples_split=2, min_samples_leaf=1, min_weight_fraction_leaf=0.0, max_features=auto, max_leaf_nodes=None, min_impurity_decrease=0.0, min_impurity_split=None, bootstrap=True, oob_score=False, n_jobs=1, random_state=None, verbose=0, warm_start=False, class_weight=None)7.4 Boos
18、ting1990年,R. Schapire给出了肯定的答案,通过组合三个弱学习器实现了一个强学习器,促进了提升(Boosting)算法的极大发展。Boosting算法分为如下两个阶段。训练阶段。给定一个大训练集X,随机地将其划分为3个子集X=X1,X2,X3。首先,使用X1训练的d1;接着,提取X2并将它作为d1的输入,将d1错误分类的所有实例以及X2中被d1正确分类的一些实例一起作为d2的训练集;然后,提取X3并将它输入给d1和d2,其中用d1和d2输出不一致的实例作为d3的训练集。检验阶段。给定一个实例,首先将其提供给d1和d2,如果二者输出一致,这就是输出结果,否则d3的输出作为输出结果
19、。7.4 Boosting7.4.1 AdaBoost尽管Boosting非常成功,但是需要一个非常大的训练样本集,将样本集一分为三。(很多场合不太现实)1996年,Yoav Freund和Robert Schapire提出了提升的一个变种,即自适应提升(Adaptive Boosting,AdaBoost),它重复使用相同的训练集,而不再要求很大的数据集。AdaBoost算法的工作机制首先,训练集用初始权重训练出一个弱学习器1,根据弱学习的学习误差率表现来更新训练样本的权重,使得之前弱学习器1学习误差率高的训练样本点的权重变高,使得这些误差率高的点在后面的弱学习器2中得到更多的重视。然后,基
20、于调整权重后的训练集来训练弱学习器2,如此重复进行,直到训练到指定的弱学习器数量。最后,将这些弱学习器通过集合策略进行整合,得到最终的强学习器。7.4 Boosting7.4.1 AdaBoostBoosting7.4.1 AdaBoostingBoosting7.4.1 AdaBoosting7.4 Boosting7.4.1 AdaBoost,标准的AdaBoost算法模型是二分类的加法模型,其中损失函数为指数函数,学习方法为前向分步算法。在AdaBoost中,尽管不同的基学习器使用稍有差异的训练集,但是这种差异不像Bagging那样完全依靠偶然性,而是它前一个基学习器误差的函数。提升对一
21、个特定问题的实际性能显然依赖于训练数据集和基学习器。为此,需要有足够的训练数据,并且学习器应当是弱的但又不是太弱,而且提升对噪声和离群点尤其敏感。 Sklearn提供的AdaBoost分类器实现了SAMME和SAMME.R算法,原型如下:class sklearn.ensemble.AdaBoostClassifier(base_estimator=None, n_estimators=50, learning_rate=1.0, algorithm=SAMME.R, random_state=None)7.4 Boosting SAMME和SAMME.R算法的主要参数base_estimat
22、or:对象,默认值为决策树。该基础分类器必须支持带样本权重的学习。n_estimators:整型,默认值为50。设定基分类器数量的上限值,如果训练集已经完全训练好了,算法会提前终止。learning_rate:浮点型,默认值为1。用于减少每一步的步长,防止步长太大而跨过极值点。通常在learning_rate和n_estimators之间会有一个折中。algorithm:SAMME.R,SAMME,默认值为SAMME.R。 首先使用sklearn的make_Hastie_10_2生成12000个样本的数据集,并将其分为训练数据集和测试数据集。然后,在基决策树、决策树、AdaBoost(SAMM
23、E)和AdaBoost(SAMME.R)上计算分类的错误率。 7.4 Boosting 从实验结果看出,弱分类器(Decision Tree Stump)单独分类的效果很差,错误率将近50%,强分类器(Decision Tree)的效果要明显好于它。但是AdaBoost的效果要明显好于这两者。同时在AdaBoost中,Real AdaBoost的分类效果更好。7.4 Boosting 梯度提升(Gradient Boosting)是一种用于回归和分类问题的机器学习方法,生成一个由弱预测模型(通常是决策树)组成的集成预测模型(强学习器)。通过迭代选择一个指向负梯度方向上的函数(弱假设),优化函数
24、空间上的成本函数,拟合一棵决策树。在回归问题中,这称为梯度提升回归树GBRT;在分类问题中,这又被称为提升决策树GBDT。 7.4.2 Gradient Boosting7.4 Boosting7.4.2 Gradient BoostingBoosting7.4.2 Gradient BoostingBoosting7.4.2 Gradient Boosting7.4 Boosting7.4.2 Gradient Boosting GBDT可用于回归问题,相对Logistic Regression仅能用于线性回归,GBDT能用于线性回归和非线性回归,GBDT的适用面更广。GBDT也可用于二分类
25、问题(设定阈值,大于阈值为正例,反之为负例)。 Sklearn提供的GBDT的实现类原型如下: class sklearn.ensemble.GradientBoostingClassifier(loss=deviance, learning_rate=0.1, n_estimators=100, subsample=1.0, criterion=friedman_mse, min_samples_split=2, min_samples_leaf=1, min_weight_fraction_leaf=0.0, max_depth=3, min_impurity_decrease=0.0,
26、min_impurity_split=None, init=None, random_state=None, max_features=None,verbose=0, max_leaf_nodes=None,warm_start=False,presort=auto)7.4 Boosting7.4.2 Gradient Boosting 主要参数如下:7.4 Boosting 运行效果如下: 针对GradientBoostingClassifier中的learning_rate参数的不同取值,分别构造一颗梯度提升分类学习器,并在手写体数字数据集上进行训练并测试。从图中,可以看到,GBDT的预测
27、准确率对于学习率来说,总体上是平稳的。7.5 综合案例 集成学习是机器学习中的一种“集大成”的学习方法,下面给出一个示例程序,来比较几种典型的机器学习算法在不同数据集上的性能差异。程序如下:import numpy as npimport matplotlib.pyplot as pltfrom matplotlib.colors import ListedColormapfrom sklearn.model_selection import train_test_splitfrom sklearn.preprocessing import StandardScalerfrom sklearn
28、.datasets import make_moons, make_circles, make_classificationfrom sklearn.neighbors import KNeighborsClassifierfrom sklearn.svm import SVCfrom sklearn.tree import DecisionTreeClassifierfrom sklearn.ensemble import RandomForestClassifier, AdaBoostClassifierfrom sklearn.ensemble import GradientBoosti
29、ngClassifierfrom sklearn.naive_bayes import GaussianNBfrom sklearn.discriminant_analysis import LinearDiscriminantAnalysis as LDAfrom sklearn.discriminant_analysis import QuadraticDiscriminantAnalysis as QDA7.5 综合案例h = .02 # 网格的步长# 分类的名称列表,及其对应的对象列表names = Nearest Neighbors, Linear SVM, RBF SVM, Dec
30、ision Tree,GBDT, Random Forest, AdaBoost, Naive Bayes, LDA, QDAclassifiers = KNeighborsClassifier(3), SVC(kernel=linear, C=0.025), SVC(gamma=2, C=1), DecisionTreeClassifier(max_depth=5), GradientBoostingClassifier(max_depth=5), RandomForestClassifier(max_depth=5, n_estimators=10, max_features=1), Ad
31、aBoostClassifier(), GaussianNB(), LDA(), QDA()7.5 综合案例# 生成样本数据集X, y = make_classification(n_features=2, n_redundant=0, n_informative=2, random_state=1, n_clusters_per_class=1)rng = np.random.RandomState(2)X += 2 * rng.uniform(size=X.shape)linearly_separable = (X, y)datasets = make_moons(noise=0.3, r
32、andom_state=0), make_circles(noise=0.2, factor=0.5, random_state=1), linearly_separable figure = plt.figure(figsize=(27, 9)i = 1# 依次处理每一个数据集,在每个数据集上分别用前面列举的10种分类方法for ds in datasets: # 将每个数据集划分为训练集和测试集 X, y = ds X = StandardScaler().fit_transform(X) X_train, X_test, y_train, y_test = train_test_spli
33、t(X, y, test_size=.4) x_min, x_max = X:, 0.min() - .5, X:, 0.max() + .5 y_min, y_max = X:, 1.min() - .5, X:, 1.max() + .5 xx, yy = np.meshgrid(np.arange(x_min, x_max, h), np.arange(y_min, y_max, h) # 绘制原始数据 cm = plt.cm.RdBu cm_bright = ListedColormap(#FF0000, #0000FF) ax = plt.subplot(len(datasets),
34、 len(classifiers) + 1, i) # 分别绘制训练数据集、测试数据集 ax.scatter(X_train:, 0, X_train:, 1, c=y_train, cmap=cm_bright) ax.scatter(X_test:, 0, X_test:, 1, c=y_test, cmap=cm_bright, alpha=0.6) ax.set_xlim(xx.min(), xx.max() ax.set_ylim(yy.min(), yy.max() ax.set_xticks() ax.set_yticks() i += 17.5 综合案例7.5 综合案例 # 迭代使用上述10种分类方法 for name, clf in zip(names, classifiers): ax = plt.subplot(len(datasets), len(classifiers) + 1, i) clf
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 益元散中药成分分析-洞察分析
- 响应式认证系统设计-洞察分析
- 药物相互作用-洞察分析
- 移动安全防护研究-洞察分析
- 溯源链与建筑信用体系-洞察分析
- 匠心筑梦技能报国三分钟演讲稿(7篇)
- 冬春森林防火方案(9篇)
- 文化遗产法政策体系构建-洞察分析
- 《普通混凝土选》课件
- 网络隐私政策优化-洞察分析
- 2024年江西三校生对口升学考试语文试卷真题(含答案详解)
- 语文园地三(课件)2024~2025学年语文一年级上册统编版
- 《3 我和鸟类做朋友》(教案)-2023-2024学年五年级上册综合实践活动粤教版
- GB 30254-2024高压三相笼型异步电动机能效限定值及能效等级
- (高级)铁路货运员职业技能鉴定考试题库(浓缩500题)
- 人体捐献器官合同协议书
- 重大事故隐患判定标准与相关事故案例培训课件
- 2024年公开招聘驾驶员面试试题
- 2024年高考地理真题完全解读(广西卷)
- 2024至2030年中国冲调饮料行业市场深度研究及投资规划建议报告
- 2024年贵州省中考理科综合试卷(含答案解析)
评论
0/150
提交评论