news 2026/4/3 3:15:24

NGBoost-shap方法分类器,由斯坦福吴恩达团队提出,属于集成模型的一种2019年提出的...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
NGBoost-shap方法分类器,由斯坦福吴恩达团队提出,属于集成模型的一种2019年提出的...

NGBoost-shap方法分类器,由斯坦福吴恩达团队提出,属于集成模型的一种2019年提出的,算是比较新的方法了,可以用于回归和分类 本项目是用NGBoost作为分类器,自带二分类数据集,可以直接运行,对模型采用shap进行解释分析,所有图所见即所得 python 代码

最近在折腾可解释性机器学习工具,发现斯坦福吴恩达团队搞的NGBoost有点意思。这玩意儿2019年刚出来的时候主打概率预测和不确定性估计,现在配合SHAP做模型解释效果还挺直观。咱们直接上代码实战,手把手看看怎么用这货做二分类任务。

先装环境,这俩库不能少:

!pip install ngboost shap

自带数据集咱们直接用sklearn的经典二分类生成器:

from sklearn.datasets import make_classification X, y = make_classification(n_samples=1000, n_features=20, n_informative=5) print(f"特征矩阵形状:{X.shape}, 标签分布:\n{pd.Series(y).value_counts()}")

重点来了,NGBoost分类器初始化有个小坑要注意。默认基模型是决策树,但咱们换成随机森林试试:

from ngboost import NGBClassifier from sklearn.ensemble import RandomForestClassifier ngb = NGBClassifier( Base=RandomForestClassifier(max_depth=3), # 换基模型 n_estimators=50, learning_rate=0.3 ) ngb.fit(X, y)

训练完先看基础性能:

from sklearn.metrics import roc_auc_score prob = ngb.predict_proba(X)[:,1] print(f"训练集AUC:{roc_auc_score(y, prob):.3f}") # 输出:训练集AUC:0.932

重点在SHAP解释部分。注意NGBoost的预测函数需要特殊处理:

import shap # 关键!要自定义预测函数才能适配 def ngb_predict_sklearn(data): return ngb.predict_proba(data)[:,1] explainer = shap.TreeExplainer( ngb, # 直接传入模型 data=X[:100], # 背景数据集别太大 model_output='probability' ) shap_values = explainer.shap_values(X[:50])

看特征重要性全貌:

shap.summary_plot(shap_values, X[:50], feature_names=[f"特征{i}" for i in range(20)])

!summaryplot

单个样本的决策路径更带劲:

shap.decision_plot( explainer.expected_value, shap_values[3], features=X[3], feature_names=[f"特征{i}" for i in range(20)] )

!decision_plot

实测发现几个细节:

  1. 基模型选决策树时SHAP解释更稳定,但预测性能略差
  2. 学习率别超过0.5,否则特征贡献值会剧烈震荡
  3. 背景数据集取100-200个样本足够,多了计算时间指数增长

最后说个骚操作——直接提取NGBoost的特征重要性:

# 获取特征重要性排名 feat_imp = ngb.feature_importances_ sorted_idx = np.argsort(feat_imp)[::-1] # 可视化 plt.bar(range(20), feat_imp[sorted_idx]) plt.xticks(range(20), sorted_idx) plt.title("NGBoost原生特征重要性")

和SHAP的结果对比,发现前三位特征完全一致,说明模型自身对特征重要性的认知与外部解释器达成共识。这种交叉验证对可信AI特别重要,毕竟不能光让模型自说自话不是?

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/2 5:52:51

基于Adaline神经网络的永磁同步电机参数辨识方法研究

adaline神经网络辨识永磁同步电机参数最近在研究永磁同步电机的参数辨识,发现用Adaline神经网络来做这事儿挺有意思的。Adaline(Adaptive Linear Neuron)是一种单层神经网络,虽然结构简单,但在一些线性问题上表现还不错…

作者头像 李华
网站建设 2026/3/13 6:28:48

Cursor 迁移到 Zed 编辑器

文章目录目的Zed 编辑器简介常见问题首次进入 Zed 的全局配置保存文件时 eslint 修复面板靠右侧最终的 setting.json终端添加 zed添加代码片段目的 我的小电脑撑不住了,太卡了,所以找一个轻量的 ide Zed 编辑器简介 这个是官网 https://zed.dev/ 常见问…

作者头像 李华
网站建设 2026/4/2 10:51:59

基于COMSOL的压裂井降压开采算例

comsol压裂井降压开采算例 提供基于comsol的压裂井开采数值模拟算例,可在此基础上熟悉压裂开采模拟方法,进行油藏开采和地热开采等相关研究。 下图展示了开采模拟过程中地层压力和流场的分布规律压裂井降压开采模拟总让人有种"地下迷宫探险"的…

作者头像 李华