sklearn中的决策树-分类树:剪枝参数

news/2025/2/25 10:11:29

剪枝参数

  • 在不加限制的情况下,一棵决策树会生长到衡量不纯度的指标最优,或者没有更多的特征可用为止。这样的决策树 往往会过拟合。为了让决策树有更好的泛化性,我们要对决策树进行剪枝。剪枝策略对决策树的影响巨大,正确的剪枝策略是优化 决策树算法的核心。sklearn为我们提供了不同的剪枝策略:
max_depth
  • 限制树的最大深度,超过设定深度的树枝全部剪掉

    这是用得最广泛的剪枝参数,在高维度低样本量时非常有效。决策树多生长一层,对样本量的需求会增加一倍,所 以限制树深度能够有效地限制过拟合。在集成算法中也非常实用。实际使用时,建议从=3开始尝试,看看拟合的效 果再决定是否增加设定深度。

min_samples_leaf & min_samples_split
  • min_samples_leaf限定,一个节点在分枝后的每个子节点都必须包含至少min_samples_leaf个训练样本,否则分 枝就不会发生,或者,分枝会朝着满足每个子节点都包含min_samples_leaf个样本的方向去发生。

    min_samples_leaf限定,一个节点在分枝后的每个子节点都必须包含至少min_samples_leaf个训练样本,否则分 枝就不会发生,或者,分枝会朝着满足每个子节点都包含min_samples_leaf个样本的方向去发生 一般搭配max_depth使用,在回归树中有神奇的效果,可以让模型变得更加平滑。这个参数的数量设置得太小会引 起过拟合,设置得太大就会阻止模型学习数据。一般来说,建议从=5开始使用。如果叶节点中含有的样本量变化很 大,建议输入浮点数作为样本量的百分比来使用。同时,这个参数可以保证每个叶子的最小尺寸,可以在回归问题 中避免低方差,过拟合的叶子节点出现。对于类别不多的分类问题,=1通常就是最佳选择。

  • min_samples_split限定,一个节点必须要包含至少min_samples_split个训练样本,这个节点才允许被分枝,否则 分枝就不会发生。

  • min_samples_leaf = 10

    min_samples_split = 25

    # -*- coding: utf-8 -*-
    
    """
    **************************************************
    @author:   Ying                                      
    @software: PyCharm                       
    @file: 3、分类树_min_samples_leaf& min_samples_split.py
    @time: 2021-08-26 10:51                          
    **************************************************
    """
    from sklearn import tree
    from sklearn.datasets import load_wine
    from sklearn.model_selection import train_test_split
    import pandas as pd
    import graphviz
    
    # 加载数据
    wine = load_wine()
    data = pd.DataFrame(wine.data, columns=wine.feature_names)  # X
    target = pd.DataFrame(wine.target)  # y
    
    # 划分训练测试集
    X_train, X_test, y_train, y_test = train_test_split(data, target, test_size=0.3)
    
    clf = tree.DecisionTreeClassifier(criterion="entropy"
                                      , random_state=30
                                      , splitter="random"
                                      , max_depth=3
                                      , min_samples_leaf=10
                                      , min_samples_split=25
                                      )
    
    clf.fit(X_train, y_train)
    score = clf.score(X_test, y_test)  # 返回预测的准确度
    
    # 保存决策树
    feature_name = ['酒精', '苹果酸', '灰', '灰的碱性', '镁', '总酚', '类黄酮', '非黄烷类酚类',
                    '花青素', '颜色强度', '色调', 'od280/od315稀释葡萄酒', '脯氨酸']
    
    dot_data = tree.export_graphviz(clf
                                    , feature_names=feature_name
                                    , class_names=["琴酒", "雪莉", "贝尔摩德"]
                                    , filled=True  # 填充颜色
                                    , rounded=True  # 圆角
                                    )
    graph = graphviz.Source(dot_data)
    
    graph.render(view=True, format="png", filename="./save/decisiontree_pdf")
    
    # 特征重要性
    feature_importances = clf.feature_importances_
    
    a = pd.DataFrame([*zip(feature_name, feature_importances)])
    a.columns = ['feature', 'importance']
    a.sort_values('importance', ascending=False, inplace=True)
    print(a)
    

    image-20210826110623238

max_features & min_impurity_decrease
  • 一般max_depth使用,用作树的”精修“ max_features限制分枝时考虑的特征个数,超过限制个数的特征都会被舍弃。和max_depth异曲同工, max_features是用来限制高维度数据的过拟合的剪枝参数,但其方法比较暴力,是直接限制可以使用的特征数量 而强行使决策树停下的参数,在不知道决策树中的各个特征的重要性的情况下,强行设定这个参数可能会导致模型 学习不足。如果希望通过降维的方式防止过拟合,建议使用PCA,ICA或者特征选择模块中的降维算法。 min_impurity_decrease限制信息增益的大小,信息增益小于设定数值的分枝不会发生。这是在0.19版本中更新的 功能,在0.19版本之前时使用min_impurity_split。
确定最优剪枝参数(超参数曲线)
  • 那具体怎么来确定每个参数填写什么值呢?这时候,我们就要使用确定超参数的曲线来进行判断了,继续使用我们 已经训练好的决策树模型clf。超参数的学习曲线,是一条以超参数的取值为横坐标,模型的度量指标为纵坐标的曲 线,它是用来衡量不同超参数取值下模型的表现的线。在我们建好的决策树里,我们的模型度量指标就是score。

    # -*- coding: utf-8 -*-
    
    """
    **************************************************
    @author:   Ying                                      
    @software: PyCharm                       
    @file: 4、分类树_超参数曲线.py
    @time: 2021-12-01 11:28                          
    **************************************************
    """
    
    from sklearn import tree
    from sklearn.datasets import load_wine
    from sklearn.model_selection import train_test_split
    import pandas as pd
    import matplotlib.pyplot as plt
    
    # 加载数据
    wine = load_wine()
    data = pd.DataFrame(wine.data, columns=wine.feature_names)  # X
    target = pd.DataFrame(wine.target)  # y
    
    # 划分训练测试集
    X_train, X_test, y_train, y_test = train_test_split(data, target, test_size=0.3)
    
    
    
    test = []
    for i in range(10):
        clf = tree.DecisionTreeClassifier(max_depth=i+1
                                          ,criterion="entropy"
                                          ,random_state=10
                                          ,splitter='random')
        clf = clf.fit(X_train, y_train)
        score = clf.score(X_test, y_test)
        test.append(score)
    plt.plot(range(1,11),test,color="red",label="max_depth")
    plt.legend()
    plt.show()
    

    image-20211201113350789



http://www.niftyadmin.cn/n/5865364.html

相关文章

CoralStyle CLIP 技术浅析(四):多层次特征融合

CoralStyle CLIP 是一种结合了 CLIP(Contrastive Language–Image Pretraining)和 CoralStyle 多风格图像生成技术的模型。其核心在于通过多层次特征融合技术,将文本和图像的特征进行高效融合,从而实现跨模态的语义对齐和风格化生成。 1. 多层次特征提取 1.1 图像特征提取…

ELK之elasticsearch基本使用教程

文章目录 ELK包含技术elasticsearch基本介绍倒排索引正向索引倒排索引正向和倒排 es的一些概念文档和字段索引和映射mysql与elasticsearch 安装es、kibana创建网络加载镜像安装分词插件 索引库操作mapping映射属性索引库的CRUD创建索引库和映射基本语法:示例&#x…

23种设计模式的cpp举例

下面介绍经典的23种设计模式,并分别用C示例代码加以说明。本文分为三大类:创建型模式、结构型模式和行为型模式,每种模式简要说明其意图、关键思想和优缺点,并给出一个精简的C代码示例。 一、创建型模式 创建型模式关注对象的创建…

使用dict对嵌套列表进行求和及优化案例

文章目录 案例背景示例数据 使用 dict 求和步骤说明代码实现 优化说明 在数据处理和分析中,经常需要将嵌套列表中的数据进行汇总和计算。 本文将通过一个实际案例,展示如何使用 dict 和 dict.get() 方法对嵌套列表进行求和操作。 案例背景 假设你是一名…

20分钟 Bash 上手指南

文章目录 bash 概念与学习目的第一个 bash 脚本bash 语法变量的使用位置参数管道符号(过滤条件)重定向符号条件测试命令条件语句case 条件分支Arrayfor 循环函数exit 关键字 bash 脚本记录历史命令查询文件分发内容 bash 概念与学习目的 bash&#xff0…

吐血整理:在 Docker 中运行 Milvus

直接用docker 错误命令(这个我试了三遍,浪费了很多时间): docker run -d --name milvus -p 19530:19530 -p 9091:9091 -v /var/lib/milvus:/var/lib/milvus milvusdb/milvus:latest 先看报错: 2025-02-24 16:02:39 …

GEE中的JavaScript语法基础

以下是Google Earth Engine(GEE)中JavaScript语法的基础知识,这些知识可以帮助你在GEE环境中进行有效的编码和数据处理: JavaScript语法基础 1. 变量和数据类型 变量声明:在GEE中,我们使用 var 关键字来声…

【高并发】高并发架构设计

一、问题拆解方法论 明确场景边界 流量规模(QPS/TPS/数据量)业务特征(读多写少/写密集型/实时性要求)容忍度(延迟要求/数据一致性级别) 示例: “在电商秒杀场景中,我们面对的是瞬时10万QPS的读请求洪峰,要求99.9%请求在200ms内响应,且要保证库存准确性”分层优化策略…