Skip to content

[core] refactor attention_processor.py the easy way #10022

Open
@sayakpaul

Description

@sayakpaul

With @DN6 we have been discussing an idea about breaking up src/diffusers/models/attention_processor.py as it's getting excruciatingly longer and longer. The idea is simple and won't very likely require multiple rounds of PRs.

  • Create a module named attention_processor.
  • Split the attention processor classes with respect to the model names they are used. This makes sense because pretty much most of the models (at least the widely used ones) have their own attention processors at this point. For example, FluxAttnProcessor2_0, FluxAttnProcessor2_0_NPU, FusedFluxAttnProcessor2_0 could go to attention_processor/flux_attention_processors.py.
  • Other attention processors (such as AttnProcessor, AttnProcessor2_0, etc.) which are shared across different models could live in a common file i.e., attention_processor/common.py.

Since attention_prcoessor/ will have an init, I don't think there will be any breaking changes.

Metadata

Metadata

Assignees

Type

No type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions