Project Icon

wanda

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

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

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

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

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

@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}
}

与仅基于权重大小进行修剪的方法相比,我们的修剪方法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

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

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

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号