Enhancing Photorealism Enhancement

Abstract

We present an approach to enhancing the realism of synthetic images. The images are enhanced by a convolutional network that leverages intermediate representations produced by conventional rendering pipelines. The network is trained via a novel adversarial objective, which provides strong supervision at multiple perceptual levels. We analyze scene layout distributions in commonly used datasets and find that they differ in important ways. We hypothesize that this is one of the causes of strong artifacts that can be observed in the results of many prior methods. To address this we propose a new strategy for sampling image patches during training. We also introduce multiple architectural improvements in the deep network modules used for photorealism enhancement. We confirm the benefits of our contributions in controlled experiments and report substantial gains in stability and realism in comparison to recent image-to-image translation methods and a variety of other baselines.

image

BibTeX

Please cite our work if you use code or data from this site.

@Article{Richter_2021,
                    title = {Enhancing Photorealism Enhancement},
                    author = {Stephan R. Richter and Hassan Abu AlHaija and Vladlen Koltun},
                    journal= {arXiv:2105.04619},
                    year = {2021},
                }

Video (Paper)

Video (Keynote at Eurographics 2021)

Results

The modifications by our method are geometrically and semantically consistent with the original images.

image

They are also temporally stable:

It greens the parched grass and hills in GTA's California:

image

It adds reflections to the windows and increases the fresnel effect (e.g., at the roof of cars):

image

It rebuilds the roads:

image
image
image
image

Images from this dataset are recorded around the world with wide variety of cameras. The images are more vibrant and of high resolution.

image

It removes distant haze and rebuilds the road:

image

Grass becomes more voluminous:

image
image
image
image