This repository contains the code to generate the dataset and the perceptual measure from our paper:
A Deep Perceptual Measure for Lens and Camera Calibration
Yannick Hold-Geoffroy¹ , Dominique Piché-Meunier³ , Kalyan Sunkavalli¹ , Jean-Charles Bazin², François Rameau², and Jean-François Lalonde³
Adobe¹ , KAIST² , Université Laval²
To generate crops with randomly sampled camera parameters, run:
python main.py --pano_dir=<PANOS_ROOT> --output_dir=<OUTPUT_DIR>
In our paper, we use the purchasable panorama dataset 360Cities to generate crops. If you have access to the panoramas, you can generate our dataset by downloading the crops metadata and running
python main.py --pano_dir=<360CITIES_ROOT> --output_dir=<OUTPUT_DIR> --metadata_dir=360cities_metadata
Otherwise, we provide an open source version of the dataset based on PolyHaven. The dataset can be downloaded here. To regenerate the crops from the (tonemapped) panoramas, download the crops metadata and run:
python main.py --pano_dir=<POLYHAVEN_ROOT> --output_dir=<OUTPUT_DIR> --metadata_dir=polyhaven_metadata
Here are some samples from the PolyHaven dataset.
Random camera parameters are sampled with the following distributions:
In our paper, we conduct a large-scale study where we ask participants to judge the realism of 3D objects composited with correct and biased camera calibration parameters. From the results of this study, we define a perceptual measure that quantifies how sensitive humans are to errors in camera parameters. The perceptual measure goes from 50% (low sensitivity, humans do not notice the error) to 100% (high sensitivity, the error is easily noticeable).
from perceptual_measure import pitch_perceptual_measure, roll_perceptual_measure, hfov_perceptual_measure, distortion_perceptual_measure
For example, on an image with a ground truth roll of 15° and an estimated roll of 10° (error of 15-10=5°), the perceptual measure would be
roll_perceptual_measure(value=15, error=5)
> 62.34
On the same image, for increasing roll errors, we get:
roll_perceptual_measure([15, 15, 15, 15, 15, 15], [0, 5, 10, 15, 20, 25])
> [50.0, 62.34, 74.68, 87.15, 99.19, nan]
nan means that the parameter value or error is outside of the ranges used in our study.