.. | ||
pq_to_hlg.cc | ||
README.md | ||
render_hlg.cc | ||
tone_map.cc |
HDR tools
This directory contains a small set of command-line tools for HDR conversions, including to SDR.
Tone mapping
tools/tone_map
implements tone mapping as described in annex 5 of
Report ITU-R BT.2408-4, more
specifically the YRGB variant. Since the result may contain out-of-gamut colors,
it additionally does very basic gamut mapping, maintaining hue and luminance at
the expense of saturation (so bright colorful highlights may be brought closer
to white).
Examples
# Tone maps a PQ image for a 300 cd/m² display, and writes the result as an SDR
# (but still wide-gamut) image to be shown on such a display.
$ tools/tone_map -t 300 ClassE_507.png ClassE_507_tone_mapped_300.png
# The result can also be written as a PQ image itself:
$ tools/tone_map -t 300 --pq ClassE_507.png ClassE_507_tone_mapped_300_pq.png
# It is possible to specify the maximum luminance found in the image using
# `--max_nits`. For OpenEXR input, it will override the `whiteLuminance` tag
# which indicates the luminance of (1, 1, 1). For PQ, it will not affect the
# luminance calculated from the signal, but it will tell the tone mapping how
# much headroom to leave for highlights. Leaving more headroom than necessary
# can help with the problem of desaturated highlights mentioned above.
$ tools/tone_map -m 4000 -t 300 ClassE_507.png ClassE_507_tone_mapped_300.png
PQ to HLG conversion
tools/pq_to_hlg
performs conversion of a PQ image to HLG as described in
section 6 of the aforementioned BT.2408-4. That is, the PQ image is first
limited to 1000 cd/m² using the tone mapping mentioned above, and the result is
treated as if it were the output of a reference 1000 cd/m² HLG display: such a
display would have a system gamma of 1.2, and therefore, we can apply the
HLG inverse OOTF with a gamma of 1.2 to get “back” to the linear scene-referred
signal that would have produced that output on that reference display (and then
encode it using the OETF).
As with the tone mapping tool, the --max_nits
option can be used to guide the
1000 cd/m² limiting.
Example
$ tools/pq_to_hlg ClassE_507.png ClassE_507_hlg.png
HLG rendering
HLG is designed to look acceptable without specific processing on displays that expect a “traditional” SDR signal. Nevertheless, it is possible to optimize the appearance for specific viewing conditions by applying the HLG inverse OETF and then the OOTF with an appropriate system gamma. Here, the system gamma is computed using the extended model mentioned at the bottom of page 29 of Report ITU-R BT.2390-9. That formula should work well over a wide range of display peak luminances.
It is possible to specify not just the peak luminance of the target display
(using --target_nits
) but also the ambient luminance of the viewing
environment using --surround_nits
.
As with the tone mapping tool, the result can be written as a PQ image. In that
case, it would make sense, in further usage of tools/tone_map
or
tools/pq_to_hlg
, to set --max_nits
to the value that was passed as
--target_nits
to this tool. This also applies to the tone mapping tool.
Examples
# Renders an HLG image for a 300 cd/m² display in a 10 cd/m² room.
$ tools/render_hlg -t 300 -s 10 ClassE_507_hlg.png ClassE_507_hlg_300.png
# Renders it for a reference 1000 cd/m² display and writes the result as a PQ
# image.
$ tools/render_hlg -t 1000 --pq ClassE_507_hlg.png ClassE_507_hlg_pq.png
# Informing pq_to_hlg about that maximum luminance then ensures proper
# roundtripping as it will not needlessly tone map the highlights.
$ tools/pq_to_hlg -m 1000 ClassE_507_hlg_pq.png ClassE_507_hlg_pq_hlg.png