Home

Awesome

Self-supervised Augmentation Consistency <br/> for Adapting Semantic Segmentation

License Framework

This repository contains the official implementation of our paper:

Self-supervised Augmentation Consistency for Adapting Semantic Segmentation<br> Nikita Araslanov and Stefan Roth<br> CVPR 2021. [pdf] [supp] [arXiv]

<img src="assets/stuttgart.gif" alt="drawing" width="420"/><br>
<p align="left">We obtain state-of-the-art accuracy of adapting semantic <br> segmentation by enforcing consistency across photometric <br> and similarity transformations. We use neither style transfer <br> nor adversarial training.</p>

Contact: Nikita Araslanov fname.lname (at) visinf.tu-darmstadt.de


Installation

Requirements. To reproduce our results, we recommend Python >=3.6, PyTorch >=1.4, CUDA >=10.0. At least two Titan X GPUs (12Gb) or equivalent are required for VGG-16; ResNet-101 and VGG-16/FCN need four.

  1. create conda environment:
conda create --name da-sac
source activate da-sac
  1. install PyTorch >=1.4 (see PyTorch instructions). For example,
conda install pytorch torchvision torchaudio cudatoolkit=10.2 -c pytorch
  1. install the dependencies:
pip install -r requirements.txt
  1. download data (Cityscapes, GTA5, SYNTHIA) and create symlinks in the ./data folder, as follows:
./data/cityscapes -> <symlink to Cityscapes>
./data/cityscapes/gtFine2/
./data/cityscapes/leftImg8bit/

./data/game -> <symlink to GTA>
./data/game/labels_cs
./data/game/images

./data/synthia  -> <symlink to SYNTHIA>
./data/synthia/labels_cs
./data/synthia/RGB

Note that all ground-truth label IDs (Cityscapes, GTA5 and SYNTHIA) should be converted to Cityscapes train IDs. The label directories in the above example (gtFine2, labels_cs) therefore refer not to the original labels, but to these converted semantic maps.

Training

Training from ImageNet initialisation proceeds in three steps:

  1. Training the baseline (ABN)
  2. Generating the weights for importance sampling
  3. Training with augmentation consistency from the ABN baseline

1. Training the baseline (ABN)

Here the input are ImageNet models available from the official PyTorch repository. We provide the links to those models for convenience.

BackboneLink
ResNet-101resnet101-5d3b4d8f.pth (171M)
VGG-16vgg16_bn-6c64b313.pth (528M)

By default, these models should be placed in ./models/pretrained/ (though configurable with MODEL.INIT_MODEL).

To run the training

bash ./launch/train.sh [gta|synthia] [resnet101|vgg16|vgg16fcn] base

where the first argument specifies the source domain, the second determines the network architecture. The third argument base instructs to run the training of the baseline.

If you would like to skip this step, you can use our pre-trained models:

Source domain: GTA5

BackboneArch.IoU (val)LinkMD5
ResNet-101DeepLabv240.8baseline_abn_e040.pth (336M)9fe17[...]c11fc
VGG-16DeepLabv237.1baseline_abn_e115.pth (226M)d4ffc[...]ef755
VGG-16FCN36.7baseline_abn_e040.pth (1.1G)aa2e9[...]bae53

Source domain: SYNTHIA

BackboneArch.IoU (val)LinkMD5
ResNet-101DeepLabv236.3baseline_abn_e090.pth (336M)b3431[...]d1a83
VGG-16DeepLabv234.4baseline_abn_e070.pth (226M)3af24[...]5b24e
VGG-16FCN31.6baseline_abn_e040.pth (1.1G)5f457[...]e4b3a

Tip: You can download these files (as well as the final models below) with tools/download_baselines.sh:

cp tools/download_baselines.sh snapshots/cityscapes/baselines/
cd snapshots/cityscapes/baselines/
bash ./download_baselines.sh

2. Generating weights for importance sampling

To generate the weights you need to

  1. generate mask predictions with your baseline (see inference below);
  2. run tools/compute_image_weights.py that reads in those predictions and counts the predictions per each class.

If you would like to skip this step, you can use our weights we computed for the ABN baselines above:

BackboneArch.Source: GTA5Source: SYNTHIA
ResNet-101DeepLabv2cs_weights_resnet101_gta.datacs_weights_resnet101_synthia.data
VGG-16DeepLabv2cs_weights_vgg16_gta.datacs_weights_vgg16_synthia.data
VGG-16FCNcs_weights_vgg16fcn_gta.datacs_weights_vgg16fcn_synthia.data

Tip: The bash script data/download_weights.sh will download all these importance sampling weights in the current directory.

3. Training with augmentation consistency

To train the model with augmentation consistency, we use the same shell script as in step 1, but without the argument base:

bash ./launch/train.sh [gta|synthia] [resnet101|vgg16|vgg16fcn]

Make sure to specify your baseline snapshot with RESUME bash variable set in the environment (export RESUME=...) or directly in the shell script (commented out by default).

We provide our final models for download.

Source domain: GTA5

BackboneArch.IoU (val)IoU (test)LinkMD5
ResNet-101DeepLabv253.855.7final_e136.pth (504M)59c16[...]5a32f
VGG-16DeepLabv249.851.0final_e184.pth (339M)0accb[...]d5881
VGG-16FCN49.950.4final_e112.pth (1.6G)e69f8[...]f729b

Source domain: SYNTHIA

BackboneArch.IoU (val)IoU (test)LinkMD5
ResNet-101DeepLabv252.652.7final_e164.pth (504M)a7682[...]db742
VGG-16DeepLabv249.148.3final_e164.pth (339M)c5b31[...]5fdb7
VGG-16FCN46.845.8final_e098.pth (1.6G)efb74[...]845cc

Inference and evaluation

Inference

To run single-scale inference from your snapshot, use infer_val.py. The bash script launch/infer_val.sh provides an easy way to run the inference by specifying a few variables:

# validation/training set
FILELIST=[val_cityscapes|train_cityscapes] 
# configuration used for training
CONFIG=configs/[deeplabv2_vgg16|deeplab_resnet101|fcn_vgg16]_train.yaml
# the following 3 variables effectively specify the path to the snapshot
EXP=...
RUN_ID=...
SNAPSHOT=...
# the snapshot path is defined as
# SNAPSHOT_PATH=snapshots/cityscapes/${EXP}/${RUN_ID}/${SNAPSHOT}.pth

Evaluation

Please use the Cityscapes' official evaluation tool evalPixelLevelSemanticLabeling from Cityscapes scripts for evaluating your results.

Citation

We hope you find our work useful. If you would like to acknowledge it in your project, please use the following citation:

@inproceedings{Araslanov:2021:DASAC,
    author    = {Araslanov, Nikita and Roth, Stefan},
    title     = {Self-Supervised Augmentation Consistency for Adapting Semantic Segmentation},
    booktitle = {Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR)},
    month     = {June},
    year      = {2021},
    pages     = {15384-15394}
}