Skip to content

Enable QuantFusionPass in compiler pipeline (#19728)#19728

Open
ethansfng wants to merge 5 commits into
pytorch:mainfrom
ethansfng:export-D105728219
Open

Enable QuantFusionPass in compiler pipeline (#19728)#19728
ethansfng wants to merge 5 commits into
pytorch:mainfrom
ethansfng:export-D105728219

Conversation

@ethansfng
Copy link
Copy Markdown
Contributor

@ethansfng ethansfng commented May 21, 2026

Summary:

Both and Cadence now use the shared QuantFusionPass from compiler_funcs.py.

  • QuantFusionPass in compiler_funcs.py iterates patterns, matches anchor_ops(), calls fuse() on each match, with debug logging and dead code elimination
  • Cadence: compiler.py now uses QuantFusionPass instead of the old QuantFusion isinstance switch
  • Removed Cadence compiler target's dep on :fusion_pass (no longer imported)

Differential Revision: D105728219

@pytorch-bot
Copy link
Copy Markdown

pytorch-bot Bot commented May 21, 2026

🔗 Helpful Links

🧪 See artifacts and rendered test results at hud.pytorch.org/pr/pytorch/executorch/19728

Note: Links to docs will display an error until the docs builds have been completed.

❌ 1 New Failure, 2 Unrelated Failures

As of commit 181c7bd with merge base 7d8063f (image):

NEW FAILURE - The following job has failed:

BROKEN TRUNK - The following jobs failed but were present on the merge base:

👉 Rebase onto the `viable/strict` branch to avoid these failures

This comment was automatically generated by Dr. CI and updates every 15 minutes.

@meta-cla meta-cla Bot added the CLA Signed This label is managed by the Facebook bot. Authors need to sign the CLA before a PR can be reviewed. label May 21, 2026
@meta-codesync
Copy link
Copy Markdown
Contributor

meta-codesync Bot commented May 21, 2026

@ethansfng has exported this pull request. If you are a Meta employee, you can view the originating Diff in D105728219.

@github-actions
Copy link
Copy Markdown

This PR needs a release notes: label

If your change should be included in the release notes (i.e. would users of this library care about this change?), please use a label starting with release notes:. This helps us keep track and include your important work in the next release notes.

To add a label, you can comment to pytorchbot, for example
@pytorchbot label "release notes: none"

For more information, see
https://github.com/pytorch/pytorch/wiki/PyTorch-AutoLabel-Bot#why-categorize-for-release-notes-and-how-does-it-work.

@meta-codesync meta-codesync Bot changed the title Unify quantization fusion pass across backends Unify quantization fusion pass across backends (#19728) May 21, 2026
ethansfng added a commit to ethansfng/executorch that referenced this pull request May 21, 2026
Summary:

Enable new QuantFusionPass that calls pattern.fuse() instead of monolithic QuantFusion

Differential Revision: D105728219
@ethansfng ethansfng force-pushed the export-D105728219 branch from 42b8ffe to 8f2e4ea Compare May 21, 2026 21:11
ethansfng added a commit to ethansfng/executorch that referenced this pull request May 21, 2026
Summary:

Enable new QuantFusionPass that calls pattern.fuse() instead of monolithic QuantFusion

Differential Revision: D105728219
@ethansfng ethansfng force-pushed the export-D105728219 branch from 8f2e4ea to 250f45e Compare May 21, 2026 21:18
ethansfng added a commit to ethansfng/executorch that referenced this pull request May 22, 2026
Summary:

Enable new QuantFusionPass that calls pattern.fuse() instead of monolithic QuantFusion

Differential Revision: D105728219
@ethansfng ethansfng force-pushed the export-D105728219 branch from 250f45e to 9010a85 Compare May 22, 2026 18:48
@meta-codesync meta-codesync Bot changed the title Unify quantization fusion pass across backends (#19728) Enable QuantFusionPass in compiler pipeline May 23, 2026
@ethansfng ethansfng force-pushed the export-D105728219 branch from 9010a85 to 6e7ff7c Compare May 23, 2026 00:38
ethansfng added 5 commits May 22, 2026 21:00
…19743)

Summary:

torchao's `convert_pt2e` adds `out_dtype` kwargs to dequant nodes for bf16 models. `cadence::dequantize_per_tensor` doesn't support this kwarg (it hardcodes float32 output), so `ReplacePT2DequantWithCadenceDequantPass` crashes when it forwards kwargs blindly to the cadence op.

Strip `out_dtype` from kwargs before creating the cadence dequant node, and insert an `aten.to.dtype` cast after it to preserve the original output dtype semantics.

Differential Revision: D105630451
Summary:

Add infrastructure for per-pattern `fuse()` methods on Cadence `QuantizationPattern`:

- Add `anchor_ops()` (default: `tuple(partition_types())`) and `fuse()` (default: `None`) to `QuantizationPattern` base class
- Add shared fusion helpers: `_get_dequant`, `_find_quant_user`, `_insert_fused_op`, `_maybe_route_depthwise_conv1d`, `_fuse_conv`, `_fuse_linear`, `_fuse_matmul`
- Add `QuantFusionPass` to `compiler_funcs.py` — shared executor that iterates patterns, matches `anchor_ops()`, calls `fuse()` with debug logging and dead code elimination

Differential Revision: D105728137
Summary:

Add `fuse()` implementations to the first batch of Cadence `QuantizationPattern` subclasses — the standard fully-quantized patterns that use the shared `_fuse_conv`, `_fuse_linear`, and `_fuse_matmul` helpers:

- `AddmmPattern` — transpose weight + linear fusion
- `AddPattern` — two-input quantized add
- `AddReluBasePattern` — add+relu fusion with `anchor_ops()` override
- `BmmPattern`, `MatmulPattern` — matmul fusion via `_fuse_matmul`
- `CatPattern` — cat passthrough on quantized inputs
- `Conv1dPattern`, `Conv2dPattern` — conv fusion via `_fuse_conv` with depthwise routing
- `LayerNormPattern` — layer norm with default weight/bias creation
- `LinearPattern` — linear fusion via `_fuse_linear`

Differential Revision: D105728156
Summary:

Add `fuse()` implementations to the remaining Cadence `QuantizationPattern` subclasses:

- `MaxPool2dPattern`, `MaxPool2dWithoutIndicesPattern` — order-preserving pool on quantized values
- `ReluBasePattern` (inherited by `ReluPattern0`/`1`) — relu with requantization
- `ConvReluBasePattern` (inherited by `Conv1d`/`2dReluPattern0`/`1`) — conv+relu fusion with `anchor_ops()` override to match only the conv op
- `SoftmaxPattern` — softmax with dummy mask/pos tensors and fake_mode metadata
- `MixedW8A32LinearPattern` — weight-only quantized linear (no input/output quant)
- `MixedW8A32ConvPattern` — weight-only quantized conv1d with NCL→NLC permutation
- `MixedW8A32GruPattern` — weight-only quantized GRU with 4 dequantized params

Differential Revision: D105728177
Summary:

Both  and Cadence now use the shared `QuantFusionPass` from `compiler_funcs.py`.

- `QuantFusionPass` in `compiler_funcs.py` iterates patterns, matches `anchor_ops()`, calls `fuse()` on each match, with debug logging and dead code elimination
- Cadence: `compiler.py` now uses `QuantFusionPass` instead of the old `QuantFusion` isinstance switch
- Removed Cadence `compiler` target's dep on `:fusion_pass` (no longer imported)

Differential Revision: D105728219
@meta-codesync meta-codesync Bot changed the title Enable QuantFusionPass in compiler pipeline Enable QuantFusionPass in compiler pipeline (#19728) May 23, 2026
@ethansfng ethansfng force-pushed the export-D105728219 branch from 6e7ff7c to 181c7bd Compare May 23, 2026 04:00
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

CLA Signed This label is managed by the Facebook bot. Authors need to sign the CLA before a PR can be reviewed. fb-exported meta-exported

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant