Optimization
Optimization
The optimum.fx.optimization
module provides a set of torch.fx graph transformations, along with classes and functions to write your own transformations and compose them.
The transformation guide
In 🌍 Optimum, there are two kinds of transformations: reversible and non-reversible transformations.
Write a non-reversible transformation
The most basic case of transformations is non-reversible transformations. Those transformations cannot be reversed, meaning that after applying them to a graph module, there is no way to get the original model back. To implement such transformations in 🌍 Optimum, it is very easy: you just need to subclass Transformation and implement the transform() method.
For instance, the following transformation changes all the multiplications to additions:
Copied
After implementing it, your transformation can be used as a regular function:
Copied
Write a reversible transformation
A reversible transformation implements both the transformation and its reverse, allowing to retrieve the original model from the transformed one. To implement such transformation, you need to subclass ReversibleTransformation and implement the transform() and reverse() methods.
For instance, the following transformation is reversible:
Copied
Composing transformations together
As applying multiple transformations in chain is needed more often that not, compose() is provided. It is an utility function that allows you to create a transformation by chaining multiple other transformations.
Copied
Last updated