导出LLaMA等LLM模型为onnx

通过onnx模型可以在支持onnx推理的推理引擎上进行推理,从而可以将LLM部署在更加广泛的平台上面。此外还可以具有避免pytorch依赖,获得更好的性能等优势。

这篇博客(大模型LLaMa及周边项目(二) - 知乎)进行了llama导出onnx的开创性的工作,但是依赖于侵入式修改transformers库,比较不方便。

这里本人实现了避免侵入式修改transformers库导出LLM为ONNX方法,代码库为:

https://github.com/luchangli03/export_llama_as_onnx/tree/main

可以在这个基础上进行简单修改从而导出其他模型,例如百川,Qwen等模型。当前已经加入了对Qwen的导出支持。

该方案优点是无需侵入式修改transformers代码,缺点是你需要提前了解各个模型的输入,相关shape和dtype。

导出的llama decoder会存在if算子,但是经过符号shape推导和设置相应的符号shape到onnx模型value_info,然后经过onnxsim可以完全去掉。也可以考虑修改llama定义代码去掉if。优化前后:

相关推荐
优爱蛋白几秒前
IL-21:后Th1/Th2时代的免疫新星
java·服务器·前端·人工智能·健康医疗
深圳佛手几秒前
LangChain 提供的搜素工具SerpAPIWrapper介绍
开发语言·人工智能·python
Dreamshop_AI4 分钟前
电商视觉时代:如何用Dreamshop重构“人-货-场”?
大数据·人工智能·经验分享·ai作画·aigc
渡我白衣6 分钟前
计算机组成原理(4):计算机的层次结构与工作原理
运维·c语言·网络·c++·人工智能·笔记·硬件架构
忘记5789 分钟前
下载llama factory
llama
路边草随风10 分钟前
llama_index简单使用
人工智能·python·llama
zqy022710 分钟前
质量保障追求敏捷与快速交付
人工智能
瀚岳-诸葛弩11 分钟前
对比tensorflow,从0开始学pytorch(一)
人工智能·pytorch·tensorflow
宝贝儿好12 分钟前
【强化学习】第二章:老虎机问题、ε-greedy算法、指数移动平均
人工智能·python·算法
AI视觉网奇12 分钟前
实时 数字人 DH_live 半身
人工智能·计算机视觉