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

相关推荐
yiersansiwu123d3 分钟前
AI伦理治理:在创新与规范之间寻找平衡之道
人工智能
程途拾光1589 分钟前
AI 生成内容的伦理边界:深度伪造与信息真实性的保卫战
人工智能
趣味科技v13 分钟前
亚马逊云科技储瑞松:AI智能体正在重塑未来工作模式
人工智能·科技
GEO AI搜索优化助手17 分钟前
GEO生态重构:生成式引擎优化如何重塑信息传播链
人工智能·搜索引擎·生成式引擎优化·ai优化·geo搜索优化
爱笑的眼睛1124 分钟前
GraphQL:从数据查询到应用架构的范式演进
java·人工智能·python·ai
江上鹤.14828 分钟前
Day40 复习日
人工智能·深度学习·机器学习
QYZL_AIGC30 分钟前
全域众链以需求为基、政策为翼,创AI + 实体的可行之路
人工智能
火星资讯31 分钟前
Zenlayer AI Gateway 登陆 Dify 市场,轻装上阵搭建 AI Agent
大数据·人工智能
TextIn智能文档云平台35 分钟前
LLM处理非结构化文档有哪些痛点
人工智能·文档解析
Coder_Boy_1 小时前
DDD从0到企业级:迭代式学习 (共17章)之 四
java·人工智能·驱动开发·学习