Demonstration code and dataset for the paper titled "Color alignment for relative color constancy via non-standard references". For further exploration, please cite our paper:
@article{9923595,
author={Zhao, Yunfeng and Ferguson, Stuart and Zhou, Huiyu and Elliott, Christopher and Rafferty, Karen},
journal={IEEE Transactions on Image Processing},
title={Color Alignment for Relative Color Constancy via Non-Standard References},
year={2022},
volume={31},
number={},
pages={6591-6604},
doi={10.1109/TIP.2022.3214107}
}
IEEE Xplore link: https://ieeexplore.ieee.org/document/9923595
Arxiv link: https://arxiv.org/abs/2112.15106
-
The concept of relative colour constancy (RCC): the ability to perceive colours of objects, invariant to the colour of light source and camera.
-
A three-step process for performing colour alignment and achieving RCC: camera response calibration, response linearisation, and colour matching.
-
A balance-of-linear-distances (BoLD) feature for camera response calibration that works with non-standard references, e.g., colour charts without true colour values.
-
A new image dataset that contains images taken by different cameras under varied illuminations. (To be released).
- Tensorflow 1.14.0 (for the Optimisation approach)
- opencv-python 4.4.0
We demonstrate how to perform the camera response calibration, response linearisation, and colour matching steps of the proposed colour alignment reported in the paper using an example image dataset.
For performing the Selection approach of the camera response calibration on the dataset, run:
python camera_response_calibration_selection.py --img_path './datasets/modified_Middlebury_calibration/' --tag_path './datasets/modified_Middlebury_calibration/tags.json' --crf_save_path './results/crfs/' --vis 1
img_path
: path to the calibration image dataset.tag_path
: path to the label json file.crf_save_path
: where the generated CRFs will be stored.vis
: whether to visualise the generated CRF.1
indicates to visualise while0
otherwise.
The generated camera response functions (CRFs) will be saved in the destination folder indicated by crf_save_path
.
Next, run the following script to perform response linearisation of the images in the dataset:
python response_linearisation.py --img_path './datasets/modified_Middlebury_test/' --crf_save_path './results/crfs/' --output_path './results/images/'
img_path
is the path to the test image dataset.output_path
indicates where the linearised images will be stored.
Response linearised output images will be stored in the destination folder indicated by output_path
.
Eventually, the response linearised images will be colour matched to each other by executing the following script:
python colour_matching_and_benchmark.py --img_path './results/images/' --tag_path './datasets/modified_Middlebury_test/tags.json' --items '19,14' --intensity True --chromaticity True
- dataset/
- dorf/
| dorfCurves.txt # Database of Response Functions
| invemor.txt # Inverse Empirical Model of Responses
- modified_Middlebury_calibration/ # for camera calibration
- CanonEOS1DsMarkII/
...
- CanonPowerShotG9/
...
...
| tags.json # label information
- modified_Middlebury_test/ # for benchmark
- CanonEOS1DsMarkII/
...
- CanonPowerShotG9/
...
...
| tags.json # label information
- libs/ # supporting libraries
...
- results/
- crfs # storing calibrated crfs
- images # storing response linearised images
| camera_response_calibration_selection.py # camera response calibration script using the Selection approach
| camera_response_calibration_optimisation.py # camera response calibration script using the Optimisation approach for comparison
| response_linearisation.py # script for image response linearisation
| colour_matching_and_benchmark.py # image colour matching for relative colour constancy evaluation
The dataset
folder contains the image dataset for camera calibration and demonstration for RCC performance evaluation.
A list of the cameras selected in the modified Middlebury dataset:
- Canon EOS-1Ds Mark II
- Canon PowerShot G9
- Canon PowerShot G10
- Canon PowerShot S50
- Canon PowerShot S60
- Casio EX-Z55
- Nikon D70
- Nikon D200
- Olympus E10
- Olympus E500
- Panasonic DMC-LX3
- Pentax K10D
- Sony DSLR-A100
- Sony DSLR-A300
tags.json
file provides label information that indicates regions of colour patches in the images.
Here, indexes of colour patches used in this demo and those reported in the paper are explained for index-mapping.
Indexes of colour patches in this demo:
Indexes of colour patches reported in the paper: