本项目已不再维护。最近的一个问题使我意识到是时候将这个项目归档了。我没有时间维护它,也没有计划在未来对其进行改进。深度学习领域已经发生了变化,我相信通过适应性演化,新的想法将会出现,使深度学习更加便携,从而使这个项目过时。
这是一个用于开放神经网络交换(ONNX)的Go接口。
onnx-go包含了将onnx二进制模型解码到计算后端的原语,你可以像使用任何其他库一样在你的Go代码中使用它。 有关onnx的更多信息,请访问onnx.ai。
ONNX规范的实现在导入方面是部分完成的,而在导出方面则尚未实现。
对于需要在代码中添加机器学习功能的Go开发者来说, onnx-go 是一个便于使用神经网络模型(软件2.0)的包, 与其他计算库不同,这个包不需要数据科学方面的特殊技能。
警告 API仍处于实验阶段,可能会发生变化。
这是API的新版本。 已移除Gorgonia的修改版本。现在与Gorgonia的主分支兼容。 不过,某些运算符尚未可用。
添加了一个用于运行模型库中模型的实用工具。
请查看examples
子目录。
通过go get安装
go get github.com/owulveryck/onnx-go
onnx-go与go modules兼容。
这些示例假设你有一个预训练的model.onnx
文件可用。
你可以从onnx模型库下载预训练模型。
这个示例只是将图解码到一个简单的后端中。 然后你可以对生成的图做任何你想做的事。
// 创建一个后端接收器 backend := simple.NewSimpleGraph() // 创建一个模型并设置执行后端 model := onnx.NewModel(backend) // 读取onnx模型 b, _ := ioutil.ReadFile("model.onnx") // 将其解码到模型中 err := model.UnmarshalBinary(b)
这个示例使用Gorgonia作为后端。
import "github.com/owulveryck/onnx-go/backend/x/gorgonnx"
目前,Gorgonia还没有实现ONNX的所有运算符。因此,大多数来自模型库的模型将无法工作。 通过逐步向后端添加更多运算符,情况会逐渐改善。
你可以在这里找到已测试示例的列表和覆盖率。
func Example_gorgonia() { // 创建一个后端接收器 backend := gorgonnx.NewGraph() // 创建一个模型并设置执行后端 model := onnx.NewModel(backend) // 读取onnx模型 b, _ := ioutil.ReadFile("model.onnx") // 将其解码到模型中 err := model.UnmarshalBinary(b) if err != nil { log.Fatal(err) } // 设置第一个输入,数量取决于模型 model.SetInput(0, input) err = backend.Run() if err != nil { log.Fatal(err) } // 检查错误 output, _ := model.GetOutputTensors() // 将第一个输出写入stdout fmt.Println(output[0]) }
在examples
子目录中,你会找到一个用于运行模型库中模型的实用工具,以及一个使用Tiny YOLO v2分析图片的示例工具。
onnx的protobuf定义使用经典的protoc
工具编译成Go代码。定义可以在internal
目录中找到。
该定义不对外暴露,以避免对这个仓库的外部依赖。实际上,pb代码可能会改变以使用更高效的编译器,如gogo protobuf
,这种变化对这个包的用户应该是透明的。
为了执行神经网络,你需要一个能够执行计算图的后端(有关计算图的更多信息,请阅读这篇博客文章)
这张图表示了机制:
onnx-go本身不提供任何可执行的后端,但作为参考,提供了一个简单的后端作为示例,用于构建信息图(见simple
子包)。
Gorgonia是ONNX-Go的主要目标后端。
后端基本上是一个加权有向图,可以对其节点应用操作。它应该满足这个接口:
type Backend interface { OperationCarrier graph.DirectedWeightedBuilder }
type OperationCarrier interface { // 对图节点应用操作 // graph.Node是一个数组,因为它允许处理多个输出 // 例如,split操作返回n个节点... ApplyOperation(Operation, ...graph.Node) error }
操作由其name
和一个属性映射表示。例如,onnx规范中描述的卷积操作将表示如下:
convOperator := Operation{ Name: "Conv", Attributes: map[string]interface{}{ "auto_pad": "NOTSET", "dilations": []int64{1, 1}, "group": 1, "pads": []int64{1, 1}, "strides": []int64{1, 1}, }, }
除了操作符外,节点还可以携带一个值。值被描述为tensor.Tensor
为了携带数据,图的*Node
*应该满足这个接口:
type DataCarrier interface { SetTensor(t tensor.Tensor) error GetTensor() tensor.Tensor }
onnx-go提供了一些用于测试后端的实用工具。更多信息请访问testbackend
包。
欢迎贡献。贡献指南将最终被编写。同时,你可以提出问题或发送PR。 你也可以通过Twitter或gophers' slack联系我(我在两个平台上的用户名都是@owulveryck)
本项目旨在成为一个安全、友好的合作空间,贡献者应遵守贡献者公约行为准则。
MIT。
字节跳动发布的AI编程神器IDE
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
全能AI智能助手,随时解答生活与工作的多样问题
问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。
实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语 言交流不再有国界。
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
深度推理能力全新升级,全面对标OpenAI o1
科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力 用户轻松获取信息、解决问题,满足多样化使用场景。
一种基于大语言模型的高效单流解耦语音令牌 文本到语音合成模型
Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。
AI助力,做PPT更简单!
咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。
选题、配图、成文,一站式创作,让内容运营更高效
讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。
专业的AI公文写作平台,公文写作神器
AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。
OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。
openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。
最新AI工具、AI资讯
独家AI资源、AI项目落地
微信扫一扫关注公众号