Skip to content

Latest commit

 

History

History
34 lines (28 loc) · 2.6 KB

README.md

File metadata and controls

34 lines (28 loc) · 2.6 KB

Learning a Deep Color Difference Metric for Photographic Images

Introduction

This repository contains the official pytorch implementation of the paper "Learning a Deep Color Difference Metric for Photographic Images" by Haoyu Chen, Zhihua Wang, Yang Yang, Qilin Sun, and Kede Ma, IEEE Conference on Computer Vision and Pattern Recognition, 2023.

Most well-established and widely used color difference (CD) metrics are handcrafted and subject-calibrated against uniformly colored patches, which do not generalize well to photographic images characterized by natural scene complexities. Constructing CD formulae for photographic images is still an active research topic in imaging/illumination, vision science, and color science communities. In this paper, we aim to learn a deep CD metric for photographic images with four desirable properties. First, it well aligns with the observations in vision science that color and form are linked inextricably invisual cortical processing. Second, it is a proper metric in the mathematical sense. Third, it computes accurate CDs between photographic images, differing mainly in color appearances. Fourth, it is robust to mild geometric distortions (e.g.,translation or due to parallax), which are often present in photographic images of the same scene captured by different digital cameras. We show that all these properties can be satisfied simultaneously by learning a multi-scale autoregressive normalizing flow for feature transform, followed by the Euclidean distance which is linearly proportional to the human perceptual CD.

Prerequisites

  • python 3.10

  • pytorch 1.12.0

  • pip install -r requirements.txt

Training

To train the CD-Flow from scratch, execute the following command:

python main.py --training_datadir path/to/the/dataset --work_path work_dir --datapath data --batch_size_train 4

For the SPCD dataset, you can download via Baidu Netdisk or Google Drive.

Evaluation

To evaluate the STRESS, PLCC and SRCC of your checkpoints on test set, execute:

python test.py --datadir path/to/the/dataset --work_path work_dir --datapath data --batch_size_test 4

Citation

@inproceedings{chen2023learning,
title={Learning a Deep Color Difference Metric for Photographic Images},
author={Haoyu Chen, Zhihua Wang, Yang Yang, Qilin Sun, and Kede Ma},
booktitle={Conference on Computer Vision and Pattern Recognition 2023},
year={2023}
}