Unconditional Image Generation
Diffusers
Safetensors
English
image-generation
class-conditional
dit-moe
Instructions to use BiliSakura/DiT-MoE-diffusers with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- Diffusers
How to use BiliSakura/DiT-MoE-diffusers with Diffusers:
pip install -U diffusers transformers accelerate
import torch from diffusers import DiffusionPipeline # switch to "mps" for apple devices pipe = DiffusionPipeline.from_pretrained("BiliSakura/DiT-MoE-diffusers", dtype=torch.bfloat16, device_map="cuda") prompt = "Astronaut in a jungle, cold color palette, muted colors, detailed, 8k" image = pipe(prompt).images[0] - Notebooks
- Google Colab
- Kaggle
Fix generator determinism: forward generator through scheduler steps and seeded noise
343b8d8 verified metadata
license: apache-2.0
language:
- en
library_name: diffusers
tags:
- diffusers
- image-generation
- class-conditional
- dit-moe
pipeline_tag: unconditional-image-generation
DiT-MoE-diffusers
Diffusers implementation of DiT-MoE (Diffusion Transformer with Mixture of Experts) for class-conditional ImageNet generation. Each variant folder is self-contained:
pipeline.pyβDiTMoEPipelinescheduler/scheduler_config.jsonβDDIMScheduler(S/B) orDiTMoEFlowMatchScheduler(XL/G)transformer/transformer_dit_moe.pyβDiTMoETransformer2DModelvae/βAutoencoderKL(stabilityai/sd-vae-ft-mse)
ImageNet class labels
Each variant keeps an English id2label map directly in its own model_index.json (DiT-style).
pipe.id2labelβ inspect id β English label correspondencepipe.labelsβ reverse map (English synonym β id), sorted for browsingpipe.get_label_ids("golden retriever")pipe(class_labels="golden retriever", ...)β string labels resolved automatically
Available checkpoints
| Checkpoint | Path | Resolution | Sampler |
|---|---|---|---|
| DiT-MoE-S/2-8E2A | ./DiT-MoE-S-8E2A |
256Γ256 | DDIM |
| DiT-MoE-B/2-8E2A | ./DiT-MoE-B-8E2A |
256Γ256 | DDIM |
| DiT-MoE-XL/2-8E2A | ./DiT-MoE-XL-8E2A |
256Γ256 | RF |
| DiT-MoE-G/2-16E2A | (convert with --rectified-flow --num-experts 16) |
256Γ256 | RF |
Convert from official weights
conda activate rsgen
cd libs/DiT-MoE-diffusers
python scripts/convert_dit_moe_to_diffusers.py \
--checkpoint ../../models/feizhengcong/DiT-MoE/dit_moe_s_8E2A.pt \
--output ../../models/BiliSakura/DiT-MoE-diffusers/DiT-MoE-S-8E2A \
--model DiT-S/2 \
--num-experts 8 \
--num-experts-per-tok 2 \
--copy-vae ../../models/feizhengcong/DiT-MoE/sd-vae-ft-mse \
--check-load
Inference
Use torch.bfloat16 on Ampere+ GPUs (default in examples and sample_dit_moe.py).
from pathlib import Path
import torch
from diffusers import DiffusionPipeline
model_dir = Path("./DiT-MoE-S-8E2A").resolve()
pipe = DiffusionPipeline.from_pretrained(
str(model_dir),
local_files_only=True,
custom_pipeline=str(model_dir / "pipeline.py"),
trust_remote_code=True,
torch_dtype=torch.bfloat16,
)
pipe.to("cuda")
print(pipe.id2label[207])
print(pipe.get_label_ids("golden retriever"))
generator = torch.Generator(device="cuda").manual_seed(42)
image = pipe(
class_labels="golden retriever",
height=256,
width=256,
num_inference_steps=50,
guidance_scale=4.0,
generator=generator,
).images[0]
image.save("demo.png")
Citation
@article{FeiDiTMoE2024,
title={Scaling Diffusion Transformers to 16 Billion Parameters},
author={Zhengcong Fei and Mingyuan Fan and Changqian Yu and Debang Li and Jusnshi Huang},
year={2024},
journal={arXiv preprint arXiv:2407.11633},
}