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

相关推荐
爱吃羊的老虎8 分钟前
【大模型应用】MCP (Model Context Protocol):AI界的USB接口
人工智能
用户51914958484513 分钟前
curl中的TFTP实现:整数下溢导致堆内存越界读取漏洞
人工智能·aigc
老赵全栈实战15 分钟前
《从零搭建RAG系统第5天:安装Ollama》
人工智能
星爷AG I21 分钟前
12-4 表情识别(AGI基础理论)
人工智能·agi
Sopaco23 分钟前
AI驱动的多智能体协作模式:Actor-Critic在软件开发中的应用
人工智能
heimeiyingwang29 分钟前
AI 在企业客服场景的应用:智能问答与工单自动化
人工智能
小程故事多_8034 分钟前
OpenViking,重新定义AI Agents上下文管理的开源利器
人工智能·aigc
菜鸟小芯34 分钟前
DAY4 基于 OpenClaw + 飞书开放平台实现 AI 新闻推送机器人
人工智能·机器人·飞书
systeminof38 分钟前
七色年味映双流:AI镜头下的烟火中国年
人工智能
yuezhilangniao40 分钟前
【AI 编辑器开发规范 v2.1 版】—— 为 AI 时代的敏捷开发而生
人工智能·编辑器·敏捷流程