首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么每次我在max_depth中运行决策树时,GridSearchCV的回答都会改变?

为什么每次我在max_depth中运行决策树时,GridSearchCV的回答都会改变?
EN

Stack Overflow用户
提问于 2020-05-14 11:24:54
回答 1查看 300关注 0票数 0
代码语言:javascript
复制
Hyperparameters={'max_depth':np.arange(1,100,1)}

dectree= tree.DecisionTreeClassifier()

cv_grid = GridSearchCV(estimator= dectree ,param_grid = Hyperparameters, scoring ='accuracy',cv = 10)

cv_grid= cv_grid.fit(X_train, y_train)

cv_grid.best_params_
EN

回答 1

Stack Overflow用户

发布于 2020-05-14 11:45:10

这是因为决策树算法具有随机性。来自决策树文档

即使拆分器被设置为“最佳”,每次拆分时都会随机排列这些特性。但是,即使是max_features=n_features,最佳发现的分割可能因不同的运行而有所不同。既然如此,如果标准的改进对于几个分裂是相同的,并且必须随机选择一个分裂。

所以,随机性是正常的。如果希望采用确定性方法,请设置random_state参数(即指定种子),每次都会得到相同的结果。下面是一个例子:

代码语言:javascript
复制
from sklearn.model_selection import GridSearchCV 
import numpy as np
from sklearn import tree

X_train = np.random.rand(100, 10)
y_train = np.random.randint(0, 3, 100)

for i in range(10):
    Hyperparameters={'max_depth':np.arange(1,100,1)}
    dectree= tree.DecisionTreeClassifier(random_state=42)
    cv_grid = GridSearchCV(estimator= dectree ,param_grid = Hyperparameters, 
                           scoring ='accuracy',cv = 5)
    cv_grid= cv_grid.fit(X_train, y_train)
    print(cv_grid.best_params_)
代码语言:javascript
复制
{'max_depth': 4}
{'max_depth': 4}
{'max_depth': 4}
{'max_depth': 4}
{'max_depth': 4}

当我使用参数在没有的情况下测试运行random_state时,我得到了以下内容:

代码语言:javascript
复制
{'max_depth': 5}
{'max_depth': 65}
{'max_depth': 59}
{'max_depth': 5}
{'max_depth': 93}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61796181

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档