当前位置: 首页 > news >正文

【NLP 困惑度解析和python实现】

**困惑度(Perplexity)**是自然语言处理和机器学习中常用的评价指标,尤其在评估语言模型时广泛使用。它衡量的是一个概率模型对一个样本(如一句话)的预测能力。


一、困惑度的定义

对于一个语言模型 $ P $ 和一个测试语料 $ W = w_1, w_2, \dots, w_N $,其困惑度定义为:

Perplexity = P ( w 1 , w 2 , … , w N ) − 1 N = exp ⁡ ( − 1 N ∑ i = 1 N log ⁡ P ( w i ) ) \text{Perplexity} = P(w_1, w_2, \dots, w_N)^{-\frac{1}{N}} = \exp\left( -\frac{1}{N} \sum_{i=1}^N \log P(w_i) \right) Perplexity=P(w1,w2,,wN)N1=exp(N1i=1NlogP(wi))

其中:

  • $ N $ 是测试集中词的总数;
  • $ P(w_i) $ 是模型对第 $ i $ 个词的概率估计;
  • 求和是对所有词的概率取对数后的总和;
  • 外层指数化是为了得到更直观的数值。

二、计算步骤

假设你有一个语言模型,并且已经对某个句子做了概率预测(即每个词的概率),你可以按以下步骤计算困惑度:

步骤 1:获取词的对数概率

给定一个句子,例如:

“the cat sat on the mat”

假设你的模型输出了每个词的条件概率如下:

概率 P ( w i ) P(w_i) P(wi) log ⁡ P ( w i ) \log P(w_i) logP(wi)
the0.1-2.30
cat0.05-3.00
sat0.02-3.91
on0.07-2.66
the0.1-2.30
mat0.08-2.53

注意,上表中使用的 log ⁡ \log log 是以自然对数(ln)为基础的。

步骤 2:求平均对数概率

avg_log_prob = 1 N ∑ i = 1 N log ⁡ P ( w i ) = − 2.30 − 3.00 − 3.91 − 2.66 − 2.30 − 2.53 6 = − 16.7 6 = − 2.783 \text{avg\_log\_prob} = \frac{1}{N} \sum_{i=1}^N \log P(w_i) = \frac{-2.30 -3.00 -3.91 -2.66 -2.30 -2.53}{6} = \frac{-16.7}{6} = -2.783 avg_log_prob=N1i=1NlogP(wi)=62.303.003.912.662.302.53=616.7=2.783

步骤 3:计算困惑度

Perplexity = exp ⁡ ( − avg_log_prob ) = exp ⁡ ( 2.783 ) ≈ 16.16 \text{Perplexity} = \exp(-\text{avg\_log\_prob}) = \exp(2.783) \approx 16.16 Perplexity=exp(avg_log_prob)=exp(2.783)16.16


三、代码示例(Python)

import math# 假设这是模型对每个词的预测概率
probs = [0.1, 0.05, 0.02, 0.07, 0.1, 0.08]# 计算 log probabilities
log_probs = [math.log(p) for p in probs]# 平均 log probability
avg_log_prob = sum(log_probs) / len(log_probs)# 计算困惑度
perplexity = math.exp(-avg_log_prob)print("Perplexity:", perplexity)

输出类似:

Perplexity: 16.16

四、解释与意义

  • 困惑度越低越好,表示模型对测试数据的预测越准确。
  • 如果困惑度很高,说明模型难以确定下一个词是什么,不确定性大。
  • 最理想的情况是模型对每个词都给出高概率,这时困惑度会很低。

五、注意事项

  1. 平滑处理:实际中由于某些词可能未出现在训练数据中,直接使用最大似然估计会导致概率为 0,困惑度变成无穷大。通常需要使用 拉普拉斯平滑Kneser-Ney 平滑 等方法。

  2. 交叉熵损失:困惑度和交叉熵密切相关。实际上,在深度学习中我们常用交叉熵损失来训练语言模型,而困惑度是它的指数形式:

    Perplexity = exp ⁡ ( CrossEntropyLoss ) \text{Perplexity} = \exp(\text{CrossEntropyLoss}) Perplexity=exp(CrossEntropyLoss)


相关文章:

  • 填涂颜色(bfs)
  • 3D 数据可视化系统是什么?具体应用在哪方面?
  • Chrome安装最新vue-devtool插件
  • Flutter在键盘的上方加一个完成按钮
  • 精益数据分析(57/126):创业移情阶段的核心要点与实践方法
  • mac latex vscode 配置
  • 40:相机与镜头选型
  • VUE中 为什么是 this.$store.state.user.name,而不是 this.$store.user.state.name?
  • 16S18S_OTU分析(3)
  • 容器编排的革命:Kubernetes如何引领IT的云原生时代
  • 2011-2019年各省总抚养比数据
  • 20250507训练赛补题
  • Doris与ClickHouse深度比较
  • vue 去掉右边table的下拉条与下面的白色边框并补充满
  • 数据库基础复习笔记
  • 如何实现一个运动会计分系统?(C语言版)
  • 首个专业AI设计Agent发布-Lovart
  • 鸿蒙OSUniApp制作一个小巧的图片浏览器#三方框架 #Uniapp
  • 深入浅出入侵检测系统(IDS)的工作原理与应用场景
  • 第二章:CSS秘典 · 色彩与布局的力量
  • 网约车座椅靠背张贴“差评者得癌症”,如祺出行:未收到投诉无法处理
  • 多条跨境铁路加速推进,谁是下一个“超级枢纽”?
  • 白玉兰奖征片综述丨动画的IP生命力
  • KPL“王朝”诞生背后:AG和联赛一起迈向成熟
  • 违法违规收集使用个人信息,爱奇艺、轻颜等65款App被点名
  • 微软宣布将裁员3%