# DUPS-Pretrain

This software project accompanies the research paper, *DUPS: Dynamic upsampling for efficient semantic segmentation*.


## Introduction

We present **DUPS**, a coarse-to-fine vision transformer for semantic segmentation. 
Unlike models that begin with dense high-resolution tokens, 
DUPS starts at low resolution and dynamically upsamples only regions predicted to contain semantic boundaries, 
following a “one-token-one-class” principle. Mixed-resolution attention enables interaction between coarse and fine tokens, 
allocating computation to semantically complex areas while avoiding redundant processing in homogeneous regions.  
Experiments on ADE20K, COCO-Stuff, and Cityscapes demonstrate that DUPS achieves state-of-the-art results on ADE20K and 
COCO-Stuff with substantially fewer FLOPs, 
and delivers competitive accuracy on Cityscapes at markedly lower compute. 
For example, DUPS-Base attains **54.6 mIoU** on ADE20K in the ~110M-parameter class while using fewer FLOPs 
than comparable backbones.

## Getting Started

### Create environment and install requirements

```bash
sh create_env.sh
```

See further documentation inside the script file.

Our experiments are run with `CUDA==11.6` and `pytorch==1.12`.

### Prepare data

We use standard ImageNet dataset, which can be downloaded from http://image-net.org/.

For standard folder dataset, move validation images to labeled sub-folders. The file structure should look like:
```bash
$ tree imagenet
imagenet/
├── training
│   ├── class1
│   │   ├── img1.jpeg
│   │   ├── img2.jpeg
│   │   └── ...
│   ├── class2
│   │   ├── img3.jpeg
│   │   └── ...
│   └── ...
└── validation
    ├── class1
    │   ├── img4.jpeg
    │   ├── img5.jpeg
    │   └── ...
    ├── class2
    │   ├── img6.jpeg
    │   └── ...
    └── ...

```

### Train and evaluate

Modify the arguments in script `run_dups.sh` (e.g., path to dataset) and run
```bash
sh run_dups.sh
```
for training or evaluation.

Run `python main.py -h` to see full documentation of the args.

One can also directly modify the config files in `configs/`.