SRGB explained

sRGB
Long Name:IEC 61966-2-1 Default RGB Colour Space - sRGB
Native Name Lang:English
Status:Published
Year Started:1996
First Published:[1]
Committee:/: TC 100/TA 2
Base Standards:IEC 61966 Colour Measurement and Management in Multimedia Systems and Equipment
Abbreviation:sRGB
Domain:Color space, color model

sRGB is a standard RGB (red, green, blue) color space that HP and Microsoft created cooperatively in 1996 to use on monitors, printers, and the World Wide Web. It was subsequently standardized by the International Electrotechnical Commission (IEC) as IEC 61966-2-1:1999. sRGB is the current defined standard colorspace for the web, and it is usually the assumed colorspace for images that are neither tagged for a colorspace nor have an embedded color profile.

sRGB essentially codifies the display specifications for the computer monitors in use at that time, which greatly aided its acceptance. sRGB uses the same color primaries and white point as ITU-R BT.709 standard for HDTV,[2] a transfer function (or gamma) compatible with the era's CRT displays, and a viewing environment designed to match typical home and office viewing conditions.

sRGB definition

Gamut

ChromaticityRedGreenBlueWhite point
x0.64000.30000.15000.3127
y0.33000.60000.06000.3290
Y0.21260.71520.07221.0000

sRGB defines the chromaticities of the red, green, and blue primaries, the colors where one of the three channels is nonzero and the other two are zero. The gamut of chromaticities that can be represented in sRGB is the color triangle defined by these primaries, which are set such that the range of colors inside the triangle is well within the range of colors visible to a human with normal trichromatic vision. As with any RGB color space, for non-negative values of R, G, and B it is not possible to represent colors outside this triangle.

The primaries come from HDTV (ITU-R BT.709), which are somewhat different from those for older color TV systems (ITU-R BT.601). These values were chosen to reflect the approximate color of consumer CRT phosphors at the time of its design. Since flat-panel displays at the time were generally designed to emulate CRT characteristics, the values also reflected prevailing practice for other display devices as well.[1]

Transfer function ("gamma")

The reference display characterisation is based on the characterisation in CIE 122. The reference display is characterised by a nominal power-law gamma of 2.2, which the sRGB working group determined was representative of the CRTs used with Windows operating systems at the time. The ability to directly display sRGB images on a CRT without any lookup greatly helped sRGB's adoption. Gamma also usefully encodes more data near the black, which reduces visible noise and quantization artifacts.

The standard also defines a opto-electronic transfer function (OETF), which defines the conversion of linear light or signal intensity to a gamma-compressed image data. It is a piecewise compound function and has an approximate

\gamma

of 2.2, with a linear portion near zero to avoid an infinite slope which emphasizes signal (camera) noise.[3] [4] Near zero, a

\gamma1/2.4

power law curve intercepts a straight-line section that leads to zero.

In practice, there is still debate and confusion around whether sRGB data should be displayed with pure 2.2 gamma as defined in the standard, or with the inverse of the OETF. Some display manufacturers and calibrators use the former, while some use the latter. When a power law

\gamma2.2

is used to display data that was intended to be displayed on displays that use the piecewise function, the result is that the shadow details will be "crushed" towards hard black.[5]

Computing the inverse opto-electronic transfer function

A straight line that passes through is

y=

x
\Phi
, and a gamma curve that passes through is

y=\left(

x+A
1+A

\right)\Gamma

If these are joined at the point then:

X
\Phi

=\left(

X+A
1+A

\right)\Gamma

To avoid a kink where the two segments meet, the derivatives must be equal at this point:

1
\Phi

=\Gamma\left(

X+A
1+A

\right)\Gamma-1\left(

1
1+A

\right)

We now have two equations. If we take the two unknowns to be and then we can solve to give

X=

A
\Gamma-1

,\Phi=

(1+A)\Gamma(\Gamma-1)\Gamma-1
(A\Gamma-1)(\Gamma\Gamma)

The values and were chosen so the curve closely resembled the gamma-2.2 curve. This gives . These values, rounded to sometimes describe sRGB conversion.[6]

Draft publications by sRGB's creators further rounded, resulting in a small discontinuity in the curve. Some authors adopted these incorrect values, in part because the draft paper was freely available and the official IEC standard is behind a paywall.[7] For the standard, the rounded value of was kept and was recomputed as to make the curve continuous, resulting in a slope discontinuity from below the intersection to above.

Viewing environment

ParameterValue
Screen luminance level80 cd/m2
Illuminant white pointx = 0.3127, y = 0.3290 (D65)
Image surround reflectance20% (~medium gray)
Encoding ambient illuminance level64 lux
Encoding ambient white pointx = 0.3457, y = 0.3585 (D50)
Encoding viewing flare1.0%
Typical ambient illuminance level200 lux
Typical ambient white pointx = 0.3457, y = 0.3585 (D50)
Typical viewing flare5.0%
The sRGB specification assumes a dimly lit encoding (creation) environment with an ambient correlated color temperature (CCT) of 5003 K. This differs from the CCT of the illuminant (D65). Using D50 for both would have made the white point of most photographic paper appear excessively blue.[8] [9] The other parameters, such as the luminance level, are representative of a typical CRT monitor.

For optimal results, the ICC recommends using the encoding viewing environment (i.e., dim, diffuse lighting) rather than the less-stringent typical viewing environment.

Transformation

From sRGB to CIE XYZ

The sRGB component values

Rsrgb

,

Gsrgb

,

Bsrgb

are in the range 0 to 1. When represented digitally as 8-bit numbers, these color component values are in the range of 0 to 255, and should be divided (in a floating point representation) by 255 to convert to the range of 0 to 1.

Clinear= \begin{cases}\dfrac{Csrgb

}, & C_\mathrm\le0.04045 \\[5mu]\left(\dfrac\right)^, & C_\mathrm>0.04045\endwhere

C

is

R

,

G

, or

B

.

These gamma-expanded values (sometimes called "linear values" or "linear-light values") are multiplied by a matrix to obtain CIE XYZ (the matrix has infinite precision, any change in its values or adding non-zeroes is not allowed):

\begin{bmatrix}XD65\YD65\ZD65\end{bmatrix} = \begin{bmatrix} 0.4124&0.3576&0.1805\\ 0.2126&0.7152&0.0722\\ 0.0193&0.1192&0.9505 \end{bmatrix} \begin{bmatrix}Rlinear\Glinear\Blinear\end{bmatrix}

This is actually the matrix for BT.709 primaries, not just for sRGB, the second row corresponds to the BT.709-2 luma coefficients (BT.709-1 had a typo in these coefficients).

From CIE XYZ to sRGB

The CIE XYZ values must be scaled so that the Y of D65 ("white") is 1.0 (X = 0.9505, Y = 1.0000, Z = 1.0890). This is usually true but some color spaces use 100 or other values (such as in CIELAB, when using specified white points).

The first step in the calculation of sRGB from CIE XYZ is a linear transformation, which may be carried out by a matrix multiplication. (The numerical values below match those in the official sRGB specification,[10] which corrected small rounding errors in the original publication[11] by sRGB's creators, and assume the 2° standard colorimetric observer for CIE XYZ.) This matrix depends on the bitdepth.

\begin{bmatrix}Rlinear\Glinear\Blinear\end{bmatrix} =\begin{bmatrix} +3.2406&-1.5372&-0.4986\\ -0.9689&+1.8758&+0.0415\\ +0.0557&-0.2040&+1.0570 \end{bmatrix} \begin{bmatrix}XD65\YD65\ZD65\end{bmatrix}

These linear RGB values are the final result; gamma correction must still be applied.The following formula transforms the linear values into sRGB:

CsRGB=\begin{cases} 12.92Clinear,&Clinear\le0.0031308\\[5mu] 1.055

1/2.4
(C
linear

)-0.055,&Clinear>0.0031308 \end{cases}

where

C

is

R

,

G

, or

B

.

These gamma-compressed values (sometimes called "non-linear values") are usually clipped to the 0 to 1 range. This clipping can be done before or after the gamma calculation, or done as part of converting to 8 bits. If values in the range 0 to 255 are required, e.g. for video display or 8-bit graphics, the usual technique is to multiply by 255 and round to an integer.

Usage

Due to the standardization of sRGB on the Internet, on computers, and on printers, many low- to medium-end consumer digital cameras and scanners use sRGB as the default (or only available) working color space. However, consumer-level CCDs are typically uncalibrated, meaning that even though the image is being labeled as sRGB, one can not conclude that the image is color-accurate sRGB.

If the color space of an image is unknown and it is an 8 bit image format, sRGB is usually the assumed default, in part because color spaces with a larger gamut need a higher bit depth to maintain a low color error rate (∆E). An ICC profile or a lookup table may be used to convert sRGB to other color spaces. ICC profiles for sRGB are widely distributed, and the ICC distributes several variants of sRGB profiles,[12] including variants for ICCmax, version 4, and version 2. Version 4 is generally recommended, but version 2 is still commonly used and is the most compatible with other software including browsers. Version 2 of the ICC profile specification does not officially support piecewise parametric curve encoding ("para"), though version 2 does support simple power-law functions.[12] Nevertheless, lookup tables are more commonly used as they are computationally more efficient. Even when parametric curves are used, software will often reduce to a run-time lookup table for efficient processing.

As the sRGB gamut meets or exceeds the gamut of a low-end inkjet printer, an sRGB image is often regarded as satisfactory for home printing. sRGB is sometimes avoided by high-end print publishing professionals because its color gamut is not big enough, especially in the blue-green colors, to include all the colors that can be reproduced in CMYK printing. Images intended for professional printing via a fully color-managed workflow (e.g. prepress output) sometimes use another color space such as Adobe RGB (1998), which accommodates a wider gamut. Such images used on the Internet may be converted to sRGB using color management tools that are usually included with software that works in these other color spaces.

The two dominant programming interfaces for 3D graphics, OpenGL and Direct3D, have both incorporated support for the sRGB gamma curve.

OpenGL supports textures with sRGB gamma encoded color components (first introduced with EXT_texture_sRGB extension,[13] added to the core in OpenGL 2.1) and rendering into sRGB gamma encoded framebuffers (first introduced with EXT_framebuffer_sRGB extension,[14] added to the core in OpenGL 3.0). Correct mipmapping and interpolation of sRGB gamma textures has direct hardware support in texturing units of most modern GPUs (for example nVidia GeForce 8 performs conversion from 8-bit texture to linear values before interpolating those values), and does not have any performance penalty.[15]

sYCC

Amendment 1 to IEC 61966-2-1:1999, approved in 2003, includes the definition of a Y′Cb′Cr′ color representation called sYCC. Although the RGB color primaries are based on BT.709, the equations for transformation from sRGB to sYCC and vice versa are based on BT.601. sYCC uses 8 bits for the components resulting in a range of approximately 0 - 1 for Y; -0.5 - 0.5 for C.[16] The amendment also contains a 10-bit-or-more encoding called bg-sRGB where 0 - 1 is mapped to ..., and bg-sYCC using the same number of bits for a range of approximately -0.75 - 1.25 for Y; -1 - 1 for C.

As this conversion can result in sRGB values outside the range 0 - 1, the amendment describes how to apply the gamma correction to negative values, by applying when is negative (and is the sRGB↔linear functions described above). This is also used by scRGB.

The amendment also recommends a higher-precision XYZ to sRGB matrix using seven decimal points, to more accurately invert the sRGB to XYZ matrix (which remains at the precision shown above):

\begin{bmatrix}Rlinear\Glinear\Blinear\end{bmatrix} =\begin{bmatrix} +3.2406255&-1.5372080&-0.4986286\\ -0.9689307&+1.8757561&+0.0415175\\ +0.0557101&-0.2040211&+1.0569959 \end{bmatrix} \begin{bmatrix}XD65\YD65\ZD65\end{bmatrix}

.

References

Standards

External links

Notes and References

  1. Web site: IEC 61966-2-1:1999. IEC Webstore. International Electrotechnical Commission. 3 March 2017.
  2. Book: Digital Video and HDTV: Algorithms and Interfaces . Charles A. Poynton . Morgan Kaufmann . 2003 . 1-55860-792-7 .
  3. Roberts. A.. BBC RD 1991/6 Methods of Measuring and Calculating Display Transfer Characteristics. BBC. 1.
  4. Web site: 2015-12-05 . The Importance of Terminology and sRGB Uncertainty . 2021-11-05 . Colour Science . en.
  5. Web site: Daniele. Siragusano. July 17, 2020. Colour Online: sRGB... We Need To Talk. FilmLight. 2024-09-01.
  6. Book: Phil Green. Colour Engineering: Achieving Device Independent Colour. Lindsay W. MacDonald. John Wiley and Sons. 2002. 0-471-48688-4. amp.
  7. Book: Jon Y. Hardeberg. Acquisition and Reproduction of Color Images: Colorimetric and Multispectral Approaches. Universal-Publishers.com. 2001. 1-58112-135-0.
  8. Book: Rodney, Andrew . Color Management for Photographers . Focal Press . 2005 . 978-0-240-80649-5 . 121 .
  9. Web site: Why Calibrate Monitor to D65 When Light Booth is D50 . 2022-09-11 . X-Rite . en.
  10. Web site: How to interpret the sRGB color space. color.org. en. 17 October 2017.
  11. Web site: Michael Stokes. Matthew Anderson. Srinivasan Chandrasekar. Ricardo Motta. November 5, 1996. A Standard Default Color Space for the Internet – sRGB, Version 1.10. live. https://web.archive.org/web/20230703221707/https://www.w3.org/Graphics/Color/sRGB.html . Jul 3, 2023 .
  12. https://color.org/srgbprofiles.xalter sRGB profiles
  13. Web site: EXT_texture_sRGB . 24 January 2007 . 12 May 2020.
  14. Web site: EXT_framebuffer_sRGB . 17 September 2010 . 12 May 2020.
  15. Web site: GPU Gems 3: Chapter 24. The Importance of Being Linear, section 24.4.1 . NVIDIA Corporation . 3 March 2017.
  16. Web site: IEC 61966-2-1:1999 Multimedia systems and equipment – Colour measurement and management – Part 2-1: Colour management – Default RGB colour space – sRGB: Amendment 1 . 2003 . International Electrotechnical Commission.