如何解决RandomizedSearchCV 的 best_params 没有按预期显示输出
我试图改进我的随机森林分类器参数,但在查看其他人的一些示例后,我得到的输出看起来不像我预期的输出。
我正在使用的代码:
train_x,test_x,train_y,test_y = train_test_split(df,avalanche,shuffle=False)
# Create the random forest
rf = RandomForestClassifier()
rf_random = RandomizedSearchCV(estimator=rf,param_distributions=random_grid,n_iter=100,cv=3,verbose=2,random_state=42,n_jobs=-1)
# Train the model
rf_random.fit(train_x,train_y)
print(rf_random.best_params_)
我得到的输出(这只是几行,但它给了我几百行):
Fitting 3 folds for each of 100 candidates,totalling 300 fits
[CV] END bootstrap=True,max_depth=30,max_features=sqrt,min_samples_leaf=1,min_samples_split=5,n_estimators=400; total time= 1.3s
[CV] END bootstrap=True,n_estimators=400; total time= 1.4s
[CV] END bootstrap=False,max_depth=10,min_samples_leaf=2,n_estimators=1200; total time= 3.8
我期待的输出:
{'bootstrap': True,'max_depth': 70,'max_features': 'auto','min_samples_leaf': 4,'min_samples_split': 10,'n_estimators': 400}
来自 this 网站。
有谁知道我做错了什么或者我应该改变什么以使输出成为我期望的那样?
解决方法
由于verbose=2
,您获得了该输出。它的值越高,打印的文本就越多。这些文本提示不是结果。它们只是告诉您搜索当前适合数据的模型。
这有助于查看搜索的当前进度(有时可能需要几天时间,因此很高兴知道搜索当前处于流程的哪个部分)。如果您不想显示此文本,请设置 verbose=0
。
您还没有得到预期的结果,因为 rf_random
仍在为数据拟合模型。
搜索完成后,使用 rf_random.best_params_
获得您想要的输出。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。