This invention relates to displays such as computer displays, televisions, video monitors, home cinema displays, specialized displays such as displays used in medical imaging, virtual reality, vehicle simulators, and the like. The invention has particular application to displays having a spatial light modulator that modulates light from a light source. In some embodiments the light source has an output that is locally controllable.
Displays have become ubiquitous. There is increasing interest in providing displays that provide high quality images. Characteristics of high quality images include accurate color rendering and high dynamic (luminance) range. Displays capable of displaying high dynamic range images are known as high dynamic range displays.
Many displays display color digital images specified by input signals. Color digital images are made of pixels, and pixels are made of combinations of components, typically combinations of primary color components (e.g. Red-Green-Blue) or of a luminance component and chrominance components (e.g. YUV). The components that make up an image define a color space. A channel in this context is an image made of just one component, which varies in intensity over the image. The part of a channel that contributes to a pixel of a color image may be known as a sub-pixel.
Because input signals have finite bandwidth, the components of digital images are represented as discrete levels within finite ranges. As a result, the number of possible combinations of components is also discrete. The discrete representation of components causes the set of possible colors corresponding to combinations of the components, known as the gamut, to be limited in both depth (how finely levels of color can be expressed) and range (how broad a range of colors can be expressed).
Displays display color images by emitting colored light. Displays typically generate a range of colored light by combining light of different component colors. Displays that generate a range of colors of light by combining component colored light can display colors in a gamut defined by the component colored light. The gamut will be defined by the maximum intensity of each component colored light, and the depth of intensity of each component colored light. In some displays component colored light is emitted from pixels of a spatial light modulator that is illuminated by a backlight. In some displays, component color light is controlled digitally, for example by digital driving values. The gamuts of these displays are finite and discrete.
It is often the case that the gamut of a display will differ from the gamut of input signals that provide images to the display. The display gamut may differ from the input gamut in both depth (how finely levels of color can be expressed) and range (how broad a range of colors can be expressed). In order for the display to display a high quality image, the specification of the image for the input gamut must be transformed to specify the image for the display gamut. This transformation may require adjusting the image specification to provide increased depth or decreased depth, and/or to provide increased range or decreased range. By way of example only, an image specified for an input gamut with a range that is lower than the range of the gamut of a display may be adjusted for the higher-range gamut of the display.
The process of transforming an image specification from an input gamut to a display gamut provides an opportunity to optimize the image for display on the display. In particular, transforming the image specification may comprise increasing the dynamic range and the color depth of the image. However, increasing the dynamic range and the color depth of the image can introduce negative image characteristics, such as color shifts, posterization and visible contrast artefacts.
There is a general desire to provide displays capable of displaying high-dynamic range images. There is a general desire to adapt image data signals for high dynamic range display. There is a general desire to provide systems and methods for ameliorating and/or overcoming negative image characteristics associated with adapting image data signals for high dynamic range display.
Aspects of the invention provide displays, methods for displaying images, methods for processing image data for display, image processing components for use in displays, and display controllers. Some embodiments provide color correction features. Some embodiments provide features for boosting dynamic range of displayed images. Such embodiments may comprise features for reducing artefacts resulting from boosting the dynamic range of image data.
Further aspects of the invention and features of specific embodiments of the invention are described below.
The accompanying drawings illustrate non-limiting embodiments of the invention.
Throughout the following description, specific details are set forth in order to provide a more thorough understanding of the invention. However, the invention may be practiced without these particulars. In other instances, well known elements have not been shown or described in detail to avoid unnecessarily obscuring the invention. For example, certain known details of specification of color images and known details of methods for translating of color spaces and gamut mapping are not described herein. Such details are known to those of skill in the field and are described in the relevant literature and there is no need to repeat them here.
Accordingly, the specification and drawings are to be regarded in an illustrative, rather than a restrictive, sense.
Display 10 comprises a controller 18. Controller 18 receives input signals 19 and generates output signals 20 that supply driving values for pixels 22 of spatial light modulator 14. Pixel driving values determine what proportion of the light incident on pixels 22 from backlight 12 is passed on (transmitted or reflected) to a viewing area. The response of pixels 22 to pixel driving values may be linear or non-linear. A response function specifies a relationship between the light that is passed by a pixel and pixel driving values. In general, a desired pixel driving value may be specified as the output of a response function of the desired passing of light.
Some embodiments comprise such response functions. A response function may be embodied as a look-up table (LUT); code providing an algorithm to be executed on a processor; logic circuits (which may be configurable or hard-wired), combinations thereof, or the like.
In general, spatial light modulator 14 may be a transmissive-type spatial light modulator or a reflective type spatial light modulator. In particular embodiments, spatial light modulator 14 comprises a liquid crystal display (LCD) panel.
In some embodiments, display 10 is a color display and spatial light modulator 14 is a color spatial light modulator. For example, spatial light modulator 14 may comprise separate sets of pixels for each of a plurality of colors. The pixels for each color may comprise optical filters that pass the corresponding color and block other colors. For example, spatial light modulator 14 may comprise sets of red- green- and blue-passing pixels (RGB pixels). RGB pixels are described for example only. Other sets of colored pixels could be provided in the alternative. The pixels may be arranged in any suitable pattern. A Beyer pattern is but one example of a suitable pattern.
In some embodiments, controller 18 is configured to generate one or more additional output signals 24 that control light emitted by backlight 12. Output signals 24 may control one or more of: the overall intensity of light emitted by backlight 12, the spatial distribution of light emitted by backlight 12, one or more color characteristics of light emitted by backlight 12 or the like.
In the illustrated example embodiment, backlight 12 comprises an array of individually-controllable light sources 30. Each of light sources 30 may comprise one or more light-emitting elements such as light-emitting diodes (LEDs) or other light-emitting solid state devices. In embodiments comprising individually-controllable light sources 30, output signals 24 may comprise driving signals that can directly or indirectly drive light sources 30 to emit light.
In some embodiments, the light emitted by backlight 12 comprises white light. This may be achieved, for example, by providing light sources 30 that emit light of different colors that combine to yield white light (for example, red-, green- and blue-emitting light sources 30) or by providing individual light sources 30 that produce white light (for example white LEDs).
Some non-limiting examples of general approaches that may be implemented in controller 18 for generating output signals 20 and 24 are described in: WO02/069030 entitled HIGH DYNAMIC RANGE DISPLAY DEVICES; WO03/077013 entitled HIGH DYNAMIC RANGE DISPLAY DEVICES; WO 2006/010244 entitled RAPID IMAGE RENDERING ON DUAL-MODULATOR DISPLAYS; U.S. 61/105,419 filed on 14 Oct. 2008 and entitled: BACKLIGHT SIMULATION AT REDUCED RESOLUTION TO DETERMINE SPATIAL MODULATIONS OF LIGHT FOR HIGH DYNAMIC RANGES IMAGES; which are hereby incorporated herein by reference.
One issue that can arise in displays of the general types described above is input signals 19 may specify colors for a gamut that does not match the color gamut achievable with display 10. This is illustrated in
Another issue that can arise is that if the primary colors that are provided in a display are not the same as the primary colors assumed by the image data then colors produced by the display in response to the image data may not match the color intended by the creator of the image data. This can be the case even where the gamut of the display includes the entire gamut of input signals 19.
Consider the case where input signals 19 specify colors in a gamut 45 that is different from gamut 42. In the illustrated embodiment, gamut 45 includes some colors in a region 46 that cannot be reproduced by display 10 because they are outside of gamut 42. In other embodiments, a display gamut may include colors that cannot be represented in an input gamut. In some embodiments, a display gamut and an input gamut may each include colors that cannot be reproduced by or represented in the other.
In some types of signal that may be provided as input signals 19, luminance values (or other values indicative of brightness or intensity) are encoded according to a non-linear function such as a gamma encoding function. Where this is the case, it is advantageous (although not mandatory in all embodiments) to convert the image data of input signals 19 into a linear space. Typically, the linear space has a greater range than the encoded space. Method 50 has a linearization block 52 which yields linearized image data 53.
In some embodiments, the linearized image data 53 is represented as binary integers having a bit depth greater than that of image data input signals 19. In embodiments where signals 19 have been gamma corrected according to a power function such as:
L
OUT
=L
IN
γ (1)
where: LOUT is the luminance value encoded in input signal 19, LIN is the original unencoded luminance value and γ is a parameter then block 52 may comprise applying an inverse of Equation (1). γ has the value of 2.2 in many video formats.
In some embodiments block 52 comprises looking up linearized values in a look-up-table (LUT). For example, if the input signal 19 is in a format that specifies brightness by providing one of a discrete set of possible brightness values (e.g. a byte having bit-values specifying brightness in the range 0 to 255) then block 52 may comprise providing the brightness as a key to a LUT that retrieves a corresponding linearized brightness value.
In some embodiments block 52 comprises applying a boost such that the linearized values are increased. Applying the boost may comprise multiplying by a boost factor. In some embodiments, the boost factor is a constant. In some embodiments the boost factor is a function of the linearized values. For example, the amount of boost may increase for increasing brightness. Where the boost factor is a function of pixel values it is preferred that the same boost factor be applied to all values relating to a pixel to avoid color shifts. For example, where a pixel value comprises a tuple, such as, for example [R,G,B], it is preferable that the same boost factor be applied to all components of the tuple. The boost and linearization may be provided in a combined set of operations or in separate operations.
In some embodiments, the boost may be performed before or without linearization. If boost is performed, the boost may be performed before, after, or in the same step as linearization. In some such embodiments, the range of input signals may be expanded. In some embodiments, boosting and linearization are implemented by providing a look up table. An input signal may be used as a key to retrieve a corresponding boosted and linearized valve.
In an example embodiment, block 52 provides linearized image data 53 in which luminance values are specified by integers. Preferably the integers are sufficiently large that they can represent a large number of discrete luminance values. For example the integers may comprise 31-bit integers. It is desirable that there be sufficient discrete luminance values that the step in luminance obtained by moving to a next luminance value is not noticeable to the eye. In block 56 linearized image data 53 is transformed to a color space appropriate for display 10, if required, and a color correction is applied to yield color corrected data 57. Image data may be required to be transformed where the data specifies an image in a color space that is different from or incompatible with the color space of a destination display. It is not mandatory to perform color space transformation before scaling. Color space transformation may be performed after or in the same step as scaling. Scaling, color space transformation and color correction may be performed together or in any suitable order.
The transformation of block 56 may receive as input a set of color coordinates defined relative to gamut 45 of input data 19 and produce as output color corrected data 57 comprising a set of color coordinates defined relative to gamut 42 of display 10.
The color correction may comprise performing a transformation in a manner which maps a white point 45W of gamut 45 to a desired white point in the gamut 42 of display 38. The transformation may compensate for differences between a spectrum of light emitted by backlight 12 of display 10 and the desired white point, for example. In some embodiments, color transformation and/or color correction may be implemented by performing an affine transformation on the color valves. Such a transformation may skew, scale, and/or rotate colors in a 3-dimensional color space. For example, such a transformation may be expressed as:
o=sMi+c (2)
where o is an output color vector, i is an input color vector, s is a scaling valve or matrix, M is a transformation matrix, and c is color shift vector. A color shift vector may be added before or after applying transformation matrix M. Color shift is not mandatory.
The color correction may be applied, for example, by performing a matrix operation on linearized image data 53. In the illustrated embodiment, pixel values of linearized image data 53 are multiplied by a color correction matrix 58 to yield corrected image data 57.
In a specific example embodiment, block 56 is implemented by applying a general purpose or customized matrix multiplication facility connected to perform matrix multiplications of color vectors on a per-pixel basis in a stream of image data or to perform a matrix multiplication to image data in a buffer or other memory. The matrix multiplication facility may comprise, for example, a programmed data processor, such as a CPU, GPU, DSP, or the like, a hardware matrix multiplier such as a suitably configured FPGA, logic circuits or the like.
In some embodiments, the color correction in block 56 is performed on a pixel-by-pixel basis and takes into account one or more properties of light incident at pixels from backlight 12, such as, for example, intensity (luminance) and color (chromaticity). In some embodiments the illumination provided by backlight 12 is variable. For example, the overall intensity of light from backlight 12 may be controlled or the light output from backlight 12 may be controlled to vary spatially. Spatial variation in the intensity of light provided by backlight 12 across the pixels of spatial light modulator 14 may be provided, for example, by controlling individually the intensity of light emitted by individual elements of backlight 12. In some such embodiments, spatial light modulator 12 comprises arrays of elements that emit light of different spectral characteristics (e.g. arrays of red- green- and blue-emitting (RGB) light sources or arrays of red- green- blue- and white-emitting (RGBW) light sources). In such embodiments, the color and intensity of light from backlight 12 at pixels may be estimated or determined and the color correction may be based in part on the local color and intensity of the light from backlight 12 at locations on spatial light modulator 14. For example, in some embodiments, the color and intensity of light from backlight 12 at pixels may be estimated from a combination of image data for pixels surrounding or near the pixel and one or more known properties of backlight 12. The properties may include, for example, point spread functions for light emitters of backlight 12, electro-optical characteristics of light emitters of backlight 12, optical characteristics of optical path 16, combinations thereof, or the like.
For example, generating the estimate may comprise performing a light field simulation. A light field simulation may be performed by taking driving values for individual elements of backlight 12, applying point spread functions that approximate how light from the elements becomes distributed over pixels of spatial light modulator 14 to determine the contributions of one or more elements of backlight 12 at pixels of spatial light modulator 14 and then summing the light contributions of the one or more contributing elements of backlight 12.
In an example embodiment, an estimate of the distribution of light incident from backlight 12 is determined at a resolution that is somewhat greater than (for example twice or four times) the resolution of individuals elements of backlight 12. Per-pixel color at pixels at spatial light modulator 14 is determined in this example embodiment by bi-linear upsampling of the estimated distribution of light.
If block 56 yields values for color coordinates that are outside of a valid range then such values may be replaced with valid values. For example, if block 56 yields any negative values for color coordinates (as could occur in some cases if, for example, the input data 19 specifies a color that is within gamut 45 but outside of gamut 42) and such negative values are not valid for a display being controlled then block 56 may comprise replacing such negative values with non-negative values. For example, any negative values may be replaced with zero or a small positive value.
In some embodiments block 56 may also transform image data to a different image format. The different image format may use the same or a different color space as the original format. By way of example only, linearized image data 53 may express colors in a RGB format and block 56 may perform a conversion such that the output of block 56 provides color corrected data 57 in another format, for example an XYZ format, such a conversion may be combined with or performed separately from other color transformations.
In embodiments where the illumination provided by backlight 12 is variable, block 60 may be provided. Block 60 scales corrected image data 57 (for example, by multiplying or dividing by a factor that varies from pixel to pixel of spatial light modulator 14) in a manner that takes into account the different intensities of light incident on the pixels of spatial light modulator 14.
Block 60 may apply an indication of the intensity and spectral composition of light incident on pixels of spatial light modulator 14. The scaling factor may be based, at least in part, on the indication. The indication may be obtained in various ways, and in some embodiments, the indication comprises an estimate of the intensity and spectral composition of light incident on pixels of spatial light modulator. The estimate may be generated in block 50, or elsewhere, for example where an estimate is determined in block 56 for color correction the same estimate may be used in block 60.
In other embodiments, the indication may be obtained from image data, for example by low-pass spatial filtering the image data, taking an average or weighted average of image data for a local neighborhood of the image or the like. In some embodiments the indication comprises values that vary with the inverses of the intensities of light from backlight 12 at the pixels of spatial light modulator 14. Such embodiments may advantageously perform scaling by multiplying pixel values by corresponding scaling factors. Multiplying can be implemented somewhat more efficiently than dividing in many of the types of hardware that may be applied to implement block 60.
Such scaling may be performed, for example, by applying the general approaches described in:
WO02/069030 entitled HIGH DYNAMIC RANGE DISPLAY DEVICES; WO03/077013 entitled HIGH DYNAMIC RANGE DISPLAY DEVICES; WO 2006/010244 entitled RAPID
IMAGE RENDERING ON DUAL-MODULATOR DISPLAYS; and U.S. 61/105,419 filed on 14 Oct. 2008 and entitled: BACKLIGHT SIMULATION AT REDUCED RESOLUTION TO DETERMINE SPATIAL MODULATIONS OF LIGHT FOR HIGH DYNAMIC RANGES IMAGES, all of which are hereby incorporated herein by reference.
In block 64, the corrected image data 59 (or a scaled version thereof in embodiments which include block 60) is constrained to be within the color gamut 42 of display 10. The constraint may be applied, for example, by scaling pixel values of the corrected image data such that the image data does not specify an intensity for any color channel that is greater than an intensity that can be reproduced by display 10. The output of block 64 is gamut-limited data 65.
Consider the case, for example, where the corrected image data is represented in an RGB color format in which values for each of red- green- and blue- sub pixels 22R, 22G and 22B are each specified in a range from 0 to 1. The subpixel value 1 represents the maximum brightness that the corresponding subpixel of display 10 can produce. Where the corrected image data includes one or more subpixel values that are greater than 1, block 64 may comprise scaling the sub-pixel values such that none of the subpixel values exceeds 1. In other cases, maximum brightness sub-pixel brightness may be different for different color subpixels. In some embodiments, this scaling is performed on a pixel-by-pixel basis. In some embodiments, the scaling comprises multiplying all sub-pixel values for a pixel by a common scaling factor.
In embodiments in which the corrected image data is in a format having a brightness or intensity value and one or more color values that specify color (e.g. a YUV format), the scaling of block 64 may comprise multiplying the intensity value by a scaling factor that is a function of the one or more color values.
In block 66 driving values 67 are determined for the pixels of spatial light modulator 14. The driving values 67 may be obtained, for example by looking up coordinate values from gamut-limited data 65 in a suitably configured look-up table or by computing functions of the coordinate values of gamut-limited data 65, or the like. A particular implementation that may be advantageous is described in the U.S. patent application No. 61/105102 filed 14 Oct. 2008 and entitled EFFICIENT COMPUTATION OF DRIVING SIGNALS FOR DEVICES WITH NON-LINEAR RESPONSE CURVES, which is hereby incorporated herein by reference for all purposes.
In some embodiments, block 66 comprises reducing a bit depth of the gamut-limited data to correspond to a resolution of display 10 before determining the driving values 67. Output signals 20 may comprise driving values 67. Driving values 67 may be applied to drive the pixels and sub-pixels of spatial light modulator 14 so as to display an image.
In some embodiments, input signals 19 comprise video data and method 50 is repeated for successive frames of the video data.
Consider the case where the original image data is boosted and mapped into a color space in which a greater intensity 72A is permitted as shown, for example, in
The result of a boost is illustrated in
Some embodiments of the invention apply a method to mitigate artefacts resulting from conditions such as those illustrated in
In some embodiments, introducing dither comprises randomly or quasi-randomly adding or subtracting small amounts from pixel values. In some embodiments the small amounts added or subtracted are smaller than the differences between adjacent values for a display. The addition and subtraction of these small amounts may cause pixels that would otherwise have the same intensities to have intensities that are different.
Consider the following specific example. In this example, driving values 67 for the pixels of a display 10 are specified as binary numbers having some suitable number of bits, for example 10 bits. The method involves representing the driving values 67 as 11-bit numbers in which the value for the lowest-order bit is set randomly (including quasi-randomly). The 11-bit numbers are then rounded to provide the 10-bit driving values 67 used to drive pixels of display 10. The random addition of a lowest-order bit followed by rounding introduces a fuzziness into lines like line 81 that could form in image regions where the intensity changes slowly.
The general approach of randomly adding or subtracting a small amount from pixel values and then rounding is not limited to applications in which pixel values are expressed in a binary representation. A similar approach can be applied to provide dithering where pixel values are expressed as decimal numbers, for example.
Consider another specific embodiment in which pixel driving values are expressed as decimal integers in the range of 0 to 100. Small decimal values (for example values of magnitude less than 1) may be randomly added to or subtracted from the pixel driving values and then the pixel driving values may be rounded to the nearest integer. A simple way to implement such a scheme is to provide an array of such small numbers and to take the pixel driving values in sequence and each time add to the pixel driving value the value of the next element in the array. If the array has N entries then every Nth pixel driving value will have the same amount added to it. However, if N is more than a few and N is suitably chosen then the result will not be noticeably different from the addition of small amounts at random.
For example, the array may have a prime number of elements such as 7 or 11 in some embodiments. The following 7-element array could be applied, for example: {0; 0.25; −0.5; 0.25; 0; 0.5; −0.25}.
In some embodiments, introducing dither may comprise multiplying or dividing pixel values by random or quasi-random amounts near one.
Small random variations could also conveniently be introduced to pixel values when linearizing and/or boosting input data, for example in block 52 of method 50. Where the linearized pixel values are expressed in a manner that provides a larger number of discrete possibilities than the original data, some randomness may be introduced while or after performing the linearization.
Applying small random variations to pixel values (in some embodiments variations that are below a quantization threshold) may be performed in contexts that do not perform color correction or others of the steps described above.
Certain implementations of the invention comprise computer processors which execute software instructions which cause the processors to perform a method of the invention. For example, one or more processors in a display or in a system that generates driving signals for a display may implement the method of
The invention may also be implemented in suitably configured logic circuits such as suitably configured field-programmable gate arrays and/or hard-wired logic circuits. In an example embodiment, such logic circuits are provided in a timing controller board (TCON) for a panel display such as an LCD panel or in an image (or video) processing board or in an intermediate system imposed in a signal path between an image processing component and a TCON.
Where a component (e.g. a software module, processor, assembly, device, circuit, etc.) is referred to above, unless otherwise indicated, reference to that component (including a reference to a “means”) should be interpreted as including as equivalents of that component any component which performs the function of the described component (i.e., that is functionally equivalent), including components which are not structurally equivalent to the disclosed structure which performs the function in the illustrated exemplary embodiments of the invention.
As will be apparent to those skilled in the art in the light of the foregoing disclosure, many alterations and modifications are possible in the practice of this invention without departing from the spirit or scope thereof. Accordingly, the scope of the invention is to be construed in accordance with the substance defined by the following claims.
This application claims priority to U.S. Patent Provisional Application No. 61/228,427, filed 24 Jul. 2009, hereby incorporated by reference in its entirety.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US10/42052 | 7/15/2010 | WO | 00 | 1/12/2012 |
Number | Date | Country | |
---|---|---|---|
61228427 | Jul 2009 | US |