CoMPaSS
[ICCV 2025] Enhancing spatial understanding in text-to-Image diffusion models
**CoMPaSS** is a [ICCV 2025] Enhancing spatial understanding in text-to-Image diffusion models The project is written primarily in Python, distributed under the Apache License 2.0 license, first published in 2024. Key topics include: diffusion, generation, spatial-understanding, t2i, text-to-image.
CoMPaSS: Enhancing Spatial Understanding in Text-to-Image Diffusion Models
[Project Page]
[arXiv]
[ComfyUI node]
Gaoyang Zhang, Bingtao Fu, Qingnan Fan, Qi Zhang, Runxing Liu, Hong Gu, Huaqi Zhang, Xinguo Liu
ICCV 2025
TL; DR
CoMPaSS enhances the spatial understanding of existing text-to-image diffusion models, enabling
them to generate images that faithfully reflect spatial configurations specified in the
text prompt.

Setting up Environment
We manage our python environment with uv, and provide a convenient script for setting
up the environment at setup_env.sh.
Running this script will create a subdirectory .venv/ in the project root. To enable
it, run source .venv/bin/activate after the environment is set up:
bash# install requirements into .venv/ bash ./setup_env.sh # activate the environment source .venv/bin/activate
Trying out CoMPaSS
[!NOTE]
For training, SCOP and TENOR are both required.
For generating images from text, only TENOR and the reference weights are needed.
ComfyUI
We recommend trying out the FLUX.1-dev LoRA trained via CoMPaSS. Please refer to the
custom node's repository to get started.
Reference Weights
We provide the reference weights used to report all metrics in our paper on Hugging
Face 🤗.
We recommend trying out the FLUX.1-dev weights as it is a Rank-16 LoRA which is only
50MB in size.
The SCOP dataset
We provide full instructions for replicating the SCOP dataset (28,028 object pairs among
15,426 images) in the SCOP directory. Check out its README
to get started.
The TENOR Module
We provide both training and inference instructions for using our TENOR module in the
TENOR directory.
MMDiT-based models (e.g., FLUX.1-dev) and UNet-based models (e.g., SD1.5) are both
supported. Check out their respective instructions to get started:
Citation
<!-- vim: set ts=2 sts=2 sw=2 et: -->bibtex@inproceedings{zhang2025compass, title={CoMPaSS: Enhancing Spatial Understanding in Text-to-Image Diffusion Models}, author={Zhang, Gaoyang and Fu, Bingtao and Fan, Qingnan and Zhang, Qi and Liu, Runxing and Gu, Hong and Zhang, Huaqi and Liu, Xinguo}, booktitle={ICCV}, year={2025} }
Contributors
Showing top 1 contributor by commit count.