Bug fix
- Adds missing shape inference logic for :func:`spox.opsets.ai.v19.loop` and :func:`spox.opsets.ai.v21.loop`.
Other changes
- Propagated values may now be garbage collected if their associated Var object goes out of scope.
- :func:`spox.opsets.ai.v17.loop`, :func:`spox.opsets.ai.v19.loop` and :func:`spox.opsets.ai.v21.loop` will only infer shapes for loop carried dependencies if their shapes are unchanged across iterations.
Support change
- Support for
Python 3.8
has been dropped.
Bug fix
- Value propagation of string tensors no longer raises an erroneous
ValueError
in some instances.
Deprecation
- Importing :func:`spox._future.operator_overloading`` now triggers a
DeprecationWarning
. The function will be removed in a future release. Consider usingndonnx
as an alternative.
Other changes
- The adaption logic is not using inferred values as initializers anymore.
Bug fix
- Unset optional inputs are no longer erroneously prefixed by :func:`~spox.inline`.
Other changes
- The node-naming algorithm now has constant rather than quadratic time complexity.
New feature
- The :func:`spox.build` function gained the
drop_unused_inputs
argument.
New feature
- The opsets
ai.onnx
version 21 andai.onnx.ml
version 5 (released with ONNX 1.16) are now shipped with Spox.
Other changes
- Improved node creation speed by skipping the storing of the traceback
- :class:`spox.Var` objects may now be shallow copied. Deep copies are explicitly prohibited.
Bug fix
- Addresses node adaptation failure when referencing a non-input name from inside a subgraph by aborting opset adaptation.
Other changes
- Added
packaging
as an explicit dependency.
Other changes
- Spox's compatibility with older versions of onnx has been improved.
New feature
- The opsets
ai.onnx
version 20 andai.onnx.ml
version 4 (ONNX 1.15) are now shipped with Spox.
Other changes
- The validation of Node attributes has been improved and more consistent exceptions are raised if needed.
- ONNX node attributes are now computed only once and then cached so that the values are reused for validation and building the model.
New feature
- The opsets
ai.onnx
version 20 andai.onnx.ml
version 4 (ONNX 1.15) are now shipped with Spox.
Bug fixes
- Address missing Value Infos when building singleton model for shape inference.
- Fix issue where Value Propagation failure prevents model creation/inlining.
Other changes
- Fix a deprecation warning from one of Spox's dependencies.
Bug fixes
- The node-adaption no longer fails if faced with a node that has repeating inputs.
- Forego version adaption of inlined models if no nodes are from the default domain.
New feature
- The opset
ai.onnx@19
(ONNX 1.14) is now shipped with Spox.
Bug fixes
- The constructor for
ai.onnx@18::Split
is no longer generated incorrectly. No extraneous attribute is generated anymore, and thenum_outputs
attribute is marked as required (so that Spox can infer the number of outputs). - Fix an issue where op.const handled numbers in the range(INT64MAX, UINT64MAX) incorrectly
Other changes
- Inlining now no longer adds redundant
Identity
nodes and supports subgraphs, thanks to reimplementing the ONNX renaming routine.
Bug fixe
- An explicit error is now raised when local subgraph arguments are leaked to an outer scope. This may happen when the subgraph callback uses side effects saving local variables, which would produce later a confusing error message.
This version is intended as a release candidate for 1.0.0
.
New feature
- Spox now explicitly sets a model's IR version (currently to version 8) rather than defaulting to the latest IR version supported by the installed onnx package. Increasing the IR version is not considered a breaking change going forward. The IR version will be increase once the ecosystem has adopted it more broadly.
Bug fixes
- Fix an issue with resolving scopes during the build process. They manifested with a
KeyError
in accessing variables in scope on graphs in complex dependencies between subgraphs. inline
now removes all symbolic dimensions from input/output shapes (i.e.N x 2
becomes? x 2
) before inferring types to avoid inconsistent interactions. This is only a visual change of the output in some cases, as they are not compared strictly in ONNX.inline
now explicitly does not accept model with subgraphs and local functions. Attempting to use these would usually result in invalid models. Support for them will be added in the future.
This version is intended as a release candidate for 1.0.0
.
New features
- The opset
ai.onnx@18
is now shipped with Spox (version 18 of the default domain, as introduced in ONNX 1.13). To avoid code duplication, unchanged implementations are 'inherited' from the previous version.
Breaking changes
- The typing rules of the (previously partially documented) extra constructor
const
have changed. Its signature is nowconst(npt.ArrayLike, npt.DTypeLike = None) -> Var
. In particular,const
of a Pythonfloat
no longer becomesfloat32
, butfloat64
like numpy - this is a breaking change. The operator is redefined to be equivalent toconstant(numpy.array(value), dtype)
, instead of a complex set of cases like before. - The
Type <= Type
(Type.__le__
) overload is now removed. - Deprecated operator constructors are now no longer generated after the version their schema was deprecated. Effectively, this means
ai.onnx@17::Scatter
andai.onnx@17::Upsample
(available asop.scatter
andop.upsample
) are no longer available inspox.opset.ai.onnx.v17
. They likely were not used in practice as attempting to build deprecated operators has always failed.
Bug fixes
- The operator constructor
cum_sum
now also has an aliascumsum
, to mirrornumpy
. This alias should be preferred.
New unstable features
spox._future.initializer(ArrayLike, DTypeLike = None) -> Var
is a new function for creating variables from a constant value. The created value is constructed withnumpy.array
and follows the same rules. This function is opset-independent and is implemented using initializers.
Pending breaking changes
- The previously available
Type <= Type
(Type.__le__
) overload is deprecated and will be removed in Spox0.7.0
, as it was unintentionally public. - Constructors for deprecated ONNX operators (currently
Scatter
andUpsample
) now raise a warning when they are called. They will be removed entirely in0.7.0
.
Bug fixes
spox.inline
now correctly renames unused model inputs when building. This could previously cause invalid models to be built.- Array attributes are now copied when they are passed to an operator. This avoids accidentally mutating them after the operator is constructed.
- The
Loop
operator now has patched type inference, so that the loop-carries in its results preserve shapes if the subgraph had them inferred.
Pending breaking changes
- An undocumented extra operator constructor (
const
) now raises aDeprecationWarning
onfloat
, as its behaviour will change in Spox0.7.0
to follow that ofnumpy
.
New features
spox.inline
was added to the public interface, allowing embedding existing ONNX models in Spox.
Other changes
- Models now have a minimum opset version of
14
for theai.onnx
domain to avoid issues with low-versioned models in ORT and other tooling.
Breaking changes
- The operator constructor for
MatMul
-mat_mul
- has been renamed tomatmul
to follow numpy naming.
New features
- The
spox.build
andspox.argument
functions were added enabling the building of graphs through a stable interface.
Notable changes
- The documentation formatting inside the (auto-generated)
spox.opset
module was greatly improved.
Breaking changes
- Removed the
Var.dtype
andVar.shape
properties in favor of the more explicitVar.unwrap_tensor().dtype
andVar.unwrap_tensor().shape
ones.
Bug fixes
- Non-ASCII characters in constant tensors are now handled correctly.
- The
Compress
operator has gained an explicit type and shape inference implementation
Notable changes
- Renamed the library to Spox
- Reduced the public API surface to a bare minimum such that downstream packages may offer a usable and stable user experience with spox-based converters. This release is intended as a release candidate. Breaking changes may still occur if necessary.