news 2026/3/2 12:50:08

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/2/25 20:58:37

永磁同步力矩电机设计中的那些“坑“与解法

永磁同步力矩电机设计与仿真分析 将慢速、大转矩的永磁同步力矩电机列为主要研究对象,主要针对永磁同步力矩电机的电磁设计和模拟展开了工作。 运用解析方法,对分数槽集中绕组电动机的磁动势波形、气隙磁密度谐波和绕组的结构进行了分析,并给…

作者头像 李华
网站建设 2026/3/2 12:46:19

基于Comsol的管内两相流流型模拟的算例(泡状流和弹状流),可在此基础上熟悉管内泡状流和弹状...

基于Comsol的管内两相流流型模拟的算例(泡状流和弹状流),可在此基础上熟悉管内泡状流和弹状流的模拟方法,分析其规律。 以下为水平管、竖直管、倾斜管以及基于气泡流模型的管内气液两相流模拟部分结果。两相流模拟总带着点玄学色彩…

作者头像 李华
网站建设 2026/2/28 22:45:46

Simpack地铁A、B型车模型:精细打造城市轨道交通模拟体验

simpack地铁a、b型车模型。 凌晨三点的屏幕还亮着,鼠标在参数列表里反复横跳。刚接手地铁列车动力学仿真那会儿,总被转向架上那些密密麻麻的参数搞得头大。直到用simpack建完第八个车型模型,才突然发现A、B型地铁这对"双胞胎"藏着…

作者头像 李华
网站建设 2026/2/27 5:21:58

启动Maxwell工程时的第一反应

maxwell电机电磁仿真 新能源扁线电机设计及优化分析 电机仿真每次双击ANSYS Electronics Desktop图标的时候,总感觉像是要打开魔法工具箱——尤其是处理新能源扁线电机这类高密度怪物。鼠标刚拖进Maxwell 2D组件,满屏的几何参数立刻开始挑衅:…

作者头像 李华
网站建设 2026/2/25 13:28:21

“工业多缺陷检测漏检多 后来才知道加跨模态注意力对齐特征”

💓 博客主页:借口的CSDN主页 ⏩ 文章专栏:《热点资讯》 目录我和AI的相爱相杀史:当科技开始懂你家的猫 一、职场篇:AI面试官让我学会了闭嘴 二、工业篇:机器人同事的反杀 三、生活篇:智能家居的…

作者头像 李华