首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >高斯过程的SHAP值为零。

高斯过程的SHAP值为零。
EN

Stack Overflow用户
提问于 2021-03-03 11:49:55
回答 2查看 859关注 0票数 2

我试图使用SHAP库获得高斯过程回归(GPR)模型的SHAP值。然而,所有SHAP值都为零。我正在使用正式文件中的示例。我只是把模型改成了探地雷达。

代码语言:javascript
复制
import sklearn
from sklearn.model_selection import train_test_split
import numpy as np
import shap
import time
from sklearn.gaussian_process import GaussianProcessRegressor
from sklearn.gaussian_process.kernels import Matern, WhiteKernel, ConstantKernel

shap.initjs()

X,y = shap.datasets.diabetes()
X_train,X_test,y_train,y_test = train_test_split(X, y, test_size=0.2, random_state=0)

# rather than use the whole training set to estimate expected values, we summarize with
# a set of weighted kmeans, each weighted by the number of points they represent.
X_train_summary = shap.kmeans(X_train, 10)


kernel = Matern(length_scale=2, nu=3/2) + WhiteKernel(noise_level=1)   

gp = GaussianProcessRegressor(kernel)
gp.fit(X_train, y_train)

# explain all the predictions in the test set
explainer = shap.KernelExplainer(gp.predict, X_train_summary)
shap_values = explainer.shap_values(X_test)
shap.summary_plot(shap_values, X_test)

运行上述代码将给出以下情节:

当我使用神经网络或线性回归,上述代码工作良好,没有问题。

如果你知道如何解决这个问题,请告诉我。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-03-03 14:41:47

你的模型不能预测任何事情:

代码语言:javascript
复制
plt.scatter(y_test, gp.predict(X_test));

适当地训练你的模型,如下所示:

代码语言:javascript
复制
plt.scatter(y_test, gp.predict(X_test));

你可以走了:

代码语言:javascript
复制
explainer = shap.KernelExplainer(gp.predict, X_train_summary)
shap_values = explainer.shap_values(X_test)
shap.summary_plot(shap_values, X_test)

完全可复制的示例

代码语言:javascript
复制
import sklearn
from sklearn.model_selection import train_test_split
import numpy as np
import shap
import time
from sklearn.gaussian_process import GaussianProcessRegressor
from sklearn.gaussian_process.kernels import WhiteKernel, DotProduct

X,y = shap.datasets.diabetes()
X_train,X_test,y_train,y_test = train_test_split(X, y, test_size=0.2, random_state=0)
X_train_summary = shap.kmeans(X_train, 10)
kernel = DotProduct() + WhiteKernel()

gp = GaussianProcessRegressor(kernel)
gp.fit(X_train, y_train)

explainer = shap.KernelExplainer(gp.predict, X_train_summary)
shap_values = explainer.shap_values(X_test)
shap.summary_plot(shap_values, X_test)
票数 1
EN

Stack Overflow用户

发布于 2022-09-21 15:57:59

试试下面的代码:

代码语言:javascript
复制
kernel = 1.0 * Matern(length_scale=1.0, nu=2.5) + \
WhiteKernel(noise_level=10**-1,noise_level_bounds=(10**-1, 10**1))

model = GaussianProcessRegressor(kernel=kernel, 
                           optimizer='fmin_l_bfgs_b',random_state=123)              


explainer = shap.Explainer(model.predict,X_train)
shap_values = explainer.shap_values(X_train)
shap.plots.bar(shap_values)                                  ## bar plot
shap.summary_plot(shap_values, X_train,show=False)           ## summary       
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66456509

复制
相关文章

相似问题

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