quark.onnx.graph_transformations.transforms
#
Module Contents#
Classes#
- class quark.onnx.graph_transformations.transforms.OpTypePattern(op_type: str = '', inputs: List[OpTypePattern] | None = None, config: Dict[str, Any] | None = None)#
Defines a tree sub-graph pattern of onnx nodes to match in a model.
OpTypePattern can be used to describe various common patterns in model graphs that we need to find.
- Examples:
Matches a Conv+BN+ReLU6 and DepthwiseConv+BN+ReLU6 pattern. pattern = OpTypePattern(‘ReLU’, {‘max_value’: 6.0}, [
- OpTypePattern(‘BatchNormalization’, {}, [
OpTypePattern(‘Conv2D|DepthwiseConv2D’, {} [])
])
])
Matches multiple Conv2Ds feeding into a Concat. pattern = OpTypePattern(‘Concat’, {}, [
OpTypePattern(‘Conv2D’, {}, []), OpTypePattern(‘Conv2D’, {}, [])
])
- class quark.onnx.graph_transformations.transforms.NodeTree(node: onnx.NodeProto | None = None, weights: OrderedDict[str, onnx.TensorProto] | List[Any] | None = None, input_nodes: List[NodeTree] | None = None, metadata: Dict[str, Any] | None = None)#
Represents a pattern matching results in a node containing a tree.
NodeTree is used to represent a tree of nodes in a model. It contains the NodeDef which describes the node, and other input nodes feeding into it.
It is used as a generic class to represent both sets of nodes which have been found in a model, and nodes which should be replaced inside the model.
- class quark.onnx.graph_transformations.transforms.Transform#
Defines a transform to be applied to a onnx model graph.
A transform is a combination of ‘Find + Replace’ which describes how to find a pattern of nodes in a model, and what to replace those nodes with.
A pattern is described using OpTypePattern. The replacement function receives a NodeTree which contains the matched nodes and should return a NodeTree which contains the set of nodes which replaced the matched nodes.
- property allow_multi_consumers: bool#
Whether to allow the internal node have multiple consuming nodes.
- E.g.
B B
// //
- A – to E –
C –> D F
Should set allow_mulit_consumers if you want to match pattern “A –> C –> D”. Please be careful to handle the transformation to not break the input connection of consumers outside the pattern, otherwise will lead to unknown input tensors.
- abstract pattern() OpTypePattern #
Return the OpTypePattern to find in the model graph.
- abstract replacement(match_node: NodeTree) Any #
Generate a replacement sub-graph for the matched sub-graph.
The fundamental constraint of the replacement is that the replacement sub-graph should consume the same input tensors as the original sub-graph and also produce a final list of tensors which are same in number and shape as the original sub-graph. Not following this could crash model creation, or introduce bugs in the new model graph.
- Args:
match_nodes: Matched NodeTree based on self.pattern().