导出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。优化前后:

相关推荐
秋刀鱼 ..13 小时前
第五届机电一体化、自动化与智能控制国际学术会议(MAIC 2025)
运维·人工智能·python·机器人·自动化·制造·新人首发
多则惑少则明13 小时前
AI测试、大模型测试(五)AI测试工具有哪些
人工智能·测试工具·ai测试·大模型测试
沃丰科技13 小时前
以全栈AI能力重塑智能客服服务效能
人工智能·机器学习·自然语言处理
O561 6O623O7 安徽正华露13 小时前
(露)冷光源 大鼠洞板 新生鼠适配器
人工智能
musk121213 小时前
深度学习中 z-score 标准化理解
人工智能·深度学习·z-socre
小脉传媒GEO优化13 小时前
掌控数据燃料:面向ChatGPT的数据策略优化指南
人工智能·chatgpt
多则惑少则明13 小时前
AI测试、大模型测试(四)AI测试分类&AI测试岗位分工
人工智能·ai测试·大模型测试·算法测试
Mxsoft61913 小时前
我发现边缘节点资源不足致处理延迟,动态资源调度算法救场!
人工智能
shayudiandian13 小时前
MobaXterm高效运维实战技术文章大纲
人工智能
小白狮ww13 小时前
挥手点亮圣诞:AI 3D 魔法树教程
人工智能·深度学习·机器学习·3d·音视频·图片处理·动作识别