We believe there is a need for greater interoperability in the AI tools community. Many people are working on great tools, but developers are often locked in to one framework or ecosystem. ONNX is the first step in enabling more of these tools to work together by allowing them to share models.
Our goal is to make it possible for developers to use the right combinations of tools for their project. We want everyone to be able to take AI from research to reality as quickly as possible without artificial friction from toolchains. We hope you'll join us in this mission!
Community
ONNX is a community project. We encourage you to join the effort and contribute feedback, ideas and code.
For more information, check out our contribution guide, or join a Special Interest Group (SIG) or Working Group today.
Partners
ONNX is supported by a community of partners
Technical Design
ONNX provides a definition of an extensible computation graph model, as well as definitions of built-in operators and standard data types.
Each computation dataflow graph is structured as a list of nodes that form an acyclic graph. Nodes have one or more inputs and one or more outputs. Each node is a call to an operator. The graph also has metadata to help document its purpose, author, etc.
Operators are implemented externally to the graph, but the set of built-in operators are portable across frameworks. Every framework supporting ONNX will provide implementations of these operators on the applicable data types.
More details can be found on GitHub.