| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 | :article_outdated: True.. _doc_high_dynamic_range:High dynamic range lighting===========================Introduction------------Normally, an artist does all the 3D modeling, then all the texturing, looks attheir awesome looking model in the 3D modeling software and says "looksfantastic, ready for integration!" then goes into the game, lighting is setupand the game runs.So at what point does all this "HDR" business come into play? To understandthe answer, we need to look at how displays behave.Your display outputs linear light ratios from some maximum to some minimumintensity. Modern game engines perform complex math on linear light values intheir respective scenes. So what's the problem?The display has a limited range of intensity, depending on the display type.The game engine renders to an unlimited range of intensity values, however.While "maximum intensity" means something to an sRGB display, it has no bearingin the game engine; there is only a potentially infinitely wide rangeof intensity values generated per frame of rendering.This means that some transformation of the scene light intensity, also knownas *scene-referred* light ratios, need to be transformed and mapped to fitwithin the particular output range of the chosen display. This can be mosteasily understood if we consider virtually photographing our game engine scenethrough a virtual camera. Here, our virtual camera would apply a particularcamera rendering transform to the scene data, and the output would be readyfor display on a particular display type... note::    Godot does not support high dynamic range *output* yet. It can only perform    lighting in HDR and tonemap the result to a low dynamic range image.    For advanced users, it is still possible to get a non-tonemapped image    of the viewport with full HDR data, which can then be saved to an OpenEXR file.Computer displays-----------------Almost all displays require a nonlinear encoding for the code values sentto them. The display in turn, using its unique transfer characteristic,"decodes" the code value into linear light ratios of output, and projectsthe ratios out of the uniquely colored lights at each reddish, greenish,and blueish emission site.For a majority of computer displays, the specifications of the display areoutlined in accordance with IEC 61966-2-1, also known as the1996 sRGB specification. This specification outlines how an sRGB displayis to behave, including the color of the lights in the LED pixels as well asthe transfer characteristics of the input (OETF) and output (EOTF).Not all displays use the same OETF and EOTF as a computer display.For example, television broadcast displays use the BT.1886 EOTF.However, Godot currently only supports sRGB displays.The sRGB standard is based around the nonlinear relationship between the currentto light output of common desktop computing CRT displays... image:: img/hdr_gamma.pngThe mathematics of a scene-referred model require that we multiply the scene bydifferent values to adjust the intensities and exposure to differentlight ranges. The transfer function of the display can't appropriately renderthe wider dynamic range of the game engine's scene output using the simpletransfer function of the display. A more complex approach to encodingis required.Scene linear & asset pipelines------------------------------Working in scene-linear sRGB is more complex than pressing a single switch. First,imported image assets must be converted to linear light ratios on import. Evenwhen linearized, those assets may not be perfectly well-suited for useas textures, depending on how they were generated.There are two ways to do this:sRGB transfer function to display linear ratios on image import~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~This is the easiest method of using sRGB assets, but it's not the most ideal.One issue with this is loss of quality. Using 8 bits per channel to representlinear light ratios is not sufficient to quantize the values correctly.These textures may also be compressed later, which can exacerbate the problem.Hardware sRGB transfer function to display linear conversion~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~The GPU will do the conversion after reading the texel using floating-point.This works fine on PC and consoles, but most mobile devices don't support it,or they don't support it on compressed texture formats (iOS for example).Scene linear to display-referred nonlinear~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~After all the rendering is done, the scene linear render requires transformingto a suitable output such as an sRGB display. To do this, enable sRGB conversionin the current :ref:`Environment <class_Environment>` (more on that below).Keep in mind that the **sRGB -> Display Linear** and **Display Linear -> sRGB**conversions must always be **both** enabled. Failing to enable one of them willresult in horrible visuals suitable only for avant-garde experimentalindie games.Parameters of HDR-----------------HDR settings can be found in the :ref:`Environment <class_Environment>`resource. Most of the time, these are found inside a:ref:`WorldEnvironment <class_WorldEnvironment>`node or set in a Camera node. For more information, see:ref:`doc_environment_and_post_processing`.
 |