MLJAR-Supervised中自定义评估指标NMAE的实现要点
2025-06-26 09:43:43作者:范靓好Udolf
在机器学习项目中使用自定义评估指标是常见需求,MLJAR-Supervised作为一个自动化机器学习工具,支持用户自定义评估函数。本文将以NMAE(Normalized Mean Absolute Error)指标为例,详细介绍在MLJAR-Supervised中实现自定义评估指标的关键技术要点。
什么是NMAE指标
NMAE(归一化平均绝对误差)是MAE指标的归一化版本,计算公式为:
NMAE = MAE / mean(|true_values|)
相比原始MAE,NMAE通过除以真实值的绝对均值,使得误差值在不同量纲的数据集间具有可比性。
基础实现的问题
最直观的NMAE实现可能如下:
def NMAE(true, pred, sample_weight=None):
mae = np.mean(np.abs(true - pred))
score = mae / np.mean(np.abs(true))
return score
然而在MLJAR-Supervised的集成学习(Ensemble)阶段,这种实现会报错:"unsupported operand type(s) for +: 'float' and 'NoneType'"
问题原因分析
该错误源于MLJAR-Supervised的集成学习阶段对预测结果的特殊处理方式:
- 集成学习阶段传入的true和pred参数可能是pandas DataFrame格式
- 预测结果pred可能是二维数组(pred.shape = [n_samples, 1]),而非一维数组
健壮的实现方案
为确保自定义指标在所有学习阶段(包括集成学习)都能正常工作,需要添加类型检查和维度处理:
def NMAE(true, pred, sample_weight=None):
# 类型转换处理
if isinstance(true, pd.DataFrame):
true = np.array(true)
if isinstance(pred, pd.DataFrame):
pred = np.array(pred)
# 维度处理
if len(pred.shape) == 2 and pred.shape[1] == 1:
pred = pred.ravel()
# 核心计算逻辑
mae = np.mean(np.abs(true - pred))
score = mae / np.mean(np.abs(true))
return score
关键实现要点
- 类型检查与转换:使用isinstance检查输入是否为DataFrame,必要时转换为numpy数组
- 维度处理:将二维预测结果(pred.shape = [n_samples, 1])转换为一维数组
- 核心计算:保持原始NMAE计算逻辑不变
- 权重参数:虽然本例未使用sample_weight,但保留参数接口以保持兼容性
总结
在MLJAR-Supervised中实现自定义评估指标时,不能仅考虑基础计算逻辑,还需要考虑框架在不同学习阶段可能的数据格式变化。特别是集成学习阶段,预测结果的格式可能与基础学习器阶段不同。通过添加类型检查和维度处理,可以确保自定义指标在所有学习阶段都能稳定工作。
这种实现方式不仅适用于NMAE指标,也可作为其他自定义评估指标的参考模板,帮助开发者构建更健壮的自动化机器学习流程。
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
three-cesium-examplesthree.js cesium.js 原生案例JavaScript00
weapp-tailwindcssweapp-tailwindcss - bring tailwindcss to weapp ! 把 tailwindcss 原子化思想带入小程序开发吧 !TypeScript00
CherryUSBCherryUSB 是一个小而美的、可移植性高的、用于嵌入式系统(带 USB IP)的高性能 USB 主从协议栈C00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
580
3.94 K
Ascend Extension for PyTorch
Python
410
489
React Native鸿蒙化仓库
JavaScript
315
367
暂无简介
Dart
821
201
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
904
719
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
360
226
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.41 K
796
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
昇腾LLM分布式训练框架
Python
125
149