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

Llama中模块参数大小

LLama2中,流程中数据大小的变换如下

Transformer模块

第一次输入,进行prefill,输入x维度为[1, 8, 4096]

1. 构建wq,wk,wv,wo,尺寸均为[4096,4096], 与x点乘,得到xq, xk, xv

2. 构建KV cache, 尺寸为 [batch size, max_seq_len, local_kv_heads, head_dim],对应 [1, 8, 32, 128]

3.基于kv  cache构造 keys, alues,对应的尺寸还是[1,8,32,128]

4. 在最后两个维度对于xq和key进行点乘,得到scores,维度变成【1, 32, 8, 8】

5. 将mask与scores相加

6. 对于scores进行softmax

7. 将scores [1, 32, 8, 8]与values [1, 32, 8, 128]进行乘法

8. 得到output [1, 8, 4096]

9. 将output再与wo进行乘法[1, 8, 4096]

10. 接下来对于输出进行 ffn_norm的操作

Feedforward模块

11.然后进行feed_forward.得到当前transformer模块的输出 [1, 8, 4096]

feed_forward的操作如下,虽然代码很小,但是计算量却很大。

    def forward(self, x):return self.w2(F.silu(self.w1(x)) * self.w3(x))

其中,w1的维度为[11008, 4096], w2的维度为[4096, 11008], w3的维度为[11008, 4096]

kv cache的表达如下

        self.cache_k = torch.zeros((args.max_batch_size,args.max_seq_len,self.n_local_kv_heads,self.head_dim,)).cuda()self.cache_v = torch.zeros((args.max_batch_size,args.max_seq_len,self.n_local_kv_heads,self.head_dim,)

关于kv cache的细节讨论

llama2设定 local_kv_heads为32,head_dim为128。所以,kv cache的尺寸为 [1, 512,32, 128] * 2

对于一个batch的数据来说哦,因为llama2 7B 包含32个transformer,所以,当使用FP32表达时, 对应一个batch的kv cache的大小为128 * 32 * 128 *2 * 32 * 4byte= 0.5GB.

这里,也可以看到几个变量:

* 当batch变大时,kv cache线性增长

* 当batch 的最大长度增大时, Kv cache线性增长。

参考链接:

https://arxiv.org/pdf/1911.02150

相关文章:

Llama中模块参数大小

LLama2中,流程中数据大小的变换如下 Transformer模块 第一次输入,进行prefill,输入x维度为[1, 8, 4096] 1. 构建wq,wk,wv,wo,尺寸均为[4096,4096], 与x点乘,得到xq, xk, xv 2. 构建KV cache, 尺寸为 [b…...

Modbus转EtherCAT网关将Modbus协议的数据格式转换为EtherCAT协议

随着工业自动化技术的快速发展,不同通信协议之间的互操作性变得越来越重要。Modbus作为一种广泛使用的串行通信协议,与以太网为基础的EtherCAT协议之间的转换需求日益增长。本文将从网关功能、硬件设计、性能以及应用案例来介绍这款Modbus转EtherCAT网关…...

【开发实战】QT5 + OpenCV4 开发环境配置应用演示

前言 作为深度学习算法工程师,必须要掌握应用开发技能吗?搞工程肯定是必须要会界面开发,QT就是一个很不错的选择。本文以QT5.15 OpenCV4.8 OpenVINO2023为例,搭建应用开发环境,演示深度学习模型的QT应用案例。 开发…...

“微软蓝屏”事件暴露的网络安全问题及应对策略

“微软蓝屏”事件暴露了网络安全哪些问题? 近日,一次由微软视窗系统软件更新引发的全球性“微软蓝屏”事件,不仅成为科技领域的热点新闻,更是一次对全球IT基础设施韧性与安全性的深刻检验。这次事件,源于美国电脑安全技…...

白骑士的PyCharm教学基础篇 1.3 调试与运行

系列目录 上一篇:白骑士的PyCharm教学基础篇 1.2 PyCharm基本操作 配置与调试环境 配置调试环境 选择解释器 在 PyCharm 中选择正确的 Python 解释器:依次点击 “File” -> “Settings” -> “Project: [项目名]” -> “Project Interpret…...

爬虫学习1:初学者简单了解爬虫的基本认识和操作(详细参考图片)

爬虫 定义:爬虫(Web Crawler 或 Spider)是一种自动访问互联网上网页的程序,其主要目的是索引网页内容,以便搜索引擎能够快速检索到相关信息。以下是爬虫的一些关键特性和功能: 自动化访问:爬虫能…...

WHAT - 通过 shadcn 组件源码学习 React

目录 一、button1. 导入部分2. 定义按钮的样式变体1. variant2. size总结 3. 定义按钮的属性类型4. 定义按钮组件5. 导出组件和样式变体总结 二、multi-select多选组件的核心上下文与状态1. 上下文与钩子2. MultiSelector 组件 组件子部分1. MultiSelectorTrigger2. MultiSelec…...

grafana对接zabbix数据展示

目录 1、初始化、安装grafana 2、浏览器访问 3、安装zabbix 4、zabbix数据对接grafana 5、如何导入模板? ① 设置键值 ② 在zabbix web端完成自定义监控项 ③ garafana里添加nginx上面的的三个监控项 6、如何自定义监控项? 以下实验沿用上一篇z…...

C++ 学习补充 1:短链算法

短链算法 短链算法: 将长链接 转化为 一个短key 之所以不是短url 是因为 ,url 短链不区分大小写,可用空间比较小。 短链算法通常用于将一个长网址转换成一个较短的字符串,以便于分享和存储。这种算法通常需要满足以下条件&#…...

硅纪元视角 | 语音克隆突破:微软VALL-E 2,Deepfake新纪元!

在数字化浪潮的推动下,人工智能(AI)正成为塑造未来的关键力量。硅纪元视角栏目紧跟AI科技的最新发展,捕捉行业动态;提供深入的新闻解读,助您洞悉技术背后的逻辑;汇聚行业专家的见解,…...

没有51基础,能不能学好STM32?

在开始前刚好我有一些资料,是我根据网友给的问题精心整理了一份「STM32的资料从专业入门到高级教程」, 点个关注在评论区回复“888”之后私信回复“888”,全部无偿共享给大家!!! 我们通常准备攻读一本大部…...

Web开发:VUE3小白开发入门基础笔记

一、基本语法 1.click 后端路由&#xff1a;api/GetDataList 返回值&#xff1a;Value 前端要做的事&#xff1a; ①拿到Value值&#xff0c;传到a标签 ②a标签有一个按钮&#xff0c;每点击一下&#xff0c;Value的值加一。 前端需要用click语法 【代码】 <template>…...

技术周总结 2024.07.15~07.21周日(Spark性能优化)

文章目录 一、07.19 周五1.1&#xff09;问题01&#xff1a; spark性能优化1.2&#xff09;问题02&#xff1a; spark是怎么应用在机器学习领域的1.3&#xff09;问题03&#xff1a;spark自带工具有哪些&#xff1f;1.4&#xff09;问题04&#xff1a; spark日志的知识点有哪些…...

提高性能的常见技术

1.数据库层面&#xff1a; 读写分离&#xff0c;对于大部分业务来说&#xff0c;读取操作要大于写入&#xff0c;同一个库&#xff0c;既读又写的话&#xff0c;负载会比较重&#xff0c;拆分为读库和写入库&#xff0c;可以降低数据库的负载&#xff0c;分时或延迟将写入的数…...

LeetCode206 反转链表

前言 题目&#xff1a; 206. 反转链表 文档&#xff1a; 代码随想录——反转链表 编程语言&#xff1a; C 解题状态&#xff1a; 有了思路以后没敢尝试 思路 需要注意的是创建指针不会申请额外的内存空间。 代码 方法一&#xff1a; 双指针法/迭代 我的理解是创建了三个指针…...

nginx通过nginx_upstream_check_module实现后端健康检查

1、简介说明 nginx是常用的反向代理和负载均衡服务&#xff0c;具有强大并发能力、稳定性、丰富的功能集、低资源的消耗。 nginx自身是没有针对后端节点健康检查的&#xff0c;但是可以通过默认自带的ngx_http_proxy_module 模块和ngx_http_upstream_module模块中的相关指令来完…...

FastGPT 知识库搜索测试功能解析(二)

目录 一、代码解析 1.1 searchTest.ts 1.2 controller.ts 本文接上一篇文章FastGPT 知识库搜索测试功能解析 对具体代码进行解析。 一、代码解析 FastGPT 知识库的搜索测试功能主要涉及两个文件,分别是 searchTest.ts 和 controller.ts 文件,下面分别进行介绍。 1.1 se…...

双向链表<数据结构 C版>

目录 关于链表的分类 双向链表结构体 初始化 尾插 头插 打印 判断是否为空 尾删 头删 查找 指定位置之后的插入 指定位置的删除 销毁 关于链表的分类 根据链表的三大特性&#xff0c;单向or双向、带头or不带头、循环or不循环&#xff0c;可将链表分为2*2*2&#xf…...

react18+

主要是围绕函数式组件讲&#xff0c;18主要用就是函数式组件&#xff0c;学习前先熟悉下原生js的基本使用&#xff0c;主要是事件 1、UI操作 1.1、书写jsx标签语言 基本写法和原生如同一则&#xff0c;只是放在一个方法里面返回而已&#xff0c;我们称这样的写法为函数式组件…...

rk3568 OpenHarmony4.1 Launcher定制开发—桌面壁纸替换

Launcher 作为系统人机交互的首要入口&#xff0c;提供应用图标的显示、点击启动、卸载应用&#xff0c;并提供桌面布局设置以及最近任务管理等功能。本文将介绍如何使用Deveco Studio进行单独launcher定制开发、然后编译并下载到开发板&#xff0c;以通过Launcher修改桌面背景…...

从‘建造者’到‘侦探’:嵌入式工程师的IDA逆向入门心得(以交叉引用分析为例)

从‘建造者’到‘侦探’&#xff1a;嵌入式工程师的IDA逆向入门心得&#xff08;以交叉引用分析为例&#xff09; 当你在嵌入式领域深耕多年&#xff0c;习惯了用C语言构建系统、调试硬件&#xff0c;突然有一天需要逆向分析一段二进制代码&#xff0c;那种感觉就像建筑师被要求…...

MATLAB四旋翼无人机自适应控制仿真(Simulink和Simscape,支持SolidWo...

MATLAB四旋翼自适应控制仿真simulink simscape&#xff0c;可更换成自己的无人机solidworks模型 有公式手册需MATLAB2017版本以上刚拆完快递的周末下午最适合折腾无人机仿真了。最近在MATLAB里搞了个四旋翼自适应控制的活儿&#xff0c;用Simscape Multibody把SolidWorks建的模…...

C#源码最新版v2.1:视觉集成控制系统开发框架,包含拖拽编程与PLC通讯等功能,含注释注释...

C#源码&#xff5e;最新版v2.1版本植板控制系统&#xff0c;C#联合halcon开发框架源码。拖拽式编程,无halcon基础也能上手&#xff0c;匹配&#xff0c;测量&#xff0c;条码识别&#xff0c;ocr,定位引导&#xff0c;对位等&#xff0c;支持plc通讯&#xff0c;集成主流相机sd…...

通义千问2.5-7B-Instruct多卡部署优化:性能翻倍实战,新手也能看懂

通义千问2.5-7B-Instruct多卡部署优化&#xff1a;性能翻倍实战&#xff0c;新手也能看懂 1. 为什么需要多卡部署&#xff1f; 1.1 单卡部署的局限性 当我们在单张GPU上运行通义千问2.5-7B-Instruct模型时&#xff0c;经常会遇到以下问题&#xff1a; 显存瓶颈&#xff1a;…...

Modularization-examples社区与支持:如何参与贡献并获取专家帮助

Modularization-examples社区与支持&#xff1a;如何参与贡献并获取专家帮助 【免费下载链接】modularization-examples 代码防腐实用技术 项目地址: https://gitcode.com/gh_mirrors/mo/modularization-examples modularization-examples是一个专注于代码防腐实用技术的…...

SeqGPT-560M中文优化深度解析:针对简体中文语义理解的Prompt设计技巧

SeqGPT-560M中文优化深度解析&#xff1a;针对简体中文语义理解的Prompt设计技巧 1. 引言&#xff1a;当AI能“秒懂”你的中文 想象一下&#xff0c;你拿到一个全新的AI模型&#xff0c;不需要准备海量数据&#xff0c;也不需要花几天几周去训练它&#xff0c;只需要告诉它“…...

AgentCPM研报助手应用指南:如何用它高效完成课题研究与论文写作

AgentCPM研报助手应用指南&#xff1a;如何用它高效完成课题研究与论文写作 1. 为什么选择本地研报生成工具&#xff1f; 在学术研究和商业分析领域&#xff0c;撰写深度报告是每个研究者必须面对的任务。传统流程通常包括&#xff1a; 收集和阅读大量文献资料整理数据并构建…...

RuleAppV2版本,完全部署教程,创建内容社区,附下载

此教程是手动安装教程&#xff0c;完全依靠宝塔面板管控。要查看更多配置信息&#xff0c;可访问完整文档。 RuleProject社区应用帮助文档www.yuque.com/buxia97/ruleproject/ 基本介绍 RuleApp是一款面向内容社区与自媒体平台打造的全端文章资讯社区系统&#xff0c;早期基于…...

OPPO Find N6:折叠屏手机新势力的崛起与挑战

OPPO Find N6&#xff1a;零感折痕开启折叠屏新体验OPPO 推出的折叠屏手机 Find N6 带来了令人瞩目的“零感折痕”体验。借助液态 3D 打印铰链柱&#xff0c;其折痕是目前所有折叠屏手机中最浅的&#xff0c;几乎难以看到或摸到&#xff0c;虽未完全消失&#xff0c;但已近乎完…...

软件测试技术沉淀之常用SQL语句

涉及工具&#xff1a;NavicatSQL语句(CRUD)一、增insert into 表名&#xff08;字段名&#xff09; values &#xff08;内容列表&#xff09;insert into student values (S0013,男,18) insert into SC(Sno,Cno) values(S0013,C005)二、删delete from 表名 where 条件delete f…...