wanda

wanda

基于权重和激活的大型语言模型剪枝技术

Wanda是一种针对大型语言模型(LLM)的剪枝技术,通过结合权重大小和输入激活范数来选择性移除权重。相比传统的仅基于权重大小的剪枝方法,Wanda展现出更高的效率。该技术支持LLaMA、LLaMA-2等多种模型,可实现非结构化和结构化稀疏。Wanda方法简单实用,在维持模型性能的同时有效降低参数量,为LLM的轻量化和优化开辟了新途径。

WandaLLM剪枝模型压缩稀疏性权重激活Github开源项目

通过权重和激活值修剪大语言模型

Wanda(Weights and activations修剪法)的官方PyTorch实现,如我们的论文所述:

一种简单而有效的大语言模型修剪方法</br> Mingjie Sun*, Zhuang Liu*, Anna Bair, J. Zico Kolter (* 表示贡献相同) <br> 卡内基梅隆大学, Meta AI研究院和博世人工智能中心 <br> 论文 - 项目主页

@article{sun2023wanda, title={A Simple and Effective Pruning Approach for Large Language Models}, author={Sun, Mingjie and Liu, Zhuang and Bair, Anna and Kolter, J. Zico}, year={2023}, journal={arXiv preprint arXiv:2306.11695} }

<p align="center"> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/2beb0918-9afd-4825-b4f0-534c1e57e6da.png" width=100% height=100% class="center"> </p>

与仅基于权重大小进行修剪的方法相比,我们的修剪方法Wanda通过权重大小和输入激活范数的乘积,在每个输出基础上移除权重。

更新

  • (2023.9.22) 增加对LLaMA-2的支持
  • (2023.9.22) 增加代码以复现论文中关于OBS权重更新的消融研究。
  • (2023.10.6) 为消融研究中的权重更新分析添加新的支持。欢迎试用!
  • (2023.10.6) 增加对零样本评估的支持。
  • (2023.10.20) 增加修剪OPT模型的代码。
  • (2023.10.23) 增加LoRA微调的代码。

设置

安装说明可以在INSTALL.md中找到。

使用方法

scripts目录包含了所有用于复现论文主要结果(表2)的bash命令。

以下是使用Wanda修剪LLaMA-7B以实现非结构化50%稀疏度的示例命令:

python main.py \ --model decapoda-research/llama-7b-hf \ --prune_method wanda \ --sparsity_ratio 0.5 \ --sparsity_type unstructured \ --save out/llama_7b/unstructured/wanda/

以下是参数的简要概述:

  • --model: Hugging Face模型库中LLaMA模型的标识符。
  • --cache_dir: 加载或存储LLM权重的目录。默认为llm_weights
  • --prune_method: 我们实现了三种修剪方法,即[magnitude, wanda, sparsegpt]。
  • --sparsity_ratio: 表示要修剪的权重百分比。
  • --sparsity_type: 指定稀疏度类型[unstructured, 2:4, 4:8]。
  • --use_variant: 是否使用Wanda变体,默认为False
  • --save: 指定结果存储的目录。

对于结构化N:M稀疏度,将参数--sparsity_type设置为"2:4"或"4:8"。以下是一个示例命令:

python main.py \ --model decapoda-research/llama-7b-hf \ --prune_method wanda \ --sparsity_ratio 0.5 \ --sparsity_type 2:4 \ --save out/llama_7b/2-4/wanda/

修剪LLaMA-2

对于LLaMA-2模型,将--model替换为meta-llama/Llama-2-7b-hf(以7b为例):

python main.py \ --model meta-llama/Llama-2-7b-hf \ --prune_method wanda \ --sparsity_ratio 0.5 \ --sparsity_type unstructured \ --save out/llama2_7b/unstructured/wanda/

LLaMA-2结果:(截至2023.9.22,LLaMA-2-34b尚未发布)

稀疏度pplllama2-7bllama2-13bllama2-70b
-密集5.124.573.12
非结构化50%magnitude14.896.374.98
非结构化50%sparsegpt6.515.633.98
非结构化50%wanda6.425.563.98
4:8magnitude16.486.765.58
4:8sparsegpt8.126.604.59
4:8wanda7.976.554.47
2:4magnitude54.598.336.33
2:4sparsegpt10.178.325.40
2:4wanda11.028.275.16

OBS权重更新消融实验

为重现权重更新分析,我们提供了此消融实验的实现。所有命令可在此脚本中找到。

for method in ablate_mag_seq ablate_wanda_seq ablate_mag_iter ablate_wanda_iter do CUDA_VISIBLE_DEVICES=0 python main.py \ --model decapoda-research/llama-7b-hf \ --sparsity_ratio 0.5 \ --sparsity_type unstructured \ --prune_method ${method} \ --save out/llama_7b_ablation/unstructured/ done

这里ablate_{mag/wanda}_{seq/iter}表示我们使用幅度剪枝或wanda在每一层获取剪枝掩码,然后以顺序或迭代方式每128个输入通道应用一次权重更新程序。详情请参阅我们论文的第5节。

零样本评估

为评估零样本任务,我们修改了EleutherAI LM Harness框架,使其能够评估剪枝后的LLM模型。我们在此链接提供了修改后的仓库。请确保下载、解压并从源代码安装此自定义lm_eval包。

为保证可重现性,我们使用了主分支上的commit df3da98。除BoolQ任务版本为1外,所有任务均使用版本0进行评估。

总的来说,我们提供的功能是在这个函数中添加两个参数pretrained_modeltokenizer。然后我们可以从我们的代码库调用这个simple_evaluate函数API来评估稀疏剪枝后的LLM。要评估零样本任务以及WikiText困惑度,请传入--eval_zero_shot参数。

加速评估

每种方法的剪枝速度通过累计每层剪枝所花费的时间来评估,不包括前向传播。

对于结构化稀疏性的推理加速,我们建议读者参考这篇博客文章,其中PyTorch >= 2.1支持结构化稀疏性。你可以在这里切换CUTLASS或CuSPARSELt内核。

最后,关于剪枝图像分类器,请参见image_classifiers目录了解详情。

致谢

本仓库基于SparseGPT仓库构建。

许可

本项目在MIT许可下发布。更多信息请参见LICENSE文件。

问题

欢迎通过issues/邮件与我们讨论论文/代码!

mingjies at cs.cmu.edu
liuzhuangthu at gmail.com

编辑推荐精选

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

下拉加载更多