本项目已不再维护。最近的一个问题使我意识到是时候将这个项目归档了。我没有时间维护它,也没有计划在未来对其进行改进。深度学习领域已经发生了变化,我相信通过适应性演化,新的想法将会出现,使深度学习更加便携,从而使这个项目过时。

这是一个用于开放神经网络交换(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一键生成PPT,就用博思AIPPT!
博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。


AI赋能电商视觉革命,一站式智能商拍平台
潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。


企业专属的AI法律顾问
iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。


稳定高效的流量提升解决方案,助力品牌曝光
稳定高效的流量提升解决方案,助力品牌曝光


最新版Sora2模型免费使用,一键生成无水印视频
最新版Sora2模型免费使用,一键生成无水印视频


实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。


选题、配图、成文,一站式创作,让内容运营更高效
讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。


AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。


最强AI数据分析助手
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。


像人一样思考的AI智能体
imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。