TorchMetrics中Pearson相关系数计算的聚合问题分析与修复
2025-07-03 17:42:59作者:廉皓灿Ida
问题背景
在机器学习评估指标库TorchMetrics中,Pearson相关系数的计算实现存在两个关键问题:
- 状态修改问题:
_final_aggregation函数在多设备环境下会原地修改输入状态,导致后续计算出现不准确结果 - 数值稳定性问题:当某些设备没有数据时,计算过程中会出现NaN值
问题分析
Pearson相关系数的多设备聚合计算需要合并来自不同设备的统计量,包括均值、方差和协方差等。原实现存在以下技术缺陷:
- 原地修改问题:函数直接修改输入张量,这在多设备分布式训练场景下会导致后续计算使用已被修改的状态
- 数值稳定性:当两个设备的样本数n1和n2都为0时,除法运算会产生NaN,而实际上这些位置的统计量应该保持为0
- 算法复杂度:原实现使用了较为复杂的计算公式,增加了理解和维护难度
解决方案
基于算法文献和数值稳定性考虑,我们提出以下改进方案:
def _final_aggregation(
means_x: torch.Tensor,
means_y: torch.Tensor,
vars_x: torch.Tensor,
vars_y: torch.Tensor,
corrs_xy: torch.Tensor,
nbs: torch.Tensor,
eps: float = 1e-10,
) -> tuple[torch.Tensor, torch.Tensor, torch.Tensor, torch.Tensor, torch.Tensor, torch.Tensor]:
"""聚合来自多个设备的统计量"""
if len(means_x) == 1:
return means_x[0], means_y[0], vars_x[0], vars_y[0], corrs_xy[0], nbs[0]
mx1, my1, vx1, vy1, cxy1, n1 = means_x[0], means_y[0], vars_x[0], vars_y[0], corrs_xy[0], nbs[0]
for i in range(1, len(means_x)):
mx2, my2, vx2, vy2, cxy2, n2 = means_x[i], means_y[i], vars_x[i], vars_y[i], corrs_xy[i], nbs[i]
# 处理零样本情况
nb = torch.where(torch.logical_or(n1, n2), n1 + n2, eps)
# 计算合并均值
mean_x = (n1 * mx1 + n2 * mx2) / nb
mean_y = (n1 * my1 + n2 * my2) / nb
# 计算合并方差和协方差
n12_b = n1 * n2 / nb
delta_x = mx2 - mx1
delta_y = my2 - my1
var_x = vx1 + vx2 + n12_b * delta_x ** 2
var_y = vy1 + vy2 + n12_b * delta_y ** 2
corr_xy = cxy1 + cxy2 + n12_b * delta_x * delta_y
mx1, my1, vx1, vy1, cxy1, n1 = mean_x, mean_y, var_x, var_y, corr_xy, nb
return mean_x, mean_y, var_x, var_y, corr_xy, nb
技术优势
- 算法正确性:基于可靠的并行统计算法文献实现,确保数学正确性
- 数值稳定性:通过eps参数处理零样本情况,避免NaN值产生
- 性能优化:简化计算公式,提高计算效率
- 可维护性:代码结构更清晰,便于理解和维护
实际影响
该修复对以下场景尤为重要:
- 分布式训练:确保在多GPU/多节点环境下指标计算的准确性
- 稀疏数据:处理某些设备可能没有数据的情况
- 长期训练:避免状态污染导致的指标漂移
结论
TorchMetrics中的Pearson相关系数计算经过此次修复,在正确性、稳定性和性能方面都得到了显著提升。这一改进特别有利于大规模分布式训练场景下的模型评估工作,确保了评估指标的准确性和可靠性。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0138- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
MiniCPM-V-4.6这是 MiniCPM-V 系列有史以来效率与性能平衡最佳的模型。它以仅 1.3B 的参数规模,实现了性能与效率的双重突破,在全球同尺寸模型中登顶,全面超越了阿里 Qwen3.5-0.8B 与谷歌 Gemma4-E2B-it。Jinja00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00
MusicFreeDesktop插件化、定制化、无广告的免费音乐播放器TypeScript00
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
726
4.66 K
Ascend Extension for PyTorch
Python
597
750
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.09 K
610
deepin linux kernel
C
29
16
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
997
138
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
427
377
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
992
986
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.65 K
970
暂无简介
Dart
969
246
昇腾LLM分布式训练框架
Python
161
190