MAD(Median Absolute Deviation)详解:最稳健的尺度估计方法

MAD(Median Absolute Deviation)详解:最稳健的尺度估计方法

一、为什么需要 MAD?

在统计分析中,我们经常需要衡量数据的"离散程度",最常见的方法是标准差:

σ=1n∑(xi−xˉ)2 \sigma = \sqrt{\frac{1}{n} \sum (x_i - \bar{x})^2} σ=n1∑(xi−xˉ)2

但是标准差有一个致命问题:

对异常值极其敏感


二、异常值的影响

考虑数据:

1,2,3,4,5\] \[1, 2, 3, 4, 5\] \[1,2,3,4,5

标准差较小。

但如果加入一个异常值:

1,2,3,4,100\] \[1, 2, 3, 4, 100\] \[1,2,3,4,100

标准差会被严重放大。


三、MAD 的定义

MAD(Median Absolute Deviation)定义为:

MAD=median(∣xi−median(x)∣) \text{MAD} = \text{median}(|x_i - \text{median}(x)|) MAD=median(∣xi−median(x)∣)

步骤:

  1. 计算中位数
  2. 计算每个点到中位数的绝对偏差
  3. 再取这些偏差的中位数

四、为什么 MAD 更稳健?

关键原因:

  • 使用 median 而不是 mean
  • 不会被极端值拉偏

五、举例说明

数据:

1,2,3,4,100\] \[1, 2, 3, 4, 100\] \[1,2,3,4,100

步骤:

  1. 中位数:

median=3 \text{median} = 3 median=3

  1. 绝对偏差:

2,1,0,1,97\] \[2, 1, 0, 1, 97\] \[2,1,0,1,97

  1. MAD:

MAD=1 \text{MAD} = 1 MAD=1

可以看到:

异常值 100 并没有影响 MAD


六、MAD 与标准差的关系

为了让 MAD 可以近似标准差,需要乘一个系数:

σ≈1.4826×MAD \sigma \approx 1.4826 \times \text{MAD} σ≈1.4826×MAD

这个系数来自正态分布的性质。


七、为什么是 1.4826?

对于标准正态分布:

median(∣Z∣)≈0.6745 \text{median}(|Z|) \approx 0.6745 median(∣Z∣)≈0.6745

所以:

10.6745≈1.4826 \frac{1}{0.6745} \approx 1.4826 0.67451≈1.4826


八、如何用 MAD 判断异常点?

在得到鲁棒尺度估计之后:

σ=1.4826⋅MAD \sigma = 1.4826 \cdot \text{MAD} σ=1.4826⋅MAD

我们可以定义一个"鲁棒标准化距离"(类似 z-score):

zi=∣xi−median(x)∣σ z_i = \frac{|x_i - \text{median}(x)|}{\sigma} zi=σ∣xi−median(x)∣


判断规则

设定阈值 (k),通常取:

  • (k = 2.5)(较宽松)
  • (k = 3)(常用)
  • (k = 3.5)(更严格)

则:

zi>k⇒xi 是异常点 z_i > k \Rightarrow x_i \text{ 是异常点} zi>k⇒xi 是异常点

zi≤k⇒xi 是正常点 z_i \le k \Rightarrow x_i \text{ 是正常点} zi≤k⇒xi 是正常点


直观理解

  • 分子:点到"数据中心"的距离(用 median)
  • 分母:整体数据的"正常波动范围"(用 MAD)

所以:

zi=这个点偏离中心的程度(按整体尺度归一化) z_i = \text{这个点偏离中心的程度(按整体尺度归一化)} zi=这个点偏离中心的程度(按整体尺度归一化)


举例说明

数据:

1,2,3,4,100\] \[1, 2, 3, 4, 100\] \[1,2,3,4,100

  1. 中位数:

m=3 m = 3 m=3

  1. MAD:

MAD=1 \text{MAD} = 1 MAD=1

  1. 转换尺度:

σ=1.4826 \sigma = 1.4826 σ=1.4826

  1. 计算异常程度:

对 100:

z=∣100−3∣1.4826≈65 z = \frac{|100 - 3|}{1.4826} \approx 65 z=1.4826∣100−3∣≈65

远大于 3,因此:

100 是异常点 100 \text{ 是异常点} 100 是异常点


一句话总结

∣xi−median∣1.4826⋅MAD>k \frac{|x_i - \text{median}|}{1.4826 \cdot \text{MAD}} > k 1.4826⋅MAD∣xi−median∣>k

即可判定为异常点。

九、Python 示例

python 复制代码
import numpy as np

def mad(x):
    med = np.median(x)
    return np.median(np.abs(x - med))

def robust_sigma(x):
    return 1.4826 * mad(x)

十、应用场景

MAD 常用于:

  • 鲁棒统计
  • 异常检测
  • 信号处理

十一、总结

MAD 是一个:

  • 简单
  • 稳健
  • 抗异常

的尺度估计方法

在任何存在异常值的场景中,都优于标准差。

相关推荐
火山引擎开发者社区9 分钟前
被 Vibe Coding 用户频点名的火山 Supabase 到底是个啥?一图来看懂
人工智能
火山引擎开发者社区18 分钟前
动手做 AI 实验赢好礼!产品 + 大模型免费额度限时供应!
人工智能
字节跳动视频云技术团队39 分钟前
从 VCloud 到 Agentic VCloud:Agent 时代的范式重构
人工智能·音视频开发
AKAMAI1 小时前
每百万 Token 成本砍六成,出海 AI 团队开始重算推理这笔账
人工智能·云计算
用户938515635072 小时前
从 Prompt 到 Harness:AI 工程化的三年跃迁与实战解码
javascript·人工智能
AI小老六2 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
甲维斯3 小时前
Agnes免费生图批图API+一键生图软件!
人工智能
April6663 小时前
Prompt-only 已死,Harness 才是 2026 的分水岭
人工智能
胡萝卜术3 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
没落英雄3 小时前
从零开始搭建一个 AI Agent —— LangChain + TypeScript 实战手记
前端·人工智能·架构