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

CANN-昇腾NPU-LoRA微调-显存只占5%怎么做到的

全量微调 Llama2-7B 需要更新 7B 参数显存开销约 80GB。LoRA 只训练 0.5% 的参数约 35M显存开销约 4GB。在昇腾NPU上 LoRA 微调是性价比最高的方案。LoRA 原理在原始权重 W 旁边加一个低秩矩阵 ΔW A × B原始y Wx LoRAy (W AB)x Wx ABx A: [hidden, r], B: [r, hidden], r hidden Llama2-7B: r16, A[4096,16], B[16,4096] 每层 LoRA 参数: 2 × 4096 × 16 128K 全量参数: 4096 × 4096 16M 参数比: 0.8%训练时 W 冻结只更新 A 和 B。推理时把 ΔW 合并回 W零额外延迟。昇腾NPU上的实现frompeftimportLoraConfig,get_peft_modelimporttorchimporttorch_npu modelAutoModelForCausalLM.from_pretrained(meta-llama/Llama-2-7b-hf,torch_dtypetorch.bfloat16,device_mapnpu:0)lora_configLoraConfig(r16,lora_alpha32,target_modules[q_proj,v_proj,k_proj,o_proj,gate_proj,up_proj,down_proj],lora_dropout0.05,)modelget_peft_model(model,lora_config)model.print_trainable_parameters()# 输出: trainable params: 35M || all params: 6.7B || trainable%: 0.52%显存对比Llama2-7B 全量微调 vs LoRA 微调单卡 Atlas 800I A264GB 显存项目全量微调LoRA 微调模型权重14GB可冻结14GB冻结LoRA 权重-0.2GB梯度14GB全量0.2GB仅 LoRA优化器状态28GB全量 fp320.4GB仅 LoRA激活20GB20GB总计76GB34.8GBLoRA 微调的显存不到全量微调的一半。单卡 64GB 就能跑不需要 8 卡 TP。训练速度配置吞吐 (tokens/s)训练时间1M tokens全量微调8 卡 TP1,8009 分钟LoRA单卡1,20014 分钟LoRA 单卡比全量 8 卡慢 55%。但如果你只有一张卡LoRA 是唯一选择。推理时合并 LoRA# 方法 1动态合并每次推理时计算 Wx ABx# 优点可以热切换不同 LoRA# 缺点多一次矩阵乘法约 3-5ms 额外延迟# 方法 2预合并训练完成后 W W AB删除 A 和 B# 优点推理零开销# 缺点不能切换 LoRAmodelmodel.merge_and_unload()# 预合并预合并后的模型跟原始模型完全一样——ATB 的推理加速、FlashAttention、量化全部适用。多 LoRA 推理同一个基座模型挂多个 LoRA不同请求用不同 LoRAfromatbimportLLM,MultiLoraConfig modelLLM(meta-llama/Llama-2-7b-hf,devicenpu:0,multi_loraMultiLoraConfig(lora_dirs[lora_chat,lora_code,lora_translate],max_loras3,))# 不同请求用不同 LoRAresultsmodel.generate([(Hello,lora_chat),(def fib(n):,lora_code),(Translate:,lora_translate),])ATB 的 Multi-LoRA 把多个 LoRA 的 ΔW 打包成 Batch GEMM一次计算所有 LoRA 的增量。这比逐个 LoRA 计算高效得多。精度影响LoRA 的精度损失取决于 r 值秩r 值可训练参数微调精度损失适用场景817M0.5-1%简单任务分类1635M0.1-0.3%通用对话、代码3270M0.1%复杂任务翻译、推理64140M几乎无损失全量微调替代r16 是性价比最高的选择。除非任务特别复杂否则不需要 r32。LoRA 微调是昇腾NPU上最实用的微调方案——显存少、速度快、合并后零推理开销。如果你的场景是基座模型 领域适配LoRA 几乎总是比全量微调更好的选择。仓库在这里https://atomgit.com/cann/torch_npu

相关文章:

CANN-昇腾NPU-LoRA微调-显存只占5%怎么做到的

全量微调 Llama2-7B 需要更新 7B 参数,显存开销约 80GB。LoRA 只训练 0.5% 的参数(约 35M),显存开销约 4GB。在昇腾NPU上 LoRA 微调是性价比最高的方案。 LoRA 原理 在原始权重 W 旁边加一个低秩矩阵 ΔW A B: 原…...

RePKG架构深度解析:解密Wallpaper Engine资源处理的核心技术

RePKG架构深度解析:解密Wallpaper Engine资源处理的核心技术 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg 在数字内容创作领域,资源打包与纹理处理是图形应…...

阴阳师自动化脚本终极指南:一键解放双手的智能游戏助手

阴阳师自动化脚本终极指南:一键解放双手的智能游戏助手 【免费下载链接】OnmyojiAutoScript Onmyoji Auto Script | 阴阳师脚本 项目地址: https://gitcode.com/gh_mirrors/on/OnmyojiAutoScript 还在为阴阳师中重复繁琐的日常任务而烦恼吗?每天需…...

5分钟快速掌握ViGEmBus:Windows虚拟游戏控制器驱动完整指南

5分钟快速掌握ViGEmBus:Windows虚拟游戏控制器驱动完整指南 【免费下载链接】ViGEmBus Windows kernel-mode driver emulating well-known USB game controllers. 项目地址: https://gitcode.com/gh_mirrors/vi/ViGEmBus 你是否曾经遇到过这样的困扰&#xf…...

5分钟搭建私有抖音无水印解析服务:DouYinBot高效视频下载指南

5分钟搭建私有抖音无水印解析服务:DouYinBot高效视频下载指南 【免费下载链接】DouYinBot 该项目仅自用,不提供抖音视频下载 项目地址: https://gitcode.com/gh_mirrors/do/DouYinBot 在短视频创作成为日常的今天,获取纯净无水印的抖音…...

GMERF与MERF:处理过离散计数数据的小域估计方法对比

1. 项目概述:当小域估计遇上复杂计数数据在统计分析,尤其是社会经济调查、公共卫生监测等领域,我们常常面临一个经典难题:如何利用有限的样本数据,去准确推断那些样本量极少甚至为零的“小域”(Small Area&…...

深入Linux内核:PTP硬件时间戳(HW Timestamping)是如何炼成的?

深入Linux内核:PTP硬件时间戳(HW Timestamping)的实现机制与技术解析 1. 高精度时间同步的技术演进与PTP核心价值 在现代分布式系统中,时间同步精度已经从毫秒级演进到纳秒级需求。金融交易系统要求时间偏差小于100纳秒&#xff…...

AI产业到底包括哪些

AI 产业是一条从能源 / 材料→算力基建→数据→算法框架→大模型→平台服务→行业应用→终端与具身智能的完整长链,每一层环环相扣、层层驱动。下面从头到尾完整描述。一、最底层:能源与基础材料(产业根基)AI 是极度耗能的产业&am…...

煎饼果仔 夏天妹妹 90 天 AI 变现落地计划

配套固化核心 Skills+ 标准化Workflow,分阶段落地,兼顾口碑与长效收益 一、阶段总规划 表格 周期 阶段核心目标 变现侧重 AI 能力沉淀 1-30 天 资产梳理 + 模型训练,搭建生产底座 现有商单 + 单片付费增收 风格 LoRA、声纹、剧本模型、素材资产库 31-60 天 AI 量产内容 + …...

第七史诗自动化助手E7Helper:解放双手的游戏效率革命

第七史诗自动化助手E7Helper:解放双手的游戏效率革命 【免费下载链接】e7Helper 【Epic Seven Auto Bot】第七史诗多功能覆盖脚本(刷书签🍃,挂讨伐、后记、祭坛✌️,挂JJC等📛,多服务器支持📺&a…...

DamaiHelper:基于Python+Selenium的大麦网自动化抢票解决方案

DamaiHelper:基于PythonSelenium的大麦网自动化抢票解决方案 【免费下载链接】DamaiHelper 大麦网演唱会演出抢票脚本。 项目地址: https://gitcode.com/gh_mirrors/dama/DamaiHelper 你是否曾经在演唱会门票开售的瞬间,面对"秒光"的票…...

Windows Cleaner深度解析:4步彻底解决C盘空间不足的完整技术方案

Windows Cleaner深度解析:4步彻底解决C盘空间不足的完整技术方案 【免费下载链接】WindowsCleaner Windows Cleaner——专治C盘爆红及各种不服! 项目地址: https://gitcode.com/gh_mirrors/wi/WindowsCleaner Windows Cleaner是一款完全免费开源的…...

避开这些坑,你的孟德尔随机化分析结果才可靠:以口腔癌研究为例的实操避雷指南

孟德尔随机化分析实战避坑指南:从数据陷阱到稳健结论当你在深夜盯着屏幕上那个意义不明的0.6940093乘数,或是当MR-PRESSO分析结果始终无法收敛时,是否怀疑过自己的分析流程存在致命缺陷?孟德尔随机化(MR)作…...

小红书视频下载终极指南:5分钟掌握免费无水印批量下载技巧

小红书视频下载终极指南:5分钟掌握免费无水印批量下载技巧 【免费下载链接】XHS-Downloader 小红书(XiaoHongShu、RedNote)链接提取/作品采集工具:提取账号发布、收藏、点赞、专辑作品链接;提取搜索结果作品、用户链接…...

终极指南:使用Xenos实现Windows进程DLL注入的完整教程

终极指南:使用Xenos实现Windows进程DLL注入的完整教程 【免费下载链接】Xenos Windows dll injector 项目地址: https://gitcode.com/gh_mirrors/xe/Xenos 在Windows系统开发和安全研究中,DLL注入技术是实现进程监控、调试和功能扩展的核心手段。…...

3步实现Windows任务栏透明化:从新手到专家的桌面美化全攻略

3步实现Windows任务栏透明化:从新手到专家的桌面美化全攻略 【免费下载链接】TranslucentTB A lightweight utility that makes the Windows taskbar translucent/transparent. 项目地址: https://gitcode.com/gh_mirrors/tr/TranslucentTB Windows任务栏透明…...

SketchUp STL插件完整指南:轻松实现3D打印模型转换

SketchUp STL插件完整指南:轻松实现3D打印模型转换 【免费下载链接】sketchup-stl A SketchUp Ruby Extension that adds STL (STereoLithography) file format import and export. 项目地址: https://gitcode.com/gh_mirrors/sk/sketchup-stl SketchUp STL插…...

如何解决网易云音乐NCM格式限制:ncmdump完整实战指南

如何解决网易云音乐NCM格式限制:ncmdump完整实战指南 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 你是否曾因网易云音乐的NCM加密格式而无法在喜欢的播放器上聆听音乐?ncmdump正是你需要的解决方案。这款开…...

5分钟成为网页资源管理高手:猫抓插件让你的浏览器无所不能

5分钟成为网页资源管理高手:猫抓插件让你的浏览器无所不能 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 你是否曾经在浏览网页时&…...

NVIDIA显卡性能深度调校指南:解锁200+隐藏参数的游戏优化利器

NVIDIA显卡性能深度调校指南:解锁200隐藏参数的游戏优化利器 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector 还在为游戏画面撕裂、输入延迟过高而烦恼?NVIDIA Profile Inspector…...

UABEA深度指南:Unity AssetBundle资源提取与序列化层逆向分析

1. 为什么Unity开发者总在“找资源”上浪费半天——UABEA不是万能钥匙,但它是你最该先摸清的那把 Unity项目交付后,美术资源、音频片段、UI图集、甚至脚本逻辑,常常被打包进AssetBundle(.unity3d)、Resources文件夹或更…...

Java+Selenium等待机制实战:显式等待、FluentWait与SPA适配

1. 为什么“等”这件事,比写代码还难? 在JavaSelenium项目里,我见过太多人把WebDriver写得行云流水,结果一跑自动化脚本就卡在“元素找不到”上——不是代码写错了,是 没等对 。你点一个按钮,页面跳转、数…...

微信小程序逆向分析终极指南:快速掌握wxappUnpacker完整实战技巧

微信小程序逆向分析终极指南:快速掌握wxappUnpacker完整实战技巧 【免费下载链接】wxappUnpacker forked from https://github.com/qwerty472123/wxappUnpacker 项目地址: https://gitcode.com/gh_mirrors/wxappu/wxappUnpacker 作为一名微信小程序开发者&am…...

JMeter并发与持续性压测:从按钮操作到系统心跳诊断

1. 这不是“点几下就出报告”的玩具,而是压测工程师的听诊器很多人第一次打开 JMeter,以为它就是个高级版的 Postman:填个 URL、点个“启动”,等几秒弹出个 Summary Report,看到平均响应时间 86ms 就松一口气&#xff…...

Postman并发测试真相:不是高并发工具,而是缺陷暴露加速器

1. 为什么“并发测试”不是点几下就能出结果的幻觉?很多人第一次打开 Postman 的 Collection Runner,看到“Iterations”和“Delay”两个输入框,心里就默认:“填个100,点Run,不就模拟100个用户同时访问了吗…...

JMeter压测5大底层优化:线程模型、HTTP连接、Groovy脚本、JVM参数与分布式协同

1. 为什么90%的JMeter脚本在压测中“假成功”——从一个被忽略的线程组配置说起你有没有遇到过这样的情况:脚本在JMeter GUI里跑得飞快,聚合报告里TPS稳稳上200,响应时间平均80ms,看起来一切完美;可一上生产环境做真实…...

Burp Suite MFA插件开发实战:状态机驱动的多因素认证自动化

1. 这不是“加个验证码”那么简单:为什么MFA插件开发是Burp生态里最被低估的硬功夫你肯定见过这样的场景:测试一个银行后台,登录流程走完用户名密码后,弹出Google Authenticator六位码;再点一下,又跳转到短…...

QMcDump终极指南:三步解锁QQ音乐加密文件,实现音乐自由

QMcDump终极指南:三步解锁QQ音乐加密文件,实现音乐自由 【免费下载链接】qmcdump 一个简单的QQ音乐解码(qmcflac/qmc0/qmc3 转 flac/mp3),仅为个人学习参考用。 项目地址: https://gitcode.com/gh_mirrors/qm/qmcdum…...

JMeter梯度压测:精准定位系统可扩展性边界

1. 为什么“梯度式压测”不是加个线程组就完事了?很多人第一次打开JMeter,照着教程建个线程组、加个HTTP请求、跑个聚合报告,看到TPS从200涨到800就以为“压测完成了”。结果上线后流量一上来,服务直接503,监控里CPU没…...

本地化RAG系统构建:从原理到实践,赋能大型系统开发与运维

1. 项目概述:当RAG遇上大型系统开发在大型计算系统的开发与运维中,我们常常面临一个经典困境:系统日益复杂,文档堆积如山,但当你需要快速定位一个特定配置的来龙去脉,或是排查一个偶发的异常时,…...