This application claims priority from European No. 16305699.7, entitled “Method of mapping source colors of an image using a LUT having input colors outside a source color gamut,” filed on Jun. 10, 2016, the contents of which are hereby incorporated by reference in its entirety.
The invention relates to the mapping of source colors of an image from a source color gamut into a target color gamut.
Gamut mapping of colors of an image has the goal that the mapped colors are inside of the color gamut of a target display device. A second goal is that the mapped colors make efficient and complete use of the color gamut of the target display device. In general, color gamut mapping can be applied to any color that is within a source color gamut in order to transform it into a mapped color such that this mapped color is included in a target color gamut. The source color gamut can be linked to an image capture device such as camera or scanner. It can be linked to a reference display device such as a proof view display device used to control the creation or color processing of images. It can also be linked to a predefined, virtual color gamut as defined for instance in a standard such as ITU-R BT.709.
Colors are generally represented or encoded by color coordinates in a encoding color space. A color encoding is always based on a specific color space, but additionally includes a digital encoding method. Integer digital encodings linearly specify the digital code value range associated with the color space range. The color space range defines maximum and minimum encoding digital values. For instance, most RGB color space ranges will typically be defined as [0, 1] or [0, 250], while CIELAB may range from [0, 100] for L* and [−150, 150] for a* and b*, respectively. Therefore, although an encoding color space inherently have no boundaries, there is generally a limitation of the range of values that can be encoded, and this range can then be considered as boundaries for the encoding color space. A color gamut of an encoding color space is defined as including colors with color coordinates within such a range, i.e. that are equal or greater than minimum encoding values and that are smaller or equal to maximum encoding values. Below, the word “encoding color space” infer such a color gamut, i.e. a specific range of encoding values.
Usually, a source color is encoded in color coordinates of an input encoding color space having its own gamut. In this case holds that the gamut of the input color encoding space includes the source color gamut. In special cases, the source color gamut equals the input encoding color space, however, this invention addresses specifically the case where the input encoding color space is larger than the source color gamut.
The target color gamut can be linked to a specific reproduction display device. It can be linked also to a predefined gamut for transmission, compression or storage purpose. For example, it can be linked to a predefined, virtual color gamut as defined for instance in a standard such as ITU-R BT.2020. It can be linked to a specific medium such as film or paper prints.
In the following non-limiting examples, the source color gamut is linked to a source display device and the target color gamut is linked to a target display device.
Usually, a target color is encoded in color coordinates of an output encoding color space having its own gamut, i.e. its specific range of values. In this case holds that the gamut of the output encoding color space includes the target color gamut. In special cases, the target color gamut equals the color gamut of the output color space. This invention addresses this case with a specific variant. However, this invention addresses also the case where the color gamut of the output color space is larger than the target color gamut.
It is well known to implement such a color mapping by applying a color look-up-table (LUT) to source colors of an image to map. A color LUT consists of a list of pairs of input color coordinates RGB and of corresponding pre-calculated output color coordinates R′,G′,B′. As shown on
Input colors that are chosen to build a color LUT generally samples regularly the source color gamut. This sampling is generally performed through a grid having nodes representing source colors.
An example of a grid representing input colors of a color LUT sampling the source color gamut is illustrated on
Using such a color LUT, the mapping of a source color to map which does not lye on a grid sampling the source color gamut should be interpolated in a manner known per se from the input and output colors of the LUT. Generally, a fixed number of input colors of the LUT lying on the positions of the grid within the input encoding color space which are the closest to the source color to map are selected, and the mapped target color is interpolated in a manner known per se from the corresponding output colors of the LUT. Known interpolation methods include trilinear and tetrahedral interpolation, using 3 and 4 closest colors on the grid, respectively, such as explained for instance by Amidror in his paper entitled “Scattered data interpolation methods for electronic imaging systems: a survey” published in Electronic Imaging, Vol. 11.2 in 2002.
A problem raises when a source color to map is located in close proximity to the boundary of the source color gamut—as illustrated by the “sample source color” on
For instance, in the 2D representation of
An object of the invention is to solve the above problem, notably by using a color LUT including input colors located outside the source color gamut. Preferably, this color LUT further include output colors located outside the target color gamut.
For this purpose, a subject of the invention is method of mapping source colors of an image represented in an input encoding color space into target colors represented in an output encoding color space, from a source color gamut in a target color gamut, said method comprising applying said mapping color LUT to source colors of said image, resulting into mapped colors, wherein said mapping color LUT has input colors that sample not only said source color gamut but also a portion of said input encoding color space not included in said source color gamut.
The input and output encoding color spaces are both limited by specific boundaries corresponding to specific range of encoding values.
Such a mapping color LUT is formed by pairs of input colors included in the input encoding color space and of corresponding output colors included in the output encoding color space.
In summary, according to this method, the mapping color LUT has input colors that sample not only a source color gamut (included in an input encoding color space in which inputs colors of this LUT are encoded) but also a portion of the input encoding color space which is not included in the source color gamut.
Advantageously, accuracy of the mapping is improved, notably for source colors located near the boundary of the source color gamut.
For source colors to map which are not equal to any input color of the mapping color LUT, it is implicit that the application of the mapping color LUT includes an interpolation from a plurality of output colors of this mapping color LUT. Such an interpolation is well known in the art of application of color LUTs. It means that this interpolation is inherent to the application of the mapping color LUT.
Preferably, the source color gamut is included in the input encoding color space.
Preferably, the target color gamut is included in the output encoding color space.
Preferably, said portion of said input encoding color space is connex to said source color gamut. It means that the mapping color LUT includes input colors that are distributed outside but in neighborhood to the source color gamut, i.e. to its boundaries. Advantageously, the precision of the mapping of source colors located near the boundary of the source color gamut is improved.
Preferably, said method comprises applying a color extension operator to said mapped colors to get said target colors. It means that the mapped color that is obtained by the application of the mapping color LUT (including, if necessary, any interpolations from a plurality of output colors of this LUT) is further extended using this operator.
Preferably, said color extension operator is such that the application of said color extension operator to the surface obtained by the application of said mapping color LUT to said source color gamut results approximately in said target color gamut.
Preferably, said color extension operator is such that the application of said color extension operator to output colors of said mapping color LUT results in extended output colors, some of which are located outside said output encoding color space.
It means that the mapping color LUT results from a compression of an original color LUT and that the application of the color extension operator to the mapping color LUT results in this original color LUT.
A subject of the invention is also an image processing device configured for mapping source colors of an image represented in an input encoding color space into target colors represented in an output encoding color space, from a source color gamut in a target color gamut, and configured for applying a mapping color LUT to source colors of said image, resulting into mapped colors, wherein said mapping color LUT has input colors that sample not only said source color gamut but also a portion of said input encoding color space not included in said source color gamut.
Preferably, the image processing device is also configured for applying a color extension operator to said mapped colors to get said target colors.
Preferably, said color extension operator is such that the application of said color extension operator to output colors of said mapping color LUT results in extended output colors, some of which are located outside said output encoding color space.
A subject of the invention is also an electronic device incorporating such an image processing device. Such an electronic device can be any device able to process images, for instance a camera, a smartphone or a tablet, a TV set, a set-top-box, or a gateway.
Preferably, this electronic device comprises also a module for receiving said image, said color mapping LUT and, when needed, said color extension operator.
A subject of the invention is also a computer program product comprising program code instructions to execute the steps of the mapping method above, when this program is executed by a processor
A subject of the invention is also a method of mapping source colors of an image represented in an input encoding color space into target colors represented in an output encoding color space, from a source color gamut in a target color gamut, comprising:
Preferably, this method comprises transmitting said image, said mapping color LUT and said color extension operator before applying said mapping color LUT to source colors of said image.
The invention will be more clearly understood on reading the description which follows, given by way of non-limiting example and with reference to the appended figures in which:
It will be appreciated by those skilled in the art that flow charts presented herein represent conceptual views of illustrative circuitry embodying the invention. They may be substantially represented in computer readable media and so executed by a data processing device, whether or not such device is explicitly shown. The functions of the various elements shown in the figures may be provided through the use of hardware capable of executing software in association with appropriate software. Such hardware capable of executing such software generally uses processor, controller, digital signal processor (“DSP”) hardware, read-only memory (“ROM”) for storing software, random access memory (“RAM”), and non-volatile storage.
The invention, and notably the steps 3 and 4 of the method described below, may notably be implemented by any device capable of processing images, notably capable of implementing color gamut mapping of images. Therefore, the invention can be notably implemented in an image capture device such as a camera, an image display device such as a TV set, a monitor, a head mounted display, or a set top box or a gateway. The invention can also be implemented in a device comprising both an image capture display device and an image display device, such as a smartphone or a tablet. All such devices comprise hardware capable of executing software that can be adapted in a manner known per se to implement the invention.
A first embodiment of the method of color mapping will now be described through four different steps in reference to
An input encoding color space is chosen such that the source color gamut is included in this input encoding color space. An output encoding color space is chosen such that the target color gamut is included in this output encoding color space as shown on
The first and second steps below may be implemented for instance on the side of production of a video content on platforms that resize, encode, or generally reformat video content for specific distribution channels such as optical discs, broadcasting or cinema.
In this first step, from the source color gamut and the target color gamut, an original color LUT is built such as to be adapted to map colors from this source color gamut into the target color gamut. This original color LUT is precalculated as in the prior art, but instead of taking input colors sampling only the source color gamut for this precalculation, input colors are taken that sample at least a portion of the input encoding color space which is not included in the source color gamut. Preferably, this portion surrounds the source color gamut.
Generally, through such a process, the input colors of the color LUT that are outside the source color gamut are generally mapped into corresponding output colors that are located outside the target color gamut, as shown on
Having obtained this original color LUT, two situations are possible:
As shown on
Besides this color compression operation, a color extension operator is built in a manner known per se as the inverse of the color compression operator. This color extension operator will be used in the fourth step below.
The third and fourth steps below may be implemented for instance on the side of consumption of a video content, more precisely on a device capable of processing images, i.e. for instance on a consumer device such as TV set, a set-top-box, a tablet or any other consumer device mentioned above, or for instance on a professional device such as a video production platform that resize, encode, or generally reformat video content for specific distribution channels such as optical discs, broadcasting or cinema.
The mapping color LUT, the color extension operator and of course the image to map are provided to this device capable of processing images in a manner known per se, notably by transmission through any usual transmission network as a broadcast, a LAN or a WiFi network. Source colors defining the image is notably provided to such a device through color coordinates representing these source colors in the input encoding color space.
In this third step, the mapping color LUT—resulting from the 1st or 2nd step above depending on the situation N or Y—is applied to source colors of the image to get mapped colors, including, when appropriate, any interpolation from different output colors of this LUT as in the prior art. Such an interpolation is considered as inherent to this third step.
In the first situation in which all output colors of the original LUT are located inside the output encoding color space after the first step (see
In the second situation in which a color compression operator has been applied in order to get all output colors of the LUT inside the output encoding color space as shown on
Note that the application of this color extension operator to these mapped colors changes indeed the mapped colors; such an application is then different from a conversion of colors, i.e. from a change of representation of colors—as for instance a change of color space. For instance, the application of a color conversion operator—as obtained for instance by a combination of a source forward transform representative of a source display device and of a target inverse transform representative of a target display device—would not change colors but only their representation.
Globally, the combination of applications of the compressed mapping color LUT and of the color extension operator is approximately equivalent to the application of the original color LUT. Due to the interpolation inherent to the third step, it is possible that the result of this combination of applications—including inherent interpolations from different pairs of inputs-outputs extracted from the compressed mapping LUT—differs slightly to the direct application of the original color LUT including the same inherent interpolations, notably because these inherent interpolations are not applied at the same level: as a matter of fact, the color extension step is applied here after these interpolations.
At the end of the above process, a color mapped image is obtained, in which even source colors located near the boundary of the source color gamut are precisely mapped into target colors.
A second embodiment of the invention will now be described. In this second embodiment, the source color gamut is defined by the D65 white point and the P3 primary colors specified in SMPTE RP 431-2:2011 “D-Cinema Quality—Reference Projector and Environment”, in the following called P3 color gamut. The target color gamut is the color gamut according to ITU-R BT.709, in the following called BT.709 color gamut. The input encoding color space is chosen to be according to ITU-R BT.2020, in the following called BT.2020 color space.
In this first step, from the source color gamut and the target color gamut, an original color LUT is built such as to be adapted to map colors from the P3 color gamut into the BT.709 color gamut. This original color LUT is precalculated such as known in the prior art according to the following steps:
More specifically, this original Look Up Table is calculated using the perception-based gamut mapping operating in CIELAB color space, according to the following steps.
Input colors lying on a regular grid sampling the input color space—for example 9×9×9—are selected, such that they have input color coordinates RiGiBi—for example i=0 . . . 93−1—in this input color space. These input color coordinates RiGiBi form the entries of the original Look Up Table. For a number of these input colors, the following steps are applied:
where the matrix MRGB-to-XYZ is defined according to:
Then, in a first mapping step, hue mapping modifies the hue of the colors of the input colors by mapping these coordinates Liaibi into hue mapped coordinates L′ia′ib′i. Hue is an aspect of colour that should generally be preserved during color gamut mapping. However, misalignment of hues of primary and secondary colors may lead to suboptimal behavior of succeeding steps of colour gamut mapping. In fact, non-uniform saturation modifications may occur when the primary colors defining the source colour gamut and the primary colors defining the target colour gamut are significantly mismatched. Hue mapping aims to improve the uniformity of the saturation modification induced by colour gamut mapping, notably to minimize the degradation of colour neighborhood while minimizing the average change of hue. Hue mapping adaptively changes the hue of a P3 primary color towards the hue of the corresponding BT.709 primary color based on the difference in hue and chroma of the P3 and BT.709 primary colors. Preferably, the hue change resulting from the color gamut mapping should be stronger when the difference of saturation between the P3 primary color and the corresponding BT.709 primary color is smaller. The following steps are carried out:
This offset is the stronger the smaller is the difference of saturation between the primary colors reflected by Δα.
Then a chroma mapping acts mainly on the chroma of the first mapped colors resulting into second mapped colors such that all second mapped colors are within the BT.709 color gamut. The following steps are carried out:
where
To conclude the calculation of the original Look Up Table, the second mapped coordinates L″ia″ib″i are transformed back into linear XYZ color coordinates X′iY′iZ′i using D65 as white point, and the linear XYZ color coordinates X′iY′iZ′i of a mapped color are transformed into linear BT.709 color coordinates R′iG′iB′i according to
where the matrix MXYZ-to-RGB is defined according to
It should be noted that for this look up table precalculation, instead of taking input colors sampling only the P3 color gamut for this precalculation, input colors are taken that sample the BT.2020 input encoding color space which is significantly larger than the P3 color gamut. In other words, there is a large portion of the BT.2020 input encoding color space which is not included in the P3 source color gamut. By this process, the input colors outside the P3 source color gamut are mapped to output colors outside the BT.709 target color gamut, as shown on
Having obtained this original color LUT, whether there are output colors outside the output encoding color space, such as shown on
As shown on
This compression operator is defined here to pre-scale the linear BT.709 color coordinates R′iG′iB′i obtained in the described 1st step resulting in pre-scaled, or compressed linear BT.709 color coordinates R″iG″iB″i. Pre-scaling, or compression, handles color coordinates being out-of-range for those colors having been chroma mapped with a distance D>Dmax before chroma mapping. Prescaling of R′i color coordinates is done according to:
and equivalently for G″i, B″i. The prescaled, linear BT.709 color coordinates R″iG″iB″i build an entry of the mapping color LUT.
Besides this color compression operation, a color extension operator is built in a manner known per se as the inverse of the color compression operator. This color extension operator will be used in the fourth step below.
In this third step, the mapping color LUT—resulting from the 2nd step above—is applied to source colors of the image to get mapped colors, including, when appropriate, any interpolation from different output colors of this LUT as in the prior art.
Thanks to input colors of this LUT located outside the source color gamut, the problem of precision of color mapping interpolation for source color located near the boundary of the source color gamut is advantageously avoided.
The color extension operator defined at the 2nd step above as the inverse of the color compression operator is applied to the mapped colors obtained at the 3rd step above in order to get the final target colors.
When RLUTGLUTBLUT are the color coordinates of the mapped colors of the 3rd step, the color extension operator is a linear post-scaling according to:
R
709
=m
R
R
LUT
+b
R
G
709
=m
G
G
LUT
+b
G
B
709
=m
B
B
LUT
+b
B
resulting in color coordinates R709G709B709 of the final BT.709 target colors.
Globally, the successive applications of the color compression operator, of the compressed mapping color LUT and of the color extension operator is equivalent in terms of color to the application of the original color LUT. However, due to any interpolation from different output colors of the LUT, slight differences may occur. To avoid R709G709B709 coordinates corresponding to colors outside the BT.709 color gamut due to any interpolation, these color coordinates are clipped such that the clipped color coordinates correspond to colors within the B T.709 target color gamut.
At the end of the above process, a color mapped image is obtained, in which even source colors located near the boundary of the source color gamut are precisely mapped into target colors.
The second embodiment described above may include the following variation. When applying a mapping color LUT in an BT.2020 input encoding color space to colors included within PR source color gamut that is smaller than BT.2020, some of the entries of the mapping color LUT may never be used. In this case it can be advantageous to apply an input compression operator and an input extension operator according to the following way:
Modification of the 1st Step of the 2nd Embodiment:
The modification is to apply additionally an input compression operator to the RiGiBi color coordinates before transformation into XYZ color space. The compression operator can be for example:
R′″=R/0.96875
G′″=G/0.96875
and R′″ and G′″, respectively, is used instead of R,G for transformation into XYZ color space. This results in a modified original color LUT. The 2nd step is not modified but leads no a modified color mapping LUT since input to the 2nd step is the modified original color LUT.
Modification of the 3rd Step of the 2nd Embodiment:
The modification is to apply additionally an input extension operator being the inverse of the described input compression operator to the color coordinates of the source colors of the image before application of the modified color mapping LUT according to
R″″=0.96875 Rsource color of image
G″″=0.96875 Gsource color of image
And then using R″″ and G″″ instead of the color coordinates of the source colors of the image.
The application of the input extension operator and the modified mapping color LUT gives approximately the same colors as not applying the input extension operator and applying the mapping color LUT. The advantage of the described variation is that the modified mapping color LUT has less unused entries than the mapping color LUT and finally the whole color mapping has a higher precision. For example, when LUTs of size 33×33×33 are used for mapping P3 source colors of images represented in BT.2020 input encoding color space, and if color coordinates of these images are normalized within the range [0,1], the red and green color coordinates never go beyond the value of 0.96875 . Therefore, it is advantageous to use this value in the input extension and input compression operators.
Other types of input extension and input compression operators are possible that use non-linear terms such as for example
R′″=R
2/0.96875
or cross color channel terms such as for example
R′″=R G/0.96875.
Although the illustrative embodiment of the invention has been described herein with reference to the accompanying drawings, it is to be understood that the present invention is not limited to this precise embodiment, and that various changes and modifications may be effected therein by one of ordinary skill in the pertinent art without departing from the invention, notably when implementing separately steps 3 and 4 of the above embodiment. All such changes and modifications are intended to be included within the scope of the present invention as set forth in the appended claims. The present invention as claimed therefore includes variations from the preferred embodiment described herein, as will be apparent to one of skill in the art.
While some of the specific embodiments may be described and claimed separately, it is understood that the various features of embodiments described and claimed herein may be used in combination.
Number | Date | Country | Kind |
---|---|---|---|
16305699.7 | Jun 2016 | EP | regional |