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

相关推荐
Blossom.1186 小时前
多模态大模型LoRA微调实战:从零构建企业级图文检索系统
人工智能·python·深度学习·学习·react.js·django·transformer
檐下翻书1736 小时前
模型蒸馏与压缩技术的新进展
人工智能
小陈phd6 小时前
Dify从入门到精通(一)——Dify环境搭建
人工智能
zabr6 小时前
前端已死?我用 Trae + Gemini 零代码手搓 3D 塔罗牌,找到了新出路
前端·人工智能·aigc
速易达网络6 小时前
Trae智能体SOLO中国版
人工智能·trae
橙汁味的风7 小时前
2EM算法详解
人工智能·算法·机器学习
永霖光电_UVLED7 小时前
日本 Novel Crystal 突破10kV障碍
人工智能
小鸡吃米…7 小时前
带Python的人工智能——计算机视觉
人工智能·python·计算机视觉
oscar9997 小时前
激活函数:神经网络的“开关”与“灵魂”
人工智能·深度学习·神经网络·激活函数
万岳软件开发小城7 小时前
2026 在线教育新趋势:网校系统源码正在重塑教育培训平台开发模式
人工智能·php·在线教育系统源码·教育平台搭建·教育app开发·教育软件开发