news 2026/1/16 16:21:10

大语言模型的词语生成机制:Logits、Softmax 与Sampling详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
大语言模型的词语生成机制:Logits、Softmax 与Sampling详解

大语言模型的词语生成机制:Logits、Softmax 与Sampling详解

大型语言模型(LLM)即使面对相同的提示,也能产生多样、富有创意且有时令人惊讶的输出。这种随机性不是bug,而是模型从概率分布中采样下一个标记的核心特性。本文将解析关键采样策略,并展示温度、top-ktop-p等参数如何影响一致性与创造力之间的平衡。

在本教程中,我们将采用实践方式来理解:

  • 对数如何变成概率
  • 温度、top-ktop-p抽样的工作原理
  • 不同采样策略如何影响模型的下一个token分布

到最后,你会理解LLM推理背后的机制,并能够调整输出的创造力或确定性。

我们开始吧。

概述

本文分为四个部分;它们是:

  • Logits如何转换为概率
  • Temperature温度
  • Top-k抽样
  • Top-p抽样

对数如何成为概率

当你向LLM提问时,它会输出一个logit向量。Logit是模型为词汇中每个可能的下一个词组分配的原始分数。

如果模型的词汇表为𝑉它会输出一个向量𝑉每个下一个词的位置。logit是一个真实的数字。它通过softmax函数转换为概率:


其中𝑥我是令牌的logit我以及𝑝我是对应的概率。Softmax将这些原始分数转换为概率分布。全部𝑝我为正数,且它们的和为1。

假设我们给模型这个提示:

今天的天气真___

模型将词汇中的每个词都视为可能的下一个词。为了简化,假设词汇中只有6个标记:

wonderful cloudy nice hot gloomy delicious

模型为每个令牌生成一个logit。以下是模型可能输出的对数示例集以及基于softmax函数的相应概率:

TokenLogitProbability
wonderful1.20.0457
cloudy2.00.1017
nice3.50.4556
hot3.00.2764
gloomy1.80.0832
delicious1.00.0374

你可以用PyTorch的softmax函数来确认:

importtorchimporttorch.nn.functionalasF vocab=["wonderful","cloudy","nice","hot","gloomy","delicious"]logits=torch.tensor([1.2,2.0,3.5,3.0,1.8,1.0])probs=F.softmax(logits,dim=-1)print(probs)# Output:# tensor([0.0457, 0.1017, 0.4556, 0.2764, 0.0832, 0.0374])

基于此结果,概率最高的代币为“好”。大型语言模型并不总是选择概率最高的令牌;相反,它们从概率分布中抽样,每次都产生不同的输出。在这种情况下,看到“漂亮”的概率是46%。

如果你想让模型给出更有创意的答案,如何改变概率分布,使得“阴云”、“高温”等答案也更频繁地出现?

温度

温度(𝑇)是一个模型推理参数。它不是一个模型参数;它是生成输出的算法中的一个参数。它在应用 softmax 前先对 logit 进行扩展:

你可以预期概率分布会更具确定性,如果𝑇 <1,因为 各值之间的差值𝑥我会被夸大。另一方面,如果𝑇 >1,作为每个值的差值𝑥我将被降低。

现在,让我们可视化温度对概率分布的影响:

importmatplotlib.pyplotaspltimporttorchimporttorch.nn.functionalasF vocab=["wonderful","cloudy","nice","hot","gloomy","delicious"]logits=torch.tensor([1.2,2.0,3.5,3.0,1.8,1.0])# (vocab_size,)scores=logits.unsqueeze(0)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/26 19:51:47

关于大型语言模型的10个常见误解

关于大型语言模型的10个常见误解 大型语言模型(LLMs)已迅速融入我们的日常工作流程。从编写函数式代码的编码代理,到帮助我们头脑风暴的简单聊天会话,LLM已成为各行各业必备的生产力工具。 尽管广泛采用,当前用户和计划构建LLM应用的开发者之间仍存在根本误解。这些误解往…

作者头像 李华
网站建设 2025/12/27 6:20:39

锐捷RGSP | 全局地址绑定和端口保护原理与应用

一、全局安全地址绑定概述 1. 全局安全地址绑定背景 全局地址绑定原理和端口安全类似,全局地址绑定是在全局配置模式下绑定合法的IP+MAC,匹配绑定条目的终端可以在设备上的端口之间不受限制的移动。 端口安全可以通过端口安全技术来控制各个端口进入的IP报文。端口安全技术…

作者头像 李华
网站建设 2025/12/22 21:03:41

球类运动场景中的多目标检测与追踪_基于yolo13-C3k2-HDRAB模型实现

1. 球类运动场景中的多目标检测与追踪_基于YOLO13-C3k2-HDRAB模型实现 &#x1f3be; 目标检测作为计算机视觉领域的核心任务之一&#xff0c;旨在从图像或视频中识别并定位特定类别的目标物体。深度学习技术的兴起为目标检测领域带来了革命性的突破&#xff0c;使其在准确率、…

作者头像 李华
网站建设 2026/1/10 16:59:14

18、高级实用工具概述:SELinux与Firewalld深度解析

高级实用工具概述:SELinux与Firewalld深度解析 1. SELinux基础与模式切换 SELinux(Security-Enhanced Linux)是一种增强型的安全机制,它在用户设置的自由访问控制之外提供了重要的安全层。目标策略规则允许以 httpd_t 运行的进程访问具有 httpd_sys_content_t 上下文的…

作者头像 李华
网站建设 2026/1/15 16:41:20

前端引用printJS打印

1. 引入 PrintJS下载或 CDN 引入&#xff1a;CDN 方式&#xff1a;在 HTML 文件的 <head> 标签中&#xff0c;通过 CDN 链接引入 PrintJS 的 CSS 和 JavaScript 文件。<head><link href"https://printjs - 4de6.kxcdn.com/print.min.css" rel"st…

作者头像 李华