README.md

February 16, 2026 ยท View on GitHub

Autoregressive Image Generation with Randomized Parallel Decoding

Haopeng Li1, Jinyue Yang2, Guoqi Li2,๐Ÿ“ง, Huan Wang1,๐Ÿ“ง

1 Westlake University, 2 Institute of Automation, Chinese Academy of Sciences

arXiv Project HuggingFace

๐Ÿ”ฅ News

  • 2026-01-26: Our paper has been accepted by ICLR 2026. ๐ŸŽ‰๐ŸŽ‰๐ŸŽ‰
  • 2025-03-27: Add HuggingFace integration to ARPG.
  • 2025-03-25: Add the sampling arccos schedule.
  • 2025-03-14: The paper and code are released!

๐Ÿ“– Introduction

We introduce a novel autoregressive image generation framework named ARPG. This framework is capable of conducting BERT-style masked modeling by employing a GPT-style causal architecture. Consequently, it is able to generate images in parallel following a random token order and also provides support for the KV cache.

  • ๐Ÿ’ช ARPG achieves an FID of 1.94
  • ๐Ÿš€ ARPG delivers throughput 26 times faster than LlamaGenโ€”nearly matching VAR
  • โ™ป๏ธ ARPG reducing memory consumption by over 75% compared to VAR.
  • ๐Ÿ” ARPG supports zero-shot inference (e.g., inpainting and outpainting).
  • ๐Ÿ› ๏ธ ARPG can be easily extended to controllable generation.

๐Ÿค— Model Zoo

We provide the model weights pre-trained on ImageNet-1K 256*256.

ModelParamScheduleCFGStepFIDISWeight
ARPG-L320 Mcosine4.5642.44292arpg_300m.pt
ARPG-XL719 Mcosine6.0642.10331arpg_700m.pt
ARPG-XXL1.3 Bcosine7.5641.94340arpg_1b.pt

๐ŸŽฎ Quick Start

You can easily play ARPG using the HuggingFace DiffusionPipeline.

from diffusers import DiffusionPipeline

pipeline = DiffusionPipeline.from_pretrained("hp-l33/ARPG", custom_pipeline="hp-l33/ARPG")

class_labels = [207, 360, 388, 113, 355, 980, 323, 979]

generated_image = pipeline(
    model_type="ARPG-XL",       # choose from 'ARPG-L', 'ARPG-XL', or 'ARPG-XXL'
    seed=0,                     # set a seed for reproducibility
    num_steps=64,               # number of autoregressive steps
    class_labels=class_labels,  # provide valid ImageNet class labels
    cfg_scale=4,                # classifier-free guidance scale
    output_dir="./images",      # directory to save generated images
    cfg_schedule="constant",    # choose between 'constant' (suggested) and 'linear'
    sample_schedule="arccos",   # choose between 'arccos' (suggested) and 'cosine'
)

generated_image.show()

If you want to train or reproduce the results of ARPG, please refer to Getting Started.

๐Ÿ”— Bibtex

If this work is helpful for your research, please give it a star or cite it:

@inproceedings{li2026autoregressive,
    title={Autoregressive Image Generation with Randomized Parallel Decoding},
    author={Haopeng Li and Jinyue Yang and Guoqi Li and Huan Wang},
    booktitle={The Fourteenth International Conference on Learning Representations},
    year={2026}
}

๐Ÿค Acknowledgement

Thanks to LlamaGen for its open-source codebase. Appreciate RandAR and RAR for inspiring this work, and also thank ControlAR.