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 后端路由:api/GetDataList 返回值:Value 前端要做的事: ①拿到Value值,传到a标签 ②a标签有一个按钮,每点击一下,Value的值加一。 前端需要用click语法 【代码】 <template>…...
技术周总结 2024.07.15~07.21周日(Spark性能优化)
文章目录 一、07.19 周五1.1)问题01: spark性能优化1.2)问题02: spark是怎么应用在机器学习领域的1.3)问题03:spark自带工具有哪些?1.4)问题04: spark日志的知识点有哪些…...
提高性能的常见技术
1.数据库层面: 读写分离,对于大部分业务来说,读取操作要大于写入,同一个库,既读又写的话,负载会比较重,拆分为读库和写入库,可以降低数据库的负载,分时或延迟将写入的数…...
LeetCode206 反转链表
前言 题目: 206. 反转链表 文档: 代码随想录——反转链表 编程语言: C 解题状态: 有了思路以后没敢尝试 思路 需要注意的是创建指针不会申请额外的内存空间。 代码 方法一: 双指针法/迭代 我的理解是创建了三个指针…...
nginx通过nginx_upstream_check_module实现后端健康检查
1、简介说明 nginx是常用的反向代理和负载均衡服务,具有强大并发能力、稳定性、丰富的功能集、低资源的消耗。 nginx自身是没有针对后端节点健康检查的,但是可以通过默认自带的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版>
目录 关于链表的分类 双向链表结构体 初始化 尾插 头插 打印 判断是否为空 尾删 头删 查找 指定位置之后的插入 指定位置的删除 销毁 关于链表的分类 根据链表的三大特性,单向or双向、带头or不带头、循环or不循环,可将链表分为2*2*2…...
react18+
主要是围绕函数式组件讲,18主要用就是函数式组件,学习前先熟悉下原生js的基本使用,主要是事件 1、UI操作 1.1、书写jsx标签语言 基本写法和原生如同一则,只是放在一个方法里面返回而已,我们称这样的写法为函数式组件…...
rk3568 OpenHarmony4.1 Launcher定制开发—桌面壁纸替换
Launcher 作为系统人机交互的首要入口,提供应用图标的显示、点击启动、卸载应用,并提供桌面布局设置以及最近任务管理等功能。本文将介绍如何使用Deveco Studio进行单独launcher定制开发、然后编译并下载到开发板,以通过Launcher修改桌面背景…...
隐式神经表示(INR)技术解析与应用实践
1. 隐式神经表示技术解析隐式神经表示(Implicit Neural Representations, INR)是近年来计算机视觉领域兴起的一种新型数据表示方法。与传统显式表示(如像素网格、点云、网格等)不同,INR通过神经网络将坐标映射到对应属…...
RT-Thread LwIP内存配置避坑指南:从pbuf、内存池到menuconfig选项详解
RT-Thread LwIP内存配置避坑指南:从pbuf、内存池到menuconfig选项详解 在嵌入式网络开发中,内存管理往往是决定系统稳定性的关键因素。RT-Thread作为一款优秀的实时操作系统,其内置的LwIP协议栈为开发者提供了轻量级的TCP/IP网络解决方案。然…...
国产麒麟系统上,Maven 3.9.6 安装配置保姆级教程(附常用命令速查表)
国产麒麟系统上Maven 3.9.6全流程配置指南与实战技巧 第一次在openKylin上配置Java开发环境?作为国产操作系统的代表,openKylin以其安全稳定的特性正在开发者群体中快速普及。但当你兴冲冲地准备开始第一个Java项目时,可能会发现一些在Window…...
告别VSCode C++调试噩梦:从‘g++ build active file’报错到一键顺畅调试的避坑全记录
从零构建VSCode C调试环境:一次彻底解决配置问题的实践指南 引言 作为一名长期使用VSCode进行C开发的工程师,我深知配置调试环境时的痛苦。那种看着红色错误提示却无从下手的挫败感,那种在Stack Overflow上翻遍各种解决方案却依然无法解决问题…...
在模型广场中根据任务需求与预算快速筛选合适模型的选型体验
在模型广场中根据任务需求与预算快速筛选合适模型的选型体验 1. 模型广场的核心价值 Taotoken模型广场将主流大模型的接入、选型和切换过程简化为统一界面操作。用户无需在不同厂商平台间反复跳转,即可在一个控制台中完成从浏览模型特性到实际调用的全流程。这种集…...
AI智能体记忆系统:双记忆架构与工程化部署实战
1. 项目概述:为AI智能体构建持久化记忆系统如果你和我一样,长期在AI智能体开发领域折腾,肯定遇到过这个核心痛点:智能体没有记忆。每次对话都像第一次见面,项目上下文、历史决策、踩过的坑,聊完就忘。这直接…...
[具身智能-530]:Trae AI 主导开发:SOLO Builder 擅长“从 0 到 1”的无中生有,而 SOLO Coder 擅长“从 1 到 100”的精雕细琢。
在 Trae 的 SOLO 模式中,SOLO Builder 和 SOLO Coder 是两个核心的智能体(Agent),它们虽然都属于“AI 主导开发”的范畴,但定位、适用场景和工作流有着本质的区别。简单来说:SOLO Builder 擅长“从 0 到 1”…...
手把手教你用Python模拟光的偏振:从马吕斯定律到椭圆偏振光生成
用Python模拟光的偏振:从马吕斯定律到椭圆偏振光实战指南 偏振光是光学领域中一个既基础又充满魅力的现象。想象一下,当你戴着偏光太阳镜仰望蓝天时,镜片如何巧妙地过滤掉刺眼的眩光——这正是偏振原理在日常生活中的直观体现。对于理工科学生…...
5分钟实战:用ArchivePasswordTestTool找回遗忘的压缩包密码
5分钟实战:用ArchivePasswordTestTool找回遗忘的压缩包密码 【免费下载链接】ArchivePasswordTestTool 利用7zip测试压缩包的功能 对加密压缩包进行自动化测试密码 项目地址: https://gitcode.com/gh_mirrors/ar/ArchivePasswordTestTool 你是否曾经面对着一…...
手把手教你用iDriver搞定华为服务器Win16驱动:从下载、校验到静默安装一条龙
华为服务器Windows Server 2016驱动管理全攻略:iDriver高效实践指南 在华为FusionServer系列服务器上部署Windows Server 2016时,驱动管理往往是系统管理员面临的第一个技术门槛。不同于消费级PC的即插即用体验,企业级服务器的硬件组件需要精…...
