by Taesung Park, Alexei A. Efros, Richard Zhang, Jun-Yan Zhu
In image-to-image translation, each patch in the output should reflect the content of the corresponding patch in the input, independent of domain. We propose a straightforward method for doing so – maximizing mutual information between the two, using a framework based on contrastive learning. The method encourages two elements (corresponding patches) to map to a similar point in a learned feature space, relative to other elements (other patches) in the dataset, referred to as negatives. We explore several critical design choices for making contrastive learning effective in the image synthesis setting. Notably, we use a multilayer, patch-based approach, rather than operate on entire images. Furthermore, we draw negatives from within the input image itself, rather than from the rest of the dataset. We demonstrate that our framework enables one-sided translation in the unpaired image-to-image translation setting, while improving quality and reducing training time. In addition, our method can even be extended to the training setting where each “domain” is only a single image.
@misc{park2020contrastive,
title={Contrastive Learning for Unpaired Image-to-Image Translation},
author={Taesung Park and Alexei A. Efros and Richard Zhang and Jun-Yan Zhu},
year={2020},
eprint={2007.15651},
archivePrefix={arXiv},
primaryClass={cs.CV}
}
bash ./datasets/download_cyclegan_dataset.sh horse2zebra
python train.py
To see more intermediate results, check out ./saved_images_CUT/train/
.
python test.py
The test results will be saved here: ./saved_images_CUT/test/
.
Or apply a pre-trained model: Pretrained weights.
Extract the zip file and put the .pth
files in here: ./saved_images_CUT/train/
. Make sure you put LOAD_MODEL=True in the config.py file.
Input | FastCUT | CUT |
---|---|---|
Code is inspired by taesungp.