如何告诉Shap树解释器和Shap值计算器哪些变量是分类的?

时间:2019-07-31 07:33:12

标签: python lightgbm shap

我需要更好地了解我的LightGBM模型,因此我正在使用Shap Tree解释器。 lightGBM需要对数据进行编码,我正在将相同的数据传递给树解释器。因此,我担心Shap Tree Explainer和Shap值会将我的数据视为数字数据。如何指定数据是分类的?这会改变“ Shap值”计算吗?

我已经阅读了链接中提供的文档-https://shap.readthedocs.io/en/latest/

1 个答案:

答案 0 :(得分:2)

shap无法处理类型object的特征。只需确保您的连续变量的类型为float,类别变量的类型为category


for cont in continuous_variables:
    df[cont] = df[cont].astype('float64')

for cat in categorical_variables:
    df[cat] = df[cat].astype('category')

最后,还需要确保在参数中提供相应的值:

params = {
    'objective': "binary", 
    'num_leaves': 100, 
    'num_trees': 500, 
    'learning_rate': 0.1, 
    'tree_learner': 'data', 
    'device': 'cpu', 
    'seed': 132, 
    'max_depth': -1, 
    'min_data_in_leaf': 50, 
    'subsample': 0.9, 
    'feature_fraction': 1, 
    'metric': 'binary_logloss', 
    'categorical_feature': ['categoricalFeature1', 'categoricalFeature2']
}

bst = lgbm.Booster(model_file='model_file.txt')
tree_explainer = shap.TreeExplainer(bst)
tree_explainer.model.original_model.params = params

shap_values_result = tree_explainer.shap_values(df[features], y=df[target])

或者,您可以选择在分类功能上应用标签编码。例如,

df['categoricalFeature'] = df['categoricalFeature'].astype('category')
df['categoricalFeature'] = df['categoricalFeature'].cat.codes

请注意,请确保您可以重现此映射,以便也可以以相同的方式转换验证/测试数据集。