Transformer升级之路:逆用Leaky ReRoPE

news2024/11/25 20:20:32

766e776fce9e72817a7f37b76db0ba39.gif

©PaperWeekly 原创 · 作者 | 苏剑林

单位 | 科学空间

研究方向 | NLP、神经网络

在《Transformer升级之路:无限外推的ReRoPE?》中,笔者提出了 ReRoPE 和 Leaky ReRoPE,诸多实验结果表明,它们能够在几乎不损失训练效果的情况下免微调地扩展 LLM 的 Context 长度,并且实现了 “longer context, lower loss” 的理想特性,此外跟 NTK-aware Scaled RoPE 不同的是,其中 ReRoPE 似乎还有表现出了无限的 Context 处理能力。

总之,ReRoPE 看起来相当让人满意,但美中不足的是会增加推理成本,具体表现为第一步推理需要算两次 Attention,以及后续每步推理需要重新计算位置编码。本文试图通过在训练中逆用 Leaky ReRoPE 的方法来解决这个问题。

4caf89c2fd0a59c516654a6eae3bd6bb.png

回顾

让我们不厌其烦地重温一下:RoPE 形式上是一种绝对位置编码,但实际达到的效果是相对位置编码,对应的相对位置矩阵是:

e4fd49d2049a1038c9da804dd37d2b85.png

为了在保留局域性的同时避免 Long Context 导致位置越界问题,Leaky ReRoPE 将推理阶段的相对位置矩阵改为:

5af27251d3896b97a4d85d11a54abc16.png

其中w是窗口宽度,大概取训练长度的 到 , 用来调节可处理的最大长度,一般使得 不超过训练长度的一半为佳。至于 ReRoPE,则是直接取了 的极限:

235206939b4dc9fe78fffbe29359b6b6.png

609f0360ee5a37a1fc400833a02d94ac.png

反转

从上一篇的评测结果来看,作为一种免训练的外推方案,ReRoPE 和 Leaky ReRoPE 的效果都是相当让人满意的,既没有损失训练长度内的效果,又实现了 “Longer Context, Lower Loss”。唯一美中不足的是,它们的推理速度相比原本的 Attention 来说是变慢的,并且目前尚不兼容 Flash Attention 等加速技术。

那么,能否反过来呢?ReRoPE/Leaky ReRoPE 在训练阶段是正常速度的 RoPE,推理阶段则是变慢了,反过来也就是说:能否让训练阶段变慢,让推理阶段变为常规的 RoPE?

可能有读者疑惑:为什么会想要让训练阶段变慢?训练成本不是更高吗?这是因为 ReRoPE/Leaky ReRoPE 是一种长度外推方法,场景是 “Train Short, Test Long”,训练速度的变慢是短期的、可控的,推理速度的变慢才是长期的、难顶的,所以相较之下,如果是同等程度的变慢的话,我们更愿意将变慢的部分放到训练阶段。

让我们再看一下 Leaky ReRoPE,它在训练阶段的相对位置矩阵是步长为 1 的式(1),推理阶段则在 w 的窗口内使用 1 的步长,在窗口外使用 的步长,即式(2),换句话说,差别是推理阶段窗口外使用更小的步长。如果我们反过来,在训练阶段使用 Leaky ReRoPE,并让它窗口外的步长大于 1,那么按照“推理阶段窗口外使用更小的步长”的原则,推理阶段窗口外是否就可以使用等于 1 的步长,从而退化为 RoPE了?

笔者将以上想法称之为 “InvLeaky ReRoPE(Inverse Leaky ReRoPE)”。事不宜迟,我们马上做实验测试。

7d1ba0322c34f60933af7eed65164fd8.png

实验

继续之前的 “GAU + Deep Norm + Tiger + 语言模型”实验组合,在训练阶段使用 的 Leaky ReRoPE,在推理阶段使用正常的 RoPE,测试结果如下:

45885119fffeab946b40f6d746bdcc63.png

其中 是指 RoPE 的频率底数从 10000 换成了 80000。可以看到,“Leaky ReRoPE → RoPE”的InvLeaky ReRoPE 虽然效果上不如 “RoPE → ReRoPE/Leaky ReRoPE”,但依然胜过了 HFWA,并且由于推理阶段是常规的RoPE,可以套用现成的加速技术,因此依然是有相当竞争力的。

此外,笔者对 等参数做了一些简单的调参,发现最优解基本上就是以上两个组合了,即“ 设置为‘扩展倍数的 2 倍的倒数’、 设置为训练长度的 可选乘以扩展倍数”。

那么,InvLeaky ReRoPE 对训练速度有多大影响呢?在上述实验中,模型是 1 亿参数量,训练长度是 512,每 1000 步的训练时间从 330 秒增加到了 350 秒,增加不到 10%,当然这里边有 GAU 的原因,因为 GAU 是单头的注意力,本就比多头注意力快。如果多头注意力或者训练长度更长的话,增加幅度应该会大一些,但目测应该不超过 50% 都是可以接受的。

b6463fdd6c3f5c940f4a2fe458017a00.png

小结

本文提出了 Leaky ReRoPE 的“逆用”做法,通过在训练阶段使用更大步长的 Leaky ReRoPE,使得推理阶段可以退回常规的 RoPE,从而可以保持推理速度不变,实验结果显示这种做法还是有一定的竞争力的。

更多阅读

ee9cb32b9185d7be56801976bd10c5cf.png

26d5085570738a58b8c341918eec854c.png

91e85a682a4d4660acac39a7842ea4d0.png

a396abcdf7123933014ef267c8e0c533.gif

#投 稿 通 道#

 让你的文字被更多人看到 

如何才能让更多的优质内容以更短路径到达读者群体,缩短读者寻找优质内容的成本呢?答案就是:你不认识的人。

总有一些你不认识的人,知道你想知道的东西。PaperWeekly 或许可以成为一座桥梁,促使不同背景、不同方向的学者和学术灵感相互碰撞,迸发出更多的可能性。 

PaperWeekly 鼓励高校实验室或个人,在我们的平台上分享各类优质内容,可以是最新论文解读,也可以是学术热点剖析科研心得竞赛经验讲解等。我们的目的只有一个,让知识真正流动起来。

📝 稿件基本要求:

• 文章确系个人原创作品,未曾在公开渠道发表,如为其他平台已发表或待发表的文章,请明确标注 

• 稿件建议以 markdown 格式撰写,文中配图以附件形式发送,要求图片清晰,无版权问题

• PaperWeekly 尊重原作者署名权,并将为每篇被采纳的原创首发稿件,提供业内具有竞争力稿酬,具体依据文章阅读量和文章质量阶梯制结算

📬 投稿通道:

• 投稿邮箱:hr@paperweekly.site 

• 来稿请备注即时联系方式(微信),以便我们在稿件选用的第一时间联系作者

• 您也可以直接添加小编微信(pwbot02)快速投稿,备注:姓名-投稿

2184f99197451f6ac2597f25feaf013a.png

△长按添加PaperWeekly小编

🔍

现在,在「知乎」也能找到我们了

进入知乎首页搜索「PaperWeekly」

点击「关注」订阅我们的专栏吧

·

·

6902ab37f14d83646a2cfea14fdf2961.jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/949327.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【设计模式】装饰者模式

目录 一、定义二、结构三、优点四、使用场景五、代码示例六、截图示例 一、定义 1.在不改变现有对象结构的情况下,动态给该对象添加额外功能的模式 2.类B继承于类A,并将类A作为B类的属性(B类聚合A类) 3.BufferedInputStream、Buff…

单元测试用例mock的使用方法

单元测试用例mock的使用方法 提升代码测试覆盖率的关键策略 为什么单元测试是如此重要? 在软件开发中,单元测试是一个关键的环节,可以确保代码的质量和稳定性。而在进行单元测试时,使用mock对象可以帮助我们更好地测试代码逻辑…

MySQL8.Xx安装控制台未生成随机密码解决方案

MySQL8.xx一主两从复制安装与配置 MySQL8.XX随未生成随机密码解决方案 MySQL8.0.30一主两从复制与配置(一) 一: Mysql 安装时控制台未生成密码 安装过程中解压或者安装时报错等,这种情况一般是因网络等其他原因导致下载的安装包不完整, 重新下载安装即可; 二:…

域名解析与http服务器实现原理

域名解析函数gethostbyname struct hostent *gethostbyname(const char *name); 主机结构在<netdb.h>中定义如下&#xff1a; 结构的成员包括&#xff1a; h_name&#xff1a;主机的正式名称 h_aliases&#xff1a;主机的备用名称数组&#xff0c;以NULL结尾指针 h_…

企业为什么要做自动化测试?我们该如何学习自动化测试?

作为一名大厂测试开发&#xff0c;编写自动化脚本&#xff0c;俨然成为一种必备的技能。 为什么要做自动化测试&#xff1f; 那企业或者是我们测试人员为什么要做自动化测试呢&#xff1f; 如果在前两年&#xff0c;可能10个测试员有6个都是做的功能测试&#xff0c;但随着测…

ToBeWritten之防御规避战术

也许每个人出生的时候都以为这世界都是为他一个人而存在的&#xff0c;当他发现自己错的时候&#xff0c;他便开始长大 少走了弯路&#xff0c;也就错过了风景&#xff0c;无论如何&#xff0c;感谢经历 转移发布平台通知&#xff1a;将不再在CSDN博客发布新文章&#xff0c;敬…

day-05 TCP半关闭 ----- DNS ----- 套接字的选项

一、优雅的断开套接字连接 之前套接字的断开都是单方面的。 &#xff08;一&#xff09;基于TCP的半关闭 Linux的close函数和windows的closesocket函数意味着完全断开连接。完全断开不仅不能发送数据&#xff0c;从而也不能接收数据。在某些情况下&#xff0c;通信双方的某一方…

2023高教社杯数学建模思路 - 案例:异常检测

文章目录 赛题思路一、简介 -- 关于异常检测异常检测监督学习 二、异常检测算法2. 箱线图分析3. 基于距离/密度4. 基于划分思想 建模资料 赛题思路 &#xff08;赛题出来以后第一时间在CSDN分享&#xff09; https://blog.csdn.net/dc_sinor?typeblog 一、简介 – 关于异常…

众创空间、孵化器、共享办公这三者之间的异同点

众创空间、孵化器和共享办公都是创新型创业生态中重要的组成部分&#xff0c;但它们在服务方式、功能和作用上有所区别。 众创空间是一种开放式的创新型创业生态&#xff0c;旨在通过提供共享办公空间、创业培训、融资对接等服务&#xff0c;帮助初创企业加速成长。众创空间注…

小区物业这个雷区,千万别踩!

在现代社会中&#xff0c;电力是我们日常生活不可或缺的一部分&#xff0c;而小区物业配电柜监控则扮演着保障电力稳定供应和管理的关键角色。 配电柜监控系统通过实时监测电力参数、设备状态和环境情况&#xff0c;我们能够早期发现潜在的问题&#xff0c;迅速采取行动&#x…

【HSPCIE仿真】输入网表文件(3)子电路描述语句

子电路描述语句 1. 子电路的定义定义子电路的基本语法子电路终止语句子电路的调用语句全局节点(.gloab)示例 2. 基于子电路执行多次分析 HSPICE 允许用户在程序执行过程中调用由各种 HSPICE 元件和器件构成的子电路&#xff0c;即电路结构的层次化描述。 子电路是以 .SUBCKT 或…

WebSocket--技术文档--基本概念--《快速了解WebSocket协议》

阿丹&#xff1a; 不断学习新技术&#xff0c;丰富自己了解更多才能扩展更多世界可能。 官网 WebSocket首页、文档和下载 - HTML5开发相关 - OSCHINA - 中文开源技术交流社区 软件简介 WebSocket 是 HTML5 开始提供的一种浏览器与服务器间进行全双工通讯的网络技术。 WebS…

java八股文面试[数据库]——数据库三范式

什么是范式&#xff1f; 范式是数据库设计时遵循的一种规范&#xff0c;不同的规范要求遵循不同的范式。 最常用的三大范式 第一范式(1NF)&#xff1a;属性不可分割&#xff0c;即每个属性都是不可分割的原子项。(实体的属性即表中的列) 理解&#xff1a;一个列不能包含两个数…

ruoYi添加子模块,访问子模块服务404

一 问题 在ruoYi项目中&#xff0c;添加了一个子模块&#xff0c;在里面创建了几个服务&#xff0c;调用时发现总是404 二 解决 1. 父pom添加该子模块 2.ruoyi-admin项目关联该子模块

git私房菜

文章目录 1、公司项目开发Git协作流程2、合并相关的操作3、Git常用命令总结 公司中如何使用Git协同开发的&#xff1f;本文将具体介绍开发模式&#xff0c;以及一些常用命令。 1、公司项目开发Git协作流程 公司一个完整的项目出来&#xff0c;项目的推进是在主分支master上进行…

重要通知,亚马逊正式取消轻小商品计划!

美亚轻小商品计划今日正式关闭 轻小商品计划允许卖家以更低的配送费用提供更小、更轻、更便宜的产品。正常的亚马逊FBA费用通常会使销售低价商品无利可图&#xff0c;但轻小商品计划降低了满足某些标准&#xff08;包括重量、尺寸和价格&#xff09;的商品的配送成本。 不过&a…

解决未授予用户在此计算机上的请求登录类型

步骤一&#xff1a;在被访问的计算机中操作 1、点击开始菜单&#xff0c;在计算机上单击右键&#xff0c;选择管理。 2、依次展开系统工具—本地用户和组—用户。 未授予用户在此计算机上的请求登录类型 3、双击Guest&#xff0c;将账户已禁用前面的勾去掉&#xff0c;点击应…

智慧乡村/数字乡村:安防监控/视频监控综合管理平台EasyCVR技术如何助力乡村数字化?

一、背景分析 数字乡村是伴随网络化、信息化和数字化在农业农村经济社会发展中的应用&#xff0c;以及农民现代信息技能的提高而衍生的农村现代化发展和转型进程。数字乡村建设既是乡村振兴的战略方向&#xff0c;也是建设数字中国的重要内容。 1&#xff09;加快农业数字化转…

QML Book 学习基础4(状态和转换)

目录 states&#xff08;状态&#xff09; Transition&#xff08;过渡&#xff09; states&#xff08;状态&#xff09; 用户界面的某些部分可以用状态来描述。状态定义一组属性更改&#xff0c;并且可以由特定条件触发。 QML 中定义状态&#xff0c;该元素需要绑定到任何项…

基于协同滤波推荐算法的图书管理系统

目录 一、项目概述 二、技术框架 三、功能设计 四、数据库设计 五、项目截图 六、技术文档 一、项目概述 Hi&#xff0c;大家好&#xff0c;今天分享的项目是《基于协同滤波推荐算法的图书管理系统》&#xff0c;对用户登录注册、图书推荐、图书管理、用户信息进行管理&…