The embodiments described herein relate generally to electronic image and video processing, and in a particular relate to color and brightness non-uniformity correction for backlit LCD panels.
Light Emitting Diodes (LEDs) are semiconductor diodes made of special material that radiate visible and invisible light (covering infrared to ultraviolet range of electromagnetic spectrum) upon spontaneous recombination of electrons and holes in the p-n junction. A forward biased voltage is normally applied to the p-n junction to accelerate the electron-hole recombination and produce sufficient brightness. The wavelength (and therefore color) of the emitted light depends on the energy of the semiconductor band gap. Early LEDs emitted low intensity red lights. Only recently have new semiconductor materials been available with larger energy gaps allowing LEDs to emit green and later on blue lights. Further, advancements in increasing the brightness and efficiency of LEDs have led to the invention of white LEDs.
A liquid crystal display (LCD), commonly used for TV panels and computer monitors, utilizes the light modulating properties of liquid crystals (LCs). LCs are transmissive elements. They merely guide and do not emit light directly. Therefore, LCD panels produce no light of their own and require an external lighting mechanism to be visible. Conventionally, a Cold Cathode Fluorescent Lamp (CCFL) situated behind the LCD panel, have provided the lighting. More recently, with advancements in HD TV and higher frequency video contents, LED backlit LCD panels have appeared in the television industry as an alternative to CCFL backlit LCDs. There are two kinds of LED backlighting techniques, white LED backlighting and Red/Green/blue (RGB) LED backlighting. A white LED (widely used in notebooks and desktop screens) is actually a blue LED combined with yellow phosphor to give the impression of white light. The spectral curve has big gaps in the green and red parts, in this case. RGB LEDs consist of a red, a green, and a blue LED and can be controlled to produce different temperatures of white. RGB LEDs can deliver an enormous color gamut to screens. The backlight from three separate LEDs can produce a color spectrum that closely matches the color filters in the LCD pixels themselves. This way, the LCD color filter pass-band can be narrowed so that each color component lets only a very narrow band of spectrum through the LCD. That improves the power efficiency of the display since a minimal amount of light is blocked when white is displayed. Also, the actual red, green, and blue points can be moved farther out so that the display is capable of reproducing more vivid colors. Both types of LED backlights can be arranged in arrays to light a screen.
LEDs present many advantages over incandescent light sources including larger color gamut, higher luminous efficiency, deeper black level (higher contrast), lower energy consumption (reduced waste light), longer lifetime, improved robustness, smaller size, faster switching response, and greater durability and reliability. In view of the demands for lower cost and power, lower environmental impact (green) and thinner displays, the industry has undertaken a major effort of improving the backlight technology by a rapid transition from the older CCFL backlighting to the more efficient and flexible LED backlighting. The U.S. Pat. No. 6,888,529 discloses an example of such system wherein an array or banks of RGB LEDs are driven by special circuitries to deliver light to each pixel of the display. The intensity and color content can be adjusted at source by manipulating individual color components directly through the driving circuits.
There exist however several drawbacks of LED sources. The most major drawback is increased color and brightness non-uniformity, due to the fact that LEDs are discrete light sources. Because of the variation in the manufacturing of LEDs and in LED aging, with each LED aging at a different rate, the uniformity is significantly decreased in relation to CCFL backlighting. A wide screen TV has a large number of LEDs (order of 100s) that are needed for a display in comparison with small number of CCFL tubes (order of 10s). Each individual LED has a different level of brightness. Even with sorting and binning, these light sources can have as much as +/−10% variation in brightness, device to device. Further, the use of three separate light sources for red, green, and blue means that the white point of the display can move as the LEDs age at different rates. Aging also occurs with White LEDs, with changes of several 100K of color temperature. White LEDs may suffer from blue shifts at higher temperatures too. As a result, they require more precise current and heat management than traditional light sources, therefore more expensive to build. In fact, if a certain level of uniformity is not achieved, the display will be rejected after production causing loss for the manufacturer.
In recent years, Organic Light Emitting Diodes (OLED) have been used in TV screens and other displays as an alternative to LCDs. Unlike an LC element, an OLED is an active element wherein lies an emissive electroluminescent layer of organic semiconductor compounds which emit light in response to an electric current. This layer is a thin film situated between two electrodes, one of which is normally transparent. The organic compounds are either small molecules or polymers that allow OLEDs to be used directly as display pixels. Thus an OLED display functions without a backlight. In another word, the backlight and the modulator planes are the same.
In general, an image from a display, LCD, OLED or otherwise, is a spatial varying pattern of color and brightness, which aims to match the pattern of an input signal. If the input signal is spatially constant, then its reproduction by a display is expected to be constant in color and brightness. This is referred to as the requirement of color and brightness uniformity, which is a critical requirement for accurate color reproduction by a display. An LCD panel has several other components including light guides and diffusers meant for directing and evenly distributing the light towards the front. Although these elements help improve uniformity, their design becomes complicated with a decreasing panel thickness trend, in turn leading to reduced effectiveness. There is a need for alternative methods of color and brightness adjustments in order to address the abovementioned shortcomings in a more effective and affordable manner.
There exists some prior art solutions on improving the quality of the backlighting mainly by manipulating the source voltage after sensing or visualizing the output signal. These solutions address uniformity in view of primarily the backlight panel, and not the LC panels where the image is actually viewed, therefore have limited effectiveness. For example US 2007/0200513 discloses means for controlling LED drives in response to changes in temperature and voltages. US 2006/0007097 discloses a backlight adjustment method for an LED backlit LCD apparatus. Luminance measurement sensors are integrated with the LCD panel by being disposed on a substrate together with thin file devices as pixels in the panel. None of these addresses the non-uniformities as a viewer would observe. Further, no solution for adjusting the chromaticity of the signal has been provided.
It is an object of one or more aspects of the present invention to provide electronic means for improving color and brightness uniformity of LCD displays addressing simultaneous adjustment of both the backlight source and the LC the light modulators. All aspects of the invention related to the modulator are applicable regardless of the light source.
In one embodiment, LEDs provide the backlight. Not only is the non-uniformity due to aging LEDs addressed, but the present approach can help manufactures in cost savings by having fewer units and tolerating units that would otherwise have failed the thresholds and been discarded. The teachings are also applicable to traditional CCFL backlight sources consisting of a plurality of CCFL tubes.
In another embodiment, Laser Diodes (LDs) are used as the backlighting source. LDs work in a similar fashion as LEDs when used to backlight LCD panels. The principal difference is in light generation where the recombination of electrons and holes occurs as stimulated rather than spontaneous, which is of course a necessary condition for lasing in general. The wavelength spectra of LDs are much narrower than that of the LEDs and result in even more well-defined colors.
The light source components and related figures presented herein primarily illustrate a direct LED backlighting system as an exemplary embodiment. However, as far as the displayed light is concerned, as mentioned, the invention is applicable to edge-lit LEDs, LDs and CCFLs as well as OLEDs (OLEDs being a special case of direct LED).
The embodiments described herein provide in one aspect, a method for improving color and brightness uniformity of a backlit Liquid Crystal Display (LCD) by studying the measurable physical outputs from the display, and efficiently creating correction maps to modify pixel values of the display. Further, voltage controls for the components of the backlight source can be modified within the same framework.
The embodiments described herein further provide in another aspect a system for improving color and brightness uniformity of a backlit LCD. The system comprises an image generator for displaying a plurality of reference input images on the display; an image capture device to measure the uniformity of the displayed images characterized by physically measurable quantities; a processor to generate a global display response function from the measured data and create a correction grid data map such that the response function becomes a constant value across the display; and a second processor to convert the correction grid data map into a functional form, and apply the correction functions to the input signal. The backlight source can be generated using various technologies, such as a set of LEDs, CCFLs, and Laser Diodes.
The embodiments described herein further provide in another aspect a system and method for improving color and brightness uniformity of an Organic LED (OLED). That is a special LED case wherein the backlight source and the display are essentially one integrated unit, making brightness and color non-uniformity issues even more relevant.
For a better understanding of the embodiments and/or related implementations described herein and to show more clearly how they may be carried into effect, reference will now be made, by way of example only, to the accompanying drawings which show at least one exemplary embodiment and/or related implementation in which:
It will be appreciated that for simplicity and clarity of illustration, elements shown in the figures have not necessarily been drawn to scale. For example, the dimensions of some of the elements may be exaggerated relative to other elements for clarity. Further, where considered appropriate, reference numerals may be repeated among the figures to indicate corresponding or analogous elements.
It will be appreciated that numerous specific details are set forth in order to provide a thorough understanding of the exemplary embodiments described herein.
However, it will be understood by those of ordinary skill in the art that the embodiments and/or implementations described herein may be practiced without these specific details. In other instances, well-known methods, procedures and components have not been described in detail so as not to obscure the embodiments and/or implementations described herein. Furthermore, this description is not to be considered as limiting the scope of the embodiments described herein, but rather to describe the structure and operation of the various embodiments and/or implementations described herein.
Uniformity is defined as the variation of brightness and color across a display in response to a set of flat input signals. A flat signal or level is one where all pixels (x,y) are assigned a constant digital RGB value:
(R(x,y),G(x,y),B(x,y))=(R0,G0,B0), For all (x,y) (1)
Where R(x,y) refers to the value of the R (red) component at the pixel position (x,y) and similarly for G (green) and B (blue). The pixel positions (x,y) are integer values, meaning column x and row y, and range over the resolution W×H of the display, where W is the horizontal resolution and H is the vertical resolution:
0<=x<=(W−1) and 0<=y<=(H−1) (2)
However in the mathematical formulation disclosed herein, (x,y) are allowed to range over any real numbers. The pixel color values (R0, G0, B0) are integers taking values in [0, 2bn−1], where bn is the bit depth of the display, e.g. 8, 10, etc. In the internal computations, the color values are allowed to be any real values, and are adjusted to the permitted integer range when being input as a signal to the display.
The uniformity of brightness and color is defined in terms of measurable physical quantities. Various different measurable quantities have been defined to describe brightness and color. The most widely used are the Commission Internationale de L'Eclairage (CIE) XYZ tristimulus values, from which all other relevant quantities can be computed. The Y components is the luminance value, also denoted L in the art, that represents what is commonly referred to as brightness or intensity, and has units of candela/m2 (cd/m2).
Minimizing variations in the luminance are most critical to obtaining a uniform display. The X and Z components are additional color quantities required to correctly define the color, their measured units are also cd/m2. Color for displays, with luminance factored out, is more easily understood in terms of the chromaticity values, rather than XYZ. The chromaticity components (xc,yc) are derived quantities given by:
Since in color science (x,y) is normally used for the chromaticity values, the c subscript is included in the notation to distinguish the chromaticity values form the spatial pixel coordinates (x,y). The z-chromaticity zc is not an independent variable and hence not used. A color's chromaticity values are plotted as coordinates on the CIE chromaticity diagram, and define the pure aspect of color, with component of brightness or luminance is decoupled. Thus XYZ and xcycY can be viewed as two orthogonal coordinate systems that fully define the brightness and the pure color aspect of any displayed color. Whereas XYZ is often the measured quantity, xcycY is a quantity that is normally used to describe a color. Typical chromaticity values (xc,yc) for the RGB primaries in a display are in the vicinity of (0.640,0.330) for R, (0.300,0.600) for G and (0.150.0.060) for B. The white D65 reference has a chromaticity of (0.3127, 0.3290). Chromaticity of pure white (or the grey levels) is also referred to as color temperature or the white point. Most color measurement instruments report XYZ values as well as the chromaticity values.
Therefore, in this space uniformity, or alternatively non-uniformity, for a measured component M={X,Y,Z,xc,yc} at a specific level (flat signal) can be defined as:
% Uniformity=100*(1−(Mmax−Mmin)/Mmax)
% Non-uniformity=100−% Uniformity (4)
where Mmax and Mmin are the maximum and minimum values of the measured component across all pixels (i.e. all (x,y)) in the display, at a specific level. In particular, luminance (brightness) uniformity is given by:
% Luminance Uniformity=100*(1−(Ymax−Ymin)/Ymax)
% Luminance Non-uniformity=100*(Ymax−Ymin)/Ymax (5)
In practice, uniformity is computed by measuring M at a subset of pixels as opposed to every pixel. Both terms uniformity and non-uniformity are used herein with understating that they are merely two different views.
An ideal uniform display will have the same measured XYZ values across all pixels, for any flat signal. This would be 100% uniformity across all levels, which is not achievable in practice. The goal of a correction technique is to improve uniformity to within acceptable limits. For example, in consumer displays, having luminance uniformity levels of >=70% for pure white (level R0=G0=B0=255 for 8 bits) is often viewed as sufficient. Uniformity in other components is not considered. The present approach provides with means for obtaining a much higher uniformity across multiple levels in an efficient manner, which is often necessary for professional displays and can also serve to raise the standard for consumer displays. Furthermore uniformity in both luminance and chromaticity is addressed. Since color temperature or white point is a subset of the chromaticity values, color temperature and white point correction are automatically corrected once chromaticity has been addressed.
Once the non-uniformities are quantified and so obtained, they can be electronically corrected. The co-pending patent application Ser. No. 11/649,765 describes a hardware system for applying both color and geometry corrections.
The sources of non-uniformity in an LCD display can be classified as two groups: a) those due to non-uniformities in the backlight panel (light source) and b) those due to non-uniformities in the LC panel (light modulator). This implies that uniformity correction may proceed by adjusting the variable controls of either the backlight panel or the LC panel, or in the most general case, adjusting the controls of both the backlight and LC panels.
In the exemplary case of LED backlighting, the variable controls for the backlight panel are the voltages applied to the LEDs. Other components, such as diffusers are fixed and not variable. We will denote these voltages as a vector:
Where Vi is the voltage at the i-th LED, and L is the total number of LEDs. If a common voltage is applied to all LEDs, then all components would have the same value. The notion and mathematics is also applicable to CCFL and LD backlit panels with i referencing the tubes.
The variable controls for the LC panel are the individual pixel digital RGB values, which is the input digital signal itself. The following notations are used interchangeably to indicate the pixel values:
(R(x,y),G(x,y),B(x,y)), or
{right arrow over (C)}(x,y)=(C1(x,y),C2(x,y),C3(x,y)),{1,2,3}={R,G,B} (7)
If a flat level is used then the pixel position (x,y) dependency is dropped:
(R,G,B), or {right arrow over (C)}=(C1,C2,C3) (8)
Mi(x,y,{right arrow over (C)},{right arrow over (V)}) (9)
As indicated, the measured value depends on the pixels position (x,y) due to the non-uniformity, the flat signal {right arrow over (C)} and the voltage values {right arrow over (V)} of the backlight sources. For each backlight setting, all light source components are usually set to a common value during the measurement step. If only brightness is being corrected, then only the luminance value Mi=Y will be measured. For a uniform display, Mi would be constant across pixels and independent of (x,y). The objective of the non-uniformity correction is to bring this generally variable quantity to a spatially constant value
From the measured data 42, the response of the display to an arbitrary RGB signal is reconstructed 43. This response is denoted as a Function 44 to be used in computing the correction. Each physical quantity has its own response, allowing the measured data to be written as a function:
Mi=Fi(x,y,{right arrow over (C)},{right arrow over (V)}) (11)
The re-calibration stage 45, determines the correction in the signal {right arrow over (C)} and voltage {right arrow over (V)} required to have a uniform measurement. It seeks a solution to a constant:
Where {right arrow over (C)}′ is the new signal, or new pixel values, which due to the non-uniformity vary in (x,y) and depends also on the input pixel value. {right arrow over (V)}′ is the new voltage setting for the LEDs, which may also depend on the pixel value. As will be shown however, it is possible to make {right arrow over (V)}′ pixel value independent. The solution is essentially computing an inverse in multiple-variables:
{{right arrow over (C)}′,{right arrow over (V)}′}=Fi1(
The non-uniformity correction can therefore be written as:
{right arrow over (C)}→{right arrow over (C)}′(x,y,{right arrow over (C)},{right arrow over (V)})
{right arrow over (V)}→{right arrow over (V)}′({right arrow over (V)}′,{right arrow over (C)}) (14)
The computation of {{right arrow over (C)}′, {right arrow over (V)}′} is done at a subset of coordinates in the (x,y,{right arrow over (C)},{right arrow over (V)}) parameter space known as grid points. For example (x,y) may be a subset of 17×17 pixel positions in a 1920×1080 resolution display. There are various reasons for that, among them:
As such, the computation provides a correction grid data 46. Correction reconstruction stage 47 converts the correction grid data 46 into functional form so that it can be applied to all pixel positions and color values. Analogous to equation (11) one obtains the correction functions 48:
{right arrow over (C)}′={right arrow over (F)}C(x,y,{right arrow over (C)},{right arrow over (V)})
Vi′=FV(i,Vi,{right arrow over (C)}) (15)
The function Fv provides the new voltage levels at the i-th LED given its initial voltage and the input pixel value. The correction function Fc is referred to as the pixel correction map or pixel map for short, and the correction function Fv is referred to as the backlight correction map or backlight map for short. The form of the correction functions may be determined by the hardware that will apply the correction to the display. A general hardware efficient form is described in the U.S. Pat. No. 7,324,706 where a set of data points is represented using a polynomial surface functional form.
At the final step 49 the correction maps are applied to the input signal and backlight controls using a hardware circuit. The hardware evaluates the maps and sends the new pixel values to the display controller and the new voltage values to the backlight controller. The co-pending patent application Ser. No. 11/649,765 describes a hardware system 100 (
The non-uniformity correction procedure 40 steps provide a highly efficient and accurate method for correcting brightness and color non-uniformity in LCD displays.
The measurement of physical quantities 41 is normally performed using a colorimeter or a spectroradiometer. These devices 52 come in two forms: spot meter types, and 2D imaging camera types. A spectroradiometer is usually a spot meter that measures physical quantities at a given point or pixel. A specific pixel can be measured or an average value in a defined neighborhood of a specific pixel can be measured. Spectroradiometers are very accurate devices and are often used in calibrating colorimeters. Colorimeters are available either as spot meters, in which measurements are performed at or about a single point, or as a 2D imaging camera. In the latter form, the colorimeter can take a picture of the display and simultaneously measure a very large number of pixels in the 2D (x,y) position space. The user may specify the pixel positions to measure. Normally a regular grid of points, denoted as Ny rows by Nx columns, are extracted from the 2D camera image for computation. Similar to the spot meter, the camera performs an averaging over a small defined neighborhood of the measured pixels. In a preferred embodiment, a 2D camera type of colorimeter is used for the measurement, because non-uniformity, by definition, is a measurement over the 2D (x, y) positions. In addition, the pixel neighborhood averaging process of the colorimeter lends itself well to characterizing non-uniformity, since visual perception does not detect individual pixels (with the exception of “broken” pixels); rather it averages over neighboring pixels. A spot colorimeter could be used for precision measurement of a 2D grid of points. This however would require physically moving the spot meter across the display, and is time consuming unless a small number of points are measured. Use of multiple spot meters is possible but costly. Regardless, the method is independent of any specific measuring instruments, only requiring that a grid of data points, sampled in both the x and y direction, be measured. Both the 2D and spot colorimeters are able to measure all relevant physical quantities, such as XYZ tristimulus values. In an exemplary discussion that follows, the term camera refers to a 2D colorimeter.
The measurement process further requires selecting a set of flat reference signals 51 (also referred to as signal levels or levels) to be input to the display. A set of required levels can be manufactured or provided using commercially available tools, such as a test pattern generator. The number of levels to measure, and their corresponding pixel values, depends on several factors including:
The reference levels are considerably reduced in number by utilizing the color superposition principle. In terms of the XYZ values, this principle states that the color produced from the combination of two independent color sources in an additive color system (such as an LCD), has its tristimulus values given by the sum of the tristimulus values of the two sources. In equations:
Color New=Color1+Color2
Color1: (X1,Y1,Z1), Color2: (X2, Y2, Z2)
Color New: (X,Y,Z)=(X1+X2,Y1+Y2,Z1+Z2) (16)
A displayed image on an LCD consists of 3 independent color components, R, G and B. The superposition principle implies that the tristimulus values of any color (R, G, B) can be computed by adding the tristimulus values of the R, G and B components:
X(R,G,B)=XR+XG+XB
Y(R,G,B)=YR+YG+YB
Z(R,G,B)=ZR+ZG+ZB (17)
Therefore a display's uniformity can be fully characterized by measuring levels of pure red, pure green and pure blue, pure meaning other components are turned off (pixel value of 0). Any combination color, including grey levels, can be achieved by the appropriate sum of the individual components (R, G, B). Let NC, C={R,G,B}, denote the number of pure levels of component C. The levels to measure, in the most general case of correcting brightness and color across all pixel color values, are then:
Pure Red Levels: (R,G,B)=(Ri,0,0), i=1 . . . NR
Pure Green Levels: (R,G,B)=(0,Gj,0), j=1 . . . NG
Pure Blue Levels: (R,G,B)=(0,0,Bk), k=1 . . . NB
0≦Ri,Gj,Bk≦2h
bn indicating the number of bits (e.g. 8). In practice, when turning the two components off for a pure color (by setting pixel value 0), there continues to be leakage of light from the backlight through the turned off liquid crystals and their filters. This breaks equation (18) by a small, yet not negligible amount. This leakage is referred to as the black level offset. It is a measure of the amount of light that leaks through when all pixels are set to 0 (R=G=B=0). To correct for the black level offset, and as a test of the superposition principle, the pure grey levels where (R=G=B), are also measured. In fact, if only luminance correction is being done, it is often sufficient to measure the pure grey levels only. Therefore a Nw number of pure greys are also added to the reference levels for measurement:
Pure Grey Levels: (R,G,B)−(Wl,Wl,Wl), l=1 . . . NW
0≦Wl≦2b
Wl indicates the common pixel value assigned to each color components for a pure grey level. The set of levels to measure, in the most general scenario, are summarized as:
{{right arrow over (C)}}={{(Ri,0,0)},{(0,Gj,0)},{(0,0,Bk)},{(Wl,Wl,Wl)}}
i=1 . . . NR; j=1 . . . NG; k=1 . . . NB; l=1 . . . NW (20)
In practice, a much smaller subset may be measured depending on the factors discussed above.
In addition to data at different levels, measured data at different backlight voltage settings is also needed. In principle, for each level, the voltage for each LED should be independently varied and the tristimulus Point Spread Functions (PSF) measured. Thus, PSF refers to the spread of the light in (x, y) space for a single LED. In practice, it is difficult and time consuming to vary individual LED and determine how the tristimulus values change in voltage and (x, y) space. Instead the voltage settings are changed to common values for all LEDs, and the tristimulus quantities are measured to determine the voltage dependence. This essentially neglects the (x, y) dependence contained in the PSF. The different voltage settings are indicated by:
V
si
, i=1 . . . NV
At i-th setting: V1=V2= . . . =VLVsi (21)
The same setting is applied to all LEDs for a given voltage. The common voltage Vsi is also referred to as the common or initial backlight setting. It should be viewed as a backlight control, which determines a common state for all the voltages. Such a control is often provided in a display OSD. In (21) the voltages are set equal to this control but the control may be a normalized quantity, directly proportional to the LED voltages. The LED voltages are varied to provide higher or lower light intensity (luminance) in areas of non-uniformity, as will be described below. They may also be varied for adjusting color uniformity in the case of RGB LEDs. In practice however, this is not reliable since chromaticity correction is more subtle and requires finer control. Therefore chromaticity correction is better handled by the pixel map. In particular RGB LEDs may be viewed as a unit on the same footing as white LEDs, in terms of voltage variation. We use this to simplify the equations below, though the approach may easily be extended to have independent RGB voltage control.
To generate the backlight correction map, it is also necessary to know the PSF function, which specifies how the light from a single LED spreads out in (x, y) space. A single LED will illuminate many pixels, and changing its voltage, via the backlight correction map, will affect many pixels. The PSF function can be measured at the backlight plane by turning on a single LED to its maximum value and capturing the intensity variation in (x, y). The PSF can also be approximated by appropriate mathematical models (such as Gaussian). Alternatively in the absence of a PSF function, an iterative approach can be used to compute the backlight correction map. Both scenarios will be discussed. In one embodiment the PSF is given (provided, estimated or directly measured). In another embodiment the PSF is not know. In the exemplary case of RGB LED backlighting, the light from the three LEDs combine to form a white light with a broad spectral distribution, incident on the LC panel. A single PSF, analogous to a white LED PSF, may be used to describe the joint effect of the 3 LEDs, if the individual LEDs are not independently adjusted to vary the chromaticity of the white light. This is similar to viewing them as a unit from the voltage adjustment standpoint.
For the embodied system depicted in
From the camera captured images, the physical quantities can be extracted for essentially all pixels. Although the resolution of the camera restricts the number of pixels that can be accurately measured, this number is much greater than the number of data points usually required. All colorimeters are equipped with software for extracting data for any set of user specified grid points. Data is available for all pixels, but a much smaller subset is normally used for computation since uniformity is a smoothly varying function that gradually changes over a large number of pixels and not on a per pixel basis. The pixel positions at which the measured data is obtained, taking a regular grid of Ny rows by Nx columns, are denoted:
Pixel at measured column a, row b:(xa,yb), a=1 . . . Nx, b=1 . . . Ny (22)
In one exemplary setting, for the purpose of illustration, a 2D colorimeter PM-1423F by Radiant Imaging Inc was used. The measured data 42, in part, is displayed in various plots. All tristimulus quantities are in units of cd/m2.
Measured Levels: {32,64,96,128,160,192,224,255} (23)
For a given level, the values measured at the different pixels are seen as being displaced vertically from one another (i.e. Y varies from pixel to pixel). If there was no non-uniformity, all grid points for a given level would be coincident.
The non-uniformities in the tristimulus values are quite large, with luminance being only 58.73% uniform across the display. The uniformity numbers for the chromaticity coordinates are misleading (hence the **) and seem to suggest that the color is uniform. Since the chromaticity values are of the order ˜0.3, the % uniformity values computed from eq. (4) tend to be large, even if there is significant non-uniformity. For chromaticity, variations of the order 0.02 can be visible. Therefore it is much more accurate to look at the tristimulus values, where non-uniformity in X and Z will lead to perceptually significant non-uniformities in the color. In a similar manner, non-uniformities can be computed at all measured levels. This particular measured display has a significant amount of non-uniformity in both luminance and color, which is typical of LCD displays. The data from this exemplary experiment is herein used to describe in detail the various embodiments of the invention with reference to
For varying backlight voltage settings, example results can be seen in the plots of
With the physical measurements completed, the next step is reconstructing the display response 43 and determining the response functions 44. This essentially means converting the discrete measured grid data 42 to functional form (11), so that the correction can be computed for all levels, all LED voltage settings and all pixel positions. The different response functions 44 are first defined. Each physical quantity XYZ, has an independent response function 44 (i=X,Y,Z):
Fi(x,y,{right arrow over (C)},{right arrow over (V)}) (24)
The response function 44 can be decoupled into two components. From the architecture on an LCD display, as shown in
Fi(x,y,{right arrow over (C)},{right arrow over (V)})=FiP(x,y,{right arrow over (V)})×FiP(x,y,{right arrow over (C)}) (25)
Furthermore, the product form of (25) implies that the response can be studied at a fixed voltage, and then these fixed voltage responses “connected” functionally in the voltage parameter. The connection can be made at the correction stage. Thus the responses required are for each dataset at a given voltage:
Fi(x,y,{right arrow over (C)}), computed for each setting of {right arrow over (V)} (26)
Further reduction is possible by making use of the fact that each pixel behaves independently in an LCD display and is not affected by neighboring pixels. The correction at a given pixel only depends on the response at that pixel. Therefore, the responses and correction can be computed for all pixels independently. The (x, y) dependence of the response can be dropped with the understanding that the following steps are computed at every measured pixel position:
Fi({right arrow over (C)}), computed for every measured pixel position (xa,ya) and each setting of {right arrow over (V)} (27)
Next the superposition principle can be employed to further simplify the response form. According to eq. (17), the XYZ response for any RGB color is a sum of the component responses for R, G and B. Let Fij be the response function 44 for measured quantity iε{X,Y,Z}, as a result of applying a pure level of jε{R,G,B}. Then (27) implies:
Fi({right arrow over (C)})=FiR(R)+FiG(G)+FiB(B), iε{X,Y,Z}
FiR—Red component response functions
FiG—Green component response functions
FiB—Blue component response functions (28)
Determining the response functions 44 is thus reduced to finding the 9 functions Fij, which follow the data described by the 2nd to 4th plots in
FY({right arrow over (C)})=FYW(W),{right arrow over (C)}=(W,W,W) (29)
The function (29) will follow the grey level data in the first plot of
X=FXV(V)—X response to backlight setting
Y=FYV(V)—Y response to backlight setting
Z=FZV(V)—Z response to backlight setting (30)
Whereas the pixel responses are at a fixed voltage, the backlight responses are at a fixed color level. For the most common corrections, backlight response for pure white only (
The simplification of the response functions 44 to (28) depends on the validity of the superposition equation (17). A black level offset due to light leakage is one factor that can break this equation, giving a superposition error. Another possible source of discrepancy is variations in the display RGB primaries or in the camera filters, from the ideal. Therefore it is important to adjust for these real variations before the responses are computed. To adjust for black level and other factors, the sum of the XYZ measured values for R, G and B, at each level, are compared with the XYZ measured values for the identical grey level (R=G=B=W), the differences due to non-ideal behavior, called the superposition deltas (ΔXS, . . . ), are:
ΔXS=XW−(XR+XG+XB)
ΔYS=YW−(YR+YG+YB)
ΔZS=ZW−(ZR+ZG+ZB) (31)
The differences of tristimulus values are seen in
The r-factors determine the spread of the superposition correction amongst the R, G, and B components, and can be made programmable. Setting them all to 0 implies no correction for superposition errors. As an example, the following spreading could be taken:
This spreading is based on the fact that X and Z are more weighted towards R and B respectively, whereas Y is more symmetric about G. The data with the black level offset correction applied is shown in
Having defined the various responses, the functions 44 can be computed using methods for data modeling. The two main methods relevant to the invention are: fitting or interpolation of data; and representing data using known mathematical models. However, it is understood that any data modeling method could also be used.
In the first method the data points are either fitted or interpolated by the response function 44. Fitting is preferred as it is less susceptible to measurement errors. Interpolation can be used if the data is known to be very accurate. In the current exemplary discussion, “least squares fitting” method is used to model the data. Commercial software packages are available that implement least squares fitting. The basis commonly used for the fit is a polynomial basis. In the present exemplary illustration, a cubic (3rd degree) polynomial fit to the data is made, but the degree is general (denoted d) in the equations. A variation of the fitting approach is to use a series of fitting functions; i.e. the response is locally represented by different fits. A piecewise linear function is an example. Since the correction at a given level is local (change is expected to be small), the function that best represents the response can be modified at different levels. A global function need not be used. A first polynomial may work best for a level (e.g. 255), but a different polynomial may be used for another level (e.g. 192).
The second method assumes a specific model based on known behavior of displays. This method is particularly useful if only a small number of data points are available or the data points are suspect. For LCD displays, the intensity is expected to behave as a power law. This lets one estimate the response functions 44 from as little as one measured level, at maximum red, green, blue or white. If the luminance at maximum white Wmax (255) is Ymax, then the response function (29) can be estimated using a power law function:
The power value, referred to as gamma γ, is approximately 2.2. Real systems deviate from eq. (34), hence if accurate data is available a fit is preferred to be used. Nevertheless, eq. (34) or a similar mathematical model is often the best solution given the constraints of speed and limited measurements. In (34), the non-uniformity is implicit in the variation of Ymax across pixels. A variable black offset Y0 can also be added to the model in (34), which gives a model matched to W=255 and W=0.
The two methods can also be used in combination. It may be that correcting one level, better results are obtain with a fit, and at another level the power law is best.
Assuming the sufficient data available, cubic fits of the first method are made to determine the response functions 44. These have been plotted in
FiR(R)=Σn=0daRniRn
FiG(G)=Σn=0daGmiGn
FiB(B)=Σn 0daBniBn
FYW(W)=Σn 0daWnYWn (35)
These functions are computed at every measured pixel position (xa, yb). Similarly the backlight response functions are generated by fitting the data in
FXV(V)=aV1XV+aV0X
FYV(V)=aV1Y+aV0Y
FZV(V)=aV1ZV+aV0Z (36)
The quantities aVni are the linear fitting coefficients. These responses are also calculated at all measured pixel positions.
The global response functions shown in
In this example, Rmax=255 the maximum 8 bit pixel value. This assumes no local maxima/minima between the global maxima/minima, which is usually the case. The function (37) can be normalized to values of Z0 and Z1 at 0 and Rmax by:
This is sometimes useful in computation to bring the data at R=0 to 0. In what follows, any adjustments for non-monotonicity are assumed to be implemented if necessary and the same notation is used.
The response functions (35) and (36) fully characterize the display for all levels and backlight settings. The next step, the re-calibration stage 45, is to use these responses to build the correction grid 46. The correction grid provides a new set of RGB values at each measured point, which would result in physical quantities or responses that are constant in (x, y), i.e. uniform across the display. The measured values will only depend on the level {right arrow over (C)} and backlight setting {right arrow over (V)} (see eq. (10)).
The uniform values sought are computed from the measured data. The most common selections are to take the average, the minimum or maximum. Let Mab denote any measured quantity {X,Y,Z,xc,yc}, measured at pixel position (xa, yb), then the required uniform quantities can be written as:
These quantities are computed for each level {right arrow over (C)}=(R,G,B) and voltage {right arrow over (V)}, however to keep the notation simple, this dependence is not explicitly shown. In the examples presented, the average and minimum values will be used. The bar notation {
For a fixed voltage, the re-calibration step 45 is formulated as follows. Given a fixed level {right arrow over (C)}=(R,G,B) (or {right arrow over (C)}=(W,W,W) for luminance correction of grey levels only), find the new pixel value {right arrow over (C)}′=(R′,G′,B′) (or W′), dependent on the position, which results in a uniform response, independent of position. Note that the level being corrected need not be one of the levels that were measured (18), since the response for all RGB values has been computed in (35). In mathematical terms, a solution is required to the following system of non-linear equations:
I) Luminance+Color Correction for General Level:
(R,G,B)→(R′,G′,B′)
R′=R+ΔR, G′=G+ΔG, B′=B+ΔB (40)
II) Luminance Correction for Grey Level Only:
W→W′ (42)
The (x, y) spatial dependence is implicit in that the coefficients depend on (x, y), i.e. the above system is solved for every pixel position (xa, yb). The new values (R′,G′,B′) are expected to differ not significantly from (R,G,B). The notation (ΔR, ΔG, ΔB) denotes the change in pixel value, in terms of which the equation system can also be expressed and solved. For LCDs, it is standard practice to report luminance and chromaticity (xcycY), instead of XYZ. Both descriptions are equivalent and conversion between the two is handled via eq. (3). Similar expressions for (41) in terms of xcycY are:
Wherein the m=1, 2, 3 index corresponds to R, G, B respectively, C1′=R′, C2′=G′ and C3′=B′, and (
The expressions on the right hand side of (45) can be viewed as “response” functions for the chromaticities, however they do not follow the simple superposition (addition) principle in terms of the component RGB chromaticities. Hence the approach presented here, whereby response functions are defined in terms of XYZ, and chromaticities computed afterwards, is a more efficient and tractable method. Both equations (41) and (44) define a system of three non-linear equations that need to be solved for (R′,G′,B′). This will give the correction grid 46 once computed for all positions, levels and voltages.
An alternative formulation (of (41) and (43)) can be written directly in terms of the XYZ tristimulus values. First define the inverse response functions:
fcX≡(FXc)1, fcY≡(FYc)1, fcZ≡(FZc)1, c=R,G,B (46)
These are the inverses of the responses (35), and can be computed by inverting (35), or by fitting RGB levels as a function of measured XYZ instead of measured XYZ as a function of RGB levels. Also using the notation (C=R,G,B):
XC: Measured X value for component C at level C=FXC(C)
XC′: Required X value for component C at level C for uniformity
YC: Measured Y value for component C at level C=FYC(C)
YC′: Required Y value for component C at level C for uniformity
ZC: Measured Z value for component C at level C=FZC(C)
ZC′: Required Z value for component C at level C for uniformity (47)
The system of equations (41) become:
0=fRX(XR′)−fRY(Y′R)
0=fRY(Y′R)−fRZ(Z′R)
0=fGX(XG′)−fGY(Y′G)
0=fGY(Y′G)−fGZ(Z′G)
0=fBX(XB′)−FBY(Y′B)
0=fBY(Y′B)−fbZ(Z′B) (48)
This is a system of nine non-linear equations for nine unknowns (XC′,YC′,ZC′). The last six set of equations impose the constraint that the real independent variables are still RGB, hence the inverse responses must equal. Having solved (48), the new RGB values are given by:
R′=fRX(XR′)=fRY(Y′R)=fRZ(Z′R)
G′=fGX(XG′)=fGY(Y′G)=fGZ(z′G)
B′=fBX(XB′)=fBY(Y′B)=fBZ(Z′B) (49)
Equations in terms of chromaticity coordinates, analogous to (48), can also be obtained. Since this formulation hides the RGB dependence, it is preferred to work with (41) and (43) instead. Nevertheless, it should be noted that both are equivalent.
Equation (41) describes a system of 3 non-linear equations in 3 variables and can be solved using known non-linear numerical optimization routines. This however is not easily implemented for real-time computation. By using an appropriate linear approximation, (41) can be converted to a linear system that can be quickly solved. Recall that (41) needs to be solved for each level being corrected. The new values are expected to be in the neighborhood of the level being corrected. In particular, the deltas (ΔR, ΔG, ΔB), should be small, and the response functions can be locally approximated as linear functions in the deltas. Thus for correcting level (R,G,B), expand the responses as:
Equation (41) then becomes a 3×3 linear system of equations:
AXYZ×
Where:
This is solved by inverting matrix A, giving the new RGB values as:
Linear approximation to the chromaticity based equation (44) can also be computed, where (44) becomes:
AxyY×
where:
All quantities in AxyY and {right arrow over (b)}xyY are known, and again the solution is obtained by inverting the matrix:
Either the XYZ based solution (53) or xcycY based solution (56) may be used. The RGB values obtained will differ slightly due to the fact that (
The equations derived provide the full correction, for both brightness and color. If only brightness for grey levels is to be corrected, which is often sufficient for many consumer displays, then the re-calibration step 44 is simplified to solving (43) only. This is a single non-linear equation in a single variable, and can be solved using standard polynomial root solving routines. Alternatively, one can fit W as a function of Y, that is the inverse response fWY≡(FYW)−1 analogous to (46), and directly read the W′ value by evaluating fWY(W′). Care needs to be taken with monotonicity and finding solutions outside the domain. A further simplification is obtained if the response is as in (34), then an explicit formula for the re-calibration step 44 can be obtained:
For scenarios where speed is critical and data is limited, eq. (57) provides a quick approximate solution for correcting grey level luminance.
The solutions (56) are computed for all levels being corrected at all pixel positions (xa,yb). For each corrected level, this provides a set of grid points, called the correction grid 46, in (x, y) space, which are denoted as:
{(R{right arrow over (C)}ab′,G{right arrow over (C)}ab′,B{right arrow over (C)}ab′)} (58)
The {right arrow over (C)}ab subscripts indicates that this is the corrected RGB value for input color (level) {right arrow over (C)} at position (xa,yb). For a pure grey level luminance correction one similarly has the correction grid:
{WWab′} (59)
The subscript W in (59) indicates the grey level (W,W,W). Each component (RGB) will plot as a 2D surface over (x, y) space for each corrected level. In practice, majority (>90%) of brightness and color correction focuses on correcting grey levels. Thus the illustration in
In the exemplary embodiment described so far, all computations have been performed at a fixed backlight setting applied to all light source components (e.g. individual LEDs), also called the common or initial backlight setting. Therefore, the correction has been a pure pixel correction, with only the digital signal values being modified. If this is sufficient to obtain the required uniformity, then the backlight voltage need not be adjusted. For level 192 (
In case of the backlight adjustment, a backlight correction is required that proceeds as embodied herein. The correction is made at a specific voltage level V, which is also called the input or global backlight setting, or simply backlight setting, and may be in some normalized units. The common voltage V is applied to all pixels. The pixel correction (58 or 59 as an approximation) is determined for grey levels 255 and 0 at backlight setting V. If there are no pixels out of range, then the backlight correction is an identity, i.e. the voltage is not modified from V. Note this would depend on what uniformity metrics were used from (39). From the computed values (58), those points at which the RGB component values go out of range are identified. These are labeled as (using 8 bit values as an example):
Level {right arrow over (C)}=(0,0,0):(xa0,yb0)ε{(xa,yb), a=1 . . . Nx, b=1 . . . Ny}
such that one or more of the following: RĊāb′<0, GĊab′<0, BĊab′<0
Level {right arrow over (C)}=(255,255,255):(xā255,yb255)ε{(xa,yb), a=1 . . . Nx, b=1 . . . Ny}
such that any one or more of following: RCāb′>255,GĊab′>255,BĊab′>255 (60)
The required uniformity levels, also used in computing (60), will be labeled as
Next the backlight response functions (36) (shown in
At(xa0,y
At(xā255,yb255):
Increasing the voltages leads to increasing luminance, with minor changes in chromaticity if any; hence we consider only the Y values in determining the new voltage levels. The solutions, denoted {Va
Note the response functions depend on the pixel positions, and we have added additional labels to the function coefficients to indicate this. Also the backlight responses for levels 0 and 255 need to be used when solving for Va
For most corrections, the two sets of positions do not coincide. The positions of the Va
The values (63) provide the voltage settings required at specific pixels positions. In general these do not correspond to the LED positions. The pixel resolution number is much larger than the LED resolution, i.e. number of LEDs. A single LED, combined with the diffusing effects, lights up many pixels. The LED voltages are Vi, i=1 . . . L (see (6))—let the positions of these LEDs be (xLi, yLi), i=1 . . . L. An LED is assigned a value by essentially “averaging” of all Va
A simple averaging method is to take for every adjusted voltage position (xā, yb), the closest LED and assign it Vab. An LED may get more than one assignment, denoted NVi, from different positions. The voltages assigned to LED i from positions (xji, yji)ε{(xā, yb)}, j=1 . . . NVi are labeled as {tilde over (V)}ijε{Vāb}. The final voltage used is then the average of these, giving the correction:
LEDs not affected by the above will retain their original value of V. If the sampling of pixel positions (xa,yb) is of the order of the resolution of the LEDs and positioned similar to the LED positions, then the number of assignments from each (xa, yb) will essentially be one. In this case the above average becomes essentially selecting the nearest Vāb for each LED, i.e. there is no sum. In fact, during computation of the backlight correction, the sampled pixel positions can be kept small corresponding with some subset of the LED positions. This also speeds the computation. A variation on (64) is to assign weights αij depending on the distance from the LED:
For each Va
The voltages can also be computed from point of view of the LEDs. For each LED, take an appropriate weighted sum of Vāb, within a certain distance:
These methods are all different types of averaging.
A slightly different method is to interpolate or fit a smooth function to the Vāb values over (x, y). This gives a 2D voltage surface which can be evaluated at (xLi, yLi) to determine the voltage at the ith LED. If the function is denoted F0V(x, y) one has:
V=F0V(x,y):Fit/Interpolant to (xa,y
Vi′=F0V(xLi,yLi) (67)
A fit is preferred over interpolation as it will include a smoothing.
The corrected voltage values {Vi′} have been computed for a particular starting backlight setting V. Each backlight setting will have a different set of correction voltages computed using the above steps. Normally the computations are done at a set of voltage values as in (21), and the corrections interpolated between the levels. It is also possible to use the same relative adjustment for all backlight settings. The set of corrected voltages for backlight settings Vsi, i=1 . . . NV, will be denoted using the earlier vector notation:
Here Vij′ denotes the corrected voltage from one of (64) to (67) approaches, for the jth LED at (xi,j, yi,j), for a backlight setting V=Vsi. Thus the correction amounts to a change of Vij′−Vsi at the jth LED for initial voltage V=Vsi. If there are RGB LEDs, all three are applied the same correction, ensuring that the backlight correction adjusts brightness only and does not introduce color artifacts.
The backlight correction can also change with the input pixel level in theory. However, the out of range condition (60) is primarily determined by the maximum and minimum grey levels. Due to monotonic responses, intermediate color levels will be in range provided the maximum and minimum levels have been brought to range. Other levels do not need to be independently considered for testing the out of range condition. As such, the voltage correction is kept independent of the color level, though levels 0 and 255 are used to determine the correction itself. This also means that for uniformity correction, at a fixed backlight setting the voltages are adjusted once and not changed (unless the global backlight setting changes) when the input pixel value changes. The content dependent change required is then managed by the pixel correction (58) alone. Another benefit of having the backlight correction independent of the color level being that the uniformity correction will not interfere with other LCD display features, such as local dimming and high dynamic range imaging. These features are all content (color level) dependent and will compete with the uniformity correction if it was also color dependent.
The backlight discussion in the exemplary embodiment has focused on the case where LEDs can individually be adjusted, namely a direct backlit configuration. However as mentioned before, the approach can also be used where there are CCFL tubes or edge-lit LEDs that can be individually controlled. The main change being that adjusting an LED or tube will influence a much larger number of pixels and that needs to be taken into account in the averaging. If local adjustment is complicated, as it may be in an edge-lit backlight or tube based backlight, a global corrected value V′ can be used. Possible choices being:
The choice again dictated by the specifics of the correction.
It can be appreciated that a lot of variations are possible and depending on the requirements for the correction and also factors outlined above (computation speed, number of levels being corrected, etc.), different combinations will provide the best result for different criteria. In particular, the backlight correction can be entirely skipped if a very quick luminance correction towards a minimum uniform quantity is required.
The backlight correction (68) provides a coarse correction for brightness uniformity due to the limited resolution of the LEDs (CCFLs are even more limited). A backlight correction alone is insufficient to obtain high level of uniformity; in particular it cannot provide color uniformity correction. Coarse also implies that a change in the LEDs is more pronounced than changes in pixel values. This means that once the LEDs are adjusted according to (68), the pixel correction needs to be recomputed using (35). To make the process fast and efficient, the first pixel correction, prior to the backlight correction computation, can be made as a rough estimate measuring only levels 0 and 255, for a small number of points, and using the approximation (34). Once the backlight correction has been computed and the LEDs adjusted, then a more detailed calculated with more levels can be made using (35). If required, the steps of approximate pixel correction plus backlight correction can be iterated to ensure that W's are all within range, before proceeding to the detailed computation.
An important benefit of the present method is that it unifies the key components requiring correction, namely the backlight source and the pixels, within the same framework. Both components affect uniformity in an inter-dependent manner and must be treated in parallel for best results.
The method presented herein for generating the backlight correction does not rely on knowing the PSF of the LEDs and/or diffuser. It uses one or more simple iterations to determine a backlight correction, and then determine the precise matching pixel correction. This is very beneficial in practice since PSFs and diffuser effects are very difficult to determine precisely. The present approach is also very practical for a manufacturing flow, whereby the details of the various optical/electronic components (LEDs, diffusers, coatings), often provided by different vendors, need not be known. This correction can also be applied in the field provided some backlight control is available—most displays do allow a global backlight setting control.
In one embodiment, the less common case when PSFs are available, a mathematical approach can be used. This is formulated herein, though the more “empirical” method presented above is more valuable in practice. According to eq. (25) the response splits into a backlight component and a pixel component:
Fi(x,y,{right arrow over (C)},{right arrow over (V)})=FiP(x,y,{right arrow over (V)})×FiP(x,y,{right arrow over (C)}) (70)
For the backlight correction, only the luminance response is considered. The voltage dependence only appears in the backlight response FiP(x,y,{right arrow over (V)}). The response component FiP(x,y,{right arrow over (C)}) is independent of the voltage—this is not identical to the full response Fi(x,y,{right arrow over (C)}), which was based on the measured data for a fixed backlight setting. Specifically Fi(x,y,{right arrow over (C)}) changes with voltage, whereas FiP(x,y,{right arrow over (C)}) is constant. The component FiP(x,y,{right arrow over (C)}) will be referred to as the base pixel response. The base pixel response can also be represented as in (35), giving:
FYP(x,y,{right arrow over (C)})=Σm=13Σn=0dāmnY(x,y)(Cm)n
{right arrow over (C)}=(C1,C2,C3)≡(R,G,B) (71)
The yet to be determined coefficients āmnY(x,y) define the response. The spatial dependence has been made explicit by writing the coefficients as functions of (x, y).
Turning now to FYL(x,y,{right arrow over (V)}), let Pi(x,y) be the normalized PSF of the ith LED, including the affects of the diffuser and any other components. That is Pi(x,y) is the PSF incident at the pixel plane, having gone through the diffuser, etc., when only the ith LED is on. It is now assumed that Pi(x,y) is known. The contribution of the ith LED with voltage Vi to the backlight response is:
FY,iL(x,y,Vi)=ViPi(x,y) (72)
This assumes that the dependence on the voltage is linear, as is expected for LCD displays and shown in
FYL(x,y,{right arrow over (V)})=Σi 1N
The full response then becomes:
FY(x,y,{right arrow over (C)},{right arrow over (V)})=Σi=1N
This represents the complete luminance response for any RGB input, at any pixel position (x,y), and any LED voltage values. As mentioned above, this is rarely a known quantity a priori.
The full response at a fixed voltage value was determined from the measured data above as FY{right arrow over (V)}(x,y,{right arrow over (C)}) in terms of the component responses (35). The superscript {right arrow over (V)} has been included to indicate that this was computed at a specific voltage. This measured response must equal (74) giving the following constraint equation:
FY(x,y,{right arrow over (C)},{right arrow over (V)})=FY{dot over (V)}(x,y,{right arrow over (C)})
Σi 1N
The coefficients amnY have been re-written as amnY{right arrow over (V)}(x,y), to show that they depend on the position (x, y) and the voltages applied {right arrow over (V)}. At each position, a separate equation (75) exists and needs to be solved independently. All quantities in (75) are known except the āmnY(x,y) coefficients. The equality needs to hold for all {right arrow over (C)}, which is only possible if the coefficients for each (Cm)n term are identical. This gives the solution for āmnY(x,y) as:
With the āmnY(x, y) determined, the full response (74) is a known function and can be used to solve for the backlight correction.
In principle (74) provides solutions for both the pixel and backlight corrections. The correction (including X and Z tristimulus responses) is the solution to:
With the restriction that:
0≦Cm≦2b
Viε[V0−δ,V0+δ], i=1 . . . NL (78)
The first restriction states that the pixel values have to be in range [0,255], and the second restriction states that that the solution for the voltage values also should be in some valid range. Equation (77) is a non-linear system of equations and exists as an independent equation at every position (xa,yb). Thus we have a non-linear system of 3×Nx×Ny equations in 3×Nx×Ny+NL variables; the 3×Nx×Ny come from the different Cm values at each position. This is a complicated system to solve, especially under time constraints. Instead, the efficient two-step approach presented above can be also be used here. First the solution (56) (or taking (57) for approximation) is computed for grey levels 0 and 255, concentrating on luminance. These are denoted as Cm0, and Cm255. Those positions at which Cm0 and Cm255 fall out of the valid range, have Cm0 and Cm255 values clipped:
Cm0<0Cm0=0
Cm255>=255Cm255=255 (79)
If the values are in range then no clipping is required. Denote the values with clipping taken into account as
As previously, an independent set of Vi′ values are computed for each initial backlight setting V; recall this is the common voltage applied to all LEDs in computing Cm0 and Cm255. Using the same notation as in (68), write the corrected voltage values for initial setting Vsj (here j is the setting index and i the LED index) as:
Vji′=Vsj+ΔjiV (81)
Then the corrected backlight voltages are computed from:
Σi=1N
Σi=1N
a=1 . . . Nx, b=1 . . . Ny (82)
Unlike (77), this is now a linear system of equations, which are much easier to solve. A pair of such equations exists for every position (xa,yb), hence (x,y) has been replaced by (xa,yb), giving a linear system of 2×Nx×Ny equations in NL variables ΔjiV (note each jth setting is treated separately). The unified approach mentioned previously, treating backlight correction and pixel correction in parallel, is very clear in equation (82). Only one of the two equations in (82) may be used—for example if correction at 255 is more critical then the only the second equation may be used.
For LCDs various other optimizations can be made that make solving (82) simpler. The number of points, and hence the number of equations, can be reduced such that there are more variables ΔjiV than the number of equations. This ensures that in general solutions will exist. Such a reduction is always possible since the coarse brightness improvement sought by the LED correction varies over large regions. If the number of variables and equations are the same then one has a square matrix system. The positions can be taken to correspond with the LEDs, which simplify the matrix, by reducing the relative contributions of the neighboring LEDs. The number of LEDs contributing at a specific position can be limited to the nearest LEDs. This will bring (82) into a “block-diagonal” type form (taking as an example contributions from only 3 LEDs):
Well known numerical methods can be used to solve such systems. The coarser the correction required, the more simplifications that can be made. Only the nearest LED may be used to greatly reduce (82).
As shown above when the PSFs are known, computing the backlight correction can be reduced to solving systems as in (82). In practice, PSFs are complicated to compute and often unavailable, in which case the iterative approach provides a fast and practical alternative to determining the backlight correction.
At the end of the re-calibration stage 45 the pixel correction and backlight correction are known. The pixel correction {right arrow over (C)}′ is provided as a set of corrected pixel values, for each level {right arrow over (C)}′ and common backlight setting Vsj, across a grid of points (xa,yb). The backlight correction {right arrow over (V)}′ is provided as a set of corrected LED voltages depending on the common backlight setting Vsj. This data is summarized below:
{right arrow over (C)}=(R,G,B){right arrow over (C)}′=(RĊabj′,G{right arrow over (C)}abj′,B
The index j indicates the common backlight setting one starts with.
The next stage of reconstruction takes this grid data to a functional form 48. For the pixel correction this will provide new pixel values for all levels, all pixel positions and backlight settings. For the backlight correction this will provide new LED voltage values at any given common backlight setting. Constructing a functional form essentially means converting the above data at discrete points of the various spaces into a continuous function, using some fitting or interpolation method. This is completely analogous to constructing the responses in (35) from a set of points. The form of the function depends also on the hardware in the next and last application stage. A general form, that has a very efficient hardware implementation, has been presented in U.S. Pat. No. 7,324,706. The same form is used here and summarized.
The ranges for all independent variables are broken into regions and a separate function is fitted or interpolated to the data (84) on each region. Similar to the response computation, fitting is preferred and a polynomial basis is used. The pixel correction is considered first. Starting with pixels positions, the position space (x, y) is divided into 2D patches and a polynomial fitted to the (R
RĊj′(x,y)=Σm 0d
G
BĊj′(x,y)=Σm 0d
Here dx and dy are the polynomial degrees in x and y. Note the fitting of (x, y) has eliminated the ab indices and turned the discrete dependence into a continuous dependence. The discrete dependence on the level and backlight setting remains. Next fitting is done in the pixel value space (RGB), using the correction grids (58) computed for the different levels that were made uniform. The RGB space is also divided into patches, and polynomials fitted on each patch. Here the patches are actually 3D cubes since the RGB space is 3 dimensional. The result of the fitting is the functional forms:
Rj′(x,y,R)=Σr 0dΣs 0dΣt 0dΣm 0d
A common degree d has been used for the RGB fitting. Similar form for G and B can be found. For the most common case of uniformity correction by considering only grey level, (86) can be simplified to:
Rj′(x,y,R)=Σt=0dΣm=0d
We use (88) to simplify the notation. The only discrete dependence remaining is on the backlight setting. This is again eliminated by splitting the backlight control into 1D patches and fitting on each of these patches. This gives:
R′(x,y,R,V)=Σk=0d
G′(x,y,G,V)=Σk=0d
B′(x,y,B,V)=Σk=0d
V is again used in (90) for the backlight control which may be in some normalized units. Equation (88) is written in a very general form, though by using linear polynomials (d=1) or other optimizations, can be made much simpler in practice. Also if the same correction is used for all backlight setting then the V dependence in (88) is removed.
The backlight correction function is generated in the same fashion. The voltage data is fitted as a function of the backlight control using the data computed in (68), i being the LED index:
Vi′(V)=Σj 0d
The function should be taken to satisfy:
Vi′(Vsj)=Vji, j=1 . . . NV, i=1 . . . NL (92)
The backlight correction should be viewed as giving the correct LED voltages in response to the backlight setting or control, which may be a starting common voltage or some normalized quantity related to common voltage. Equations (88) and (89) give the final pixel correction map and the backlight correction map for the uniformity correction process. These are rewritten below as:
The first expression in (91) should be understood as being evaluated component-wise (i.e. separately for R, G, and B) on the right. This provides a very compact form for the correction in terms of a set of coefficients {{right arrow over (a)}mntk, aji}, which can conveniently be stored and the polynomials evaluated in hardware.
The final stage 49 involves applying the correction maps (91) to the LCD display using an appropriate hardware platform. The maps can easily be applied by using an FPGA due to the highly compact representation. The FPGA design essentially consists of multipliers and adders that evaluate the above functions for the input RGB signal and backlight control. Co-pending patent application Ser. No. 11/649,765 describes a hardware architecture 100, implementable in an FPGA or ASIC, for applying the pixel correction at a fixed backlight setting. This architecture can also be used for evaluation of the backlight map, as well as further extended for additional functional dependence in the pixel maps on the backlight control. For the display used in the embodied experiment (
The last two columns give the percentage changes in uniformity/non-uniformity. The uniformity has drastically improved after the correction, with the luminance going from 58.73% uniformity to 91.31% uniformity. This corresponds to a uniformity increase of 58%, i.e. >1.5×. Equivalently the non-uniformity is seen to decrease by 79%. Similar improvements can be seen in X and Z tristimulus quantities; specifically, the Z uniformity increased by a factor of 1.67, which is key for color uniformity. The chromaticity coordinates also show large decreases in non-uniformity; more importantly, the delta in (xc,yc) approximated as (% non-uniformity X average) is now <0.01, leading to perceptual color uniformity across the display. To further verify this, the distance ΔEuv* is computed in the perceptual CIE L*u*v* space, which is a measure of the perceptibility of color differences. A distance of ≦1 is considered to be imperceptible (the two colors will look the same) whereas values near ≧2 are considered perceptible, though it should be noted this is an approximation. Color differences outside of this range may or may not be perceptible in practice. To obtain an estimate for ΔEuv*, the following “perceptibility surface” is generated. For every pixel (say at (x0, y0)), ΔEuv* is computed between its L*u*v* values and those of all other pixels. These ΔEuv* values, W×H (display resolution) in total, are all averaged and assigned to the pixel (x0, y0). The process is repeated for all pixels, and amounts to computing distances for all possible pixel pair combinations. This provides a ΔEuv* surface in (x, y) space indicating the average perceptual color distance between a pixel and all other pixels. The ΔEuv* surfaces before and after correction are shown in
The compact nature of the correction of Eq. (91), namely requiring only storage of the coefficients {{right arrow over (a)}mntk, aji}, implies that any external variables that may affect uniformity can be corrected by storing a specific set of coefficients associated with those variables. As an example, illustrated in
The present invention has provided an accurate and efficient approach to greatly improving both brightness and color uniformity in backlit LCD displays. Since the correction is done at the output of the display, namely what the viewer sees, it corrects for all sources of non-uniformity. By working with tristimulus values it accurately takes into account uniformity as perceived by the observer. The embodied methods provide correction maps for both the pixels and the light source, in a unified framework. Various embodiments provide various optimizations which can be used to streamline the process based on specific criteria, such as computation speed, type of correction, etc.
While the above description provides examples of the embodiments, it will be appreciated that some features and/or functions of the described embodiments are susceptible to modification without departing from the spirit and principles of operation of the described embodiments. Accordingly, what has been described above has been intended to be illustrative of the invention and non-limiting and it will be understood by persons skilled in the art that other variants and modifications may be made without departing from the scope of the invention as defined in the claims appended hereto.
This application is a continuation-in-part of U.S. patent application Ser. No. 11/649,765 filed Jan. 5, 2007. The entirety of U.S. patent application Ser. No. 11/649,765 is hereby incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
4472732 | Bennett et al. | Sep 1984 | A |
4635532 | Tanino et al. | Jan 1987 | A |
4908874 | Gabriel | Mar 1990 | A |
4975976 | Kimata et al. | Dec 1990 | A |
5175808 | Sayre | Dec 1992 | A |
5204944 | Wolberg et al. | Apr 1993 | A |
5335097 | Murakami | Aug 1994 | A |
5452019 | Fukuda et al. | Sep 1995 | A |
5594676 | Greggain et al. | Jan 1997 | A |
5808623 | Hamburg | Sep 1998 | A |
5848199 | Naqvi | Dec 1998 | A |
6005582 | Gabriel et al. | Dec 1999 | A |
6016152 | Dickie | Jan 2000 | A |
6061477 | Lohmeyer et al. | May 2000 | A |
6097855 | Levien | Aug 2000 | A |
6239886 | Klassen et al. | May 2001 | B1 |
6243059 | Greene et al. | Jun 2001 | B1 |
6292157 | Green et al. | Sep 2001 | B1 |
6292193 | Perry et al. | Sep 2001 | B1 |
6377317 | Kiga et al. | Apr 2002 | B1 |
6504551 | Takashima et al. | Jan 2003 | B1 |
6603452 | Serita | Aug 2003 | B1 |
6753907 | Sukthankar et al. | Jun 2004 | B1 |
6774953 | Champion et al. | Aug 2004 | B2 |
6778184 | Arita et al. | Aug 2004 | B2 |
6813590 | Crusius | Nov 2004 | B1 |
6844881 | Chen et al. | Jan 2005 | B1 |
6844883 | Bakhmutsky | Jan 2005 | B2 |
7030846 | Lee et al. | Apr 2006 | B2 |
7034786 | Ham | Apr 2006 | B2 |
7039231 | Brosamle | May 2006 | B2 |
7064770 | Lachine et al. | Jun 2006 | B2 |
7084880 | Kimura et al. | Aug 2006 | B2 |
7084881 | Chen et al. | Aug 2006 | B1 |
7088478 | Shirochi et al. | Aug 2006 | B2 |
7126616 | Jasa et al. | Oct 2006 | B2 |
20020027603 | Kuwata et al. | Mar 2002 | A1 |
20030236675 | Duan | Dec 2003 | A1 |
20040012603 | Pfister et al. | Jan 2004 | A1 |
20040076336 | Bassi et al. | Apr 2004 | A1 |
20040113921 | Hains et al. | Jun 2004 | A1 |
20040130669 | Shin et al. | Jul 2004 | A1 |
20040156558 | Kim | Aug 2004 | A1 |
20040218071 | Chauville et al. | Nov 2004 | A1 |
20050024383 | D'Souza et al. | Feb 2005 | A1 |
20050206856 | Ishii | Sep 2005 | A1 |
20060050074 | Bassi | Mar 2006 | A1 |
20060098253 | Masuno et al. | May 2006 | A1 |
20060120620 | Bassi et al. | Jun 2006 | A1 |
20060187233 | Diefenbaugh et al. | Aug 2006 | A1 |
20070035706 | Margulis | Feb 2007 | A1 |
20080062164 | Bassi et al. | Mar 2008 | A1 |
20080068293 | Ishii | Mar 2008 | A1 |
20100002026 | Seetzen et al. | Jan 2010 | A1 |
20100289835 | Holub | Nov 2010 | A1 |
20120274669 | Neal | Nov 2012 | A1 |
Number | Date | Country |
---|---|---|
0920671 | Jun 1997 | EP |
1534019 | May 2005 | EP |
9739420 | Oct 1997 | WO |
Entry |
---|
Zwicker, M. et al., “EWA Splatting”, IEEE Transactions on Visualization and Computer Graphics, vol. 8, No. 3, Jul. to Sep. 2002, pp. 223-238. |
Chen, B. et al., “Footprint Area Sampled Texturing”, IEEE Transactions on Visualization and Computer Graphics, vol. 10, No. 2, Mar. to Apr. 2004, pp. 230-240. |
E. Catmull and A. R. Smith, “3-D Transformations of Images in Scanline Order”, Computer Graphics, (SIGGRAPH '80 Proceedings), vol. 14, No. 3, pp. 279-285. |
P.S. Heckbert, “Fundamentals of Texture Mapping and Image Warping” (Master's Thesis), Department of Electrical Engineering and Computer Science, University of California, Berkeley, CA, Jun. 17, 1989. |
Silicon Video, svW1 Advanced Display Processor, Product Overview, Jul. 17, 2001. |
Hoppe, et al., “Piecewise Smooth Surface Reconstruction”, University of Washington, Seattle, WA, (SIGGRAPH '94 Proceedings) pp. 295-302. |
Mortenson, Michael E., “Geometric Modeling”, Wiley 1997. |
M.J.D. Powell, “Radial basis function methods for interpolation to functions of many variables” Fifth Hellenic-European Conference on Computer Mathematics and its Applications (Athens, Sep. 2001), Department of Applied Mathematics and Theoretical Physics, Oct. 2001. |
Hebson, Robert and Lee, Louie, “Comanche Helmet Integrated Display Sighting System (HIDSS) Optical Distortion Correction Methodology”. |
International Search Report/Written Opinion for international application PCT/US04/29393, date of mailing Feb. 25, 2005. |
Wolf, Stephen, “Color correction matrix for digital still and video imaging system,” NTIA TM-4-406, Dec. 2003. |
Number | Date | Country | |
---|---|---|---|
20110285763 A1 | Nov 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11649765 | Jan 2007 | US |
Child | 13098221 | US |