gpt4 book ai didi

python - RandomForestClassifier(sklearn)的predict_proba(X)似乎是静态的?

转载 作者:太空宇宙 更新时间:2023-11-03 16:18:46 28 4
gpt4 key购买 nike

对于所有类,我想检索给定样本的预测分数/概率。我正在使用 sklearn 的 RandomForestClassifier。如果我使用 .predict(),我的代码运行良好。然而,为了显示概率,我使用 .predict_proba(X) 并且它始终返回相同的值,即使当 X 发生变化时也是如此。为什么会这样以及如何解决?

我正在将代码分解为相关部分:

# ... code ... feature generation / gets the feature data
if rf is None:
rf = RandomForestClassifier(n_estimators=80)
rf.fit(featureData, classes)
else:
prediction = rf.predict(featureData) # gets the right class / always different
proba = rf.predict_proba(featureData)
print proba # this prints always the same values for all my 40 classes

有趣的是,max(proba) 检索 .predict() 在第一次运行时返回的类。由于 .predict() 按预期工作,我相信错误出在 sklearn 一侧,即我猜想需要设置一个标志。

有人有想法吗?

最佳答案

我猜问题是你总是将相同的参数传递给predict_proba。这是我从 iris 数据集构建树木森林的代码:

from sklearn import datasets
from sklearn.ensemble import RandomForestClassifier
iris = datasets.load_iris()
X = iris.data
y = iris.target
rf = RandomForestClassifier(n_estimators=80)
rf.fit(X, y)

当我调用方法 predictpredict_proba 时,不同参数的类和类对数概率预测也不同,正如人们可以合理预期的那样。

示例运行:

In [82]: a, b = X[:3], X[-3:]

In [83]: a
Out[83]:
array([[ 5.1, 3.5, 1.4, 0.2],
[ 4.9, 3. , 1.4, 0.2],
[ 4.7, 3.2, 1.3, 0.2]])

In [84]: b
Out[84]:
array([[ 6.5, 3. , 5.2, 2. ],
[ 6.2, 3.4, 5.4, 2.3],
[ 5.9, 3. , 5.1, 1.8]])

In [85]: rf.predict(a)
Out[85]: array([0, 0, 0])

In [86]: rf.predict(b)
Out[86]: array([2, 2, 2])

In [87]: rf.predict_proba(a)
Out[87]:
array([[ 1., 0., 0.],
[ 1., 0., 0.],
[ 1., 0., 0.]])

In [88]: rf.predict_proba(b)
Out[88]:
array([[ 0. , 0. , 1. ],
[ 0. , 0.0125, 0.9875],
[ 0. , 0.0375, 0.9625]])

关于python - RandomForestClassifier(sklearn)的predict_proba(X)似乎是静态的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38672779/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com