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

相关推荐
雍凉明月夜1 分钟前
视觉opencv学习笔记Ⅴ-数据增强(2)
人工智能·python·opencv·计算机视觉
JoannaJuanCV7 分钟前
自动驾驶—CARLA仿真(24)sensor_synchronization demo
网络·人工智能·自动驾驶·carla
JoannaJuanCV7 分钟前
自动驾驶—CARLA仿真(14)draw_skeleton demo
人工智能·机器学习·自动驾驶
测试人社区-千羽8 分钟前
飞机自动驾驶系统测试:安全关键系统的全面验证框架
人工智能·安全·面试·职场和发展·自动化·自动驾驶·测试用例
Abona9 分钟前
广义端到端(GE2E)自动驾驶技术综述:范式演进、核心挑战与破局路径
人工智能·机器学习·自动驾驶
CSDN官方博客9 分钟前
CSDN社区镜像创作活动
大数据·运维·人工智能
JoannaJuanCV18 分钟前
自动驾驶—CARLA仿真(12)client_bounding_boxes demo
人工智能·自动驾驶·pygame·carla
志凌海纳SmartX18 分钟前
AI知识科普丨ModelOps / MLOps / LLMOps 有什么区别?
人工智能
SACKings19 分钟前
神经网络的层是什么?
人工智能·深度学习·神经网络
云闲不收21 分钟前
AI之 n8n
人工智能