Flat panel displays are becoming the display of choice for laptop, desktop, and handheld computers alike. There use in televisions is also growing. Flat-panel type displays can take a variety of forms, the most common of which is the liquid crystal type display. Other types include light emitting diode (LED) displays and plasma displays. Liquid crystal displays (LCD) include an active matrix type, which are also called TFT (Thin Film Transistor) type. TFT's are available in color versions and typically can have 256 shades of red, green, and blue (RGB). Such flat panel displays are driven by a controller which is typically a portion of an integrated circuit chip and is also referred to as a display controller or an LCD controller.
The display of color on LCD displays has inherent issues of color accuracy based on the principle of the liquid crystal display itself. Color accuracy has improved in recent years mostly due to the improvement of liquid-crystal panel technology, which has improved fundamentally better than other types of technology. However, if one compares a TFT LCD panel from one manufacturer with the TFT LCD panels from other manufacturers, or with TFT LCD panels from other production lots from the same manufacturer, it will be seen that the display color of the panels are not the same. Color variations between LCD panels occur even if the same display signal is input to the LCD's. This is known as LCD color error. Due to LCD color errors, the LCD has limited capacity to render gradations of primary colors smoothly, uniformly, and consistently. In addition, uniform backlighting across an LCD's entire display surface is difficult to achieve. Therefore, it is not uncommon for an LCD to have bright or dim patches or subtler variations in color intensity, which give the appearance of shading across the screen, or variable color intensity on the display.
As the production of large-sized TFT LCD panels becomes increasingly more common and popular, the display color differences between TFT LCD panels themselves and between TFT LCD panels and cathode ray tubes (CRTs) will become more apparent in the consumer market, and will therefore become an increasingly larger problem. In CRT applications, by contrast there is almost no difference in display color between CRTs lot-to-lot or from maker-to-maker.
An analogy can be drawn from the printer industry in which the print color differences between printers were exposed to the consumer public early on. And since print color was regarded as questionable from the start, color management technology for printing was developed early. However, the color management of printers is not easily adapted to flat-panel video applications. Printing color management in printers is based on red, green, blue (RGB) color space. RGB is three dimensions represented by three coordinates in RGB space (x, y, z). RGB color management utilizes very large RGB 3-dimensional conversion table for storing color correction data that is processed by a controller. The three-dimensional conversion table is used to remap input data that would produce an incorrect color to a correct value that produces the correct color. Each RGB value ranges from 0-255. Therefore, a three-dimensional RGB conversion table of 256×256×256×3=50 MB of memory is needed. Because the printing speed of a printer is slower than video data speed, processing the color management and the conversion tables by software in a processor does not pose a performance problem in printers. Not only is the size of the conversion table prohibitive for use in flat-panels, but remapping in 3-dimensional color space is unworkable for performing real-time color correction during the display of video on an flat-panels due to the high data rates involved.
Accordingly, there is a need for an improved color management method and system that compensates for color errors produced by display devices, such as flat-panel LCD displays.
The present invention provides a method and system for managing digital color for a display device having a display screen. Aspects the exemplary embodiments include receiving input display data comprising digital pixel data, wherein the data for each pixel represents 2D differential color space having X, Y coordinate values; remapping at least a portion of the coordinate values of the input display data locally in coordinates of the differential color space by reading from a memory of the display device color correction data that is configured to correct color errors of the display screen, wherein the color correction data is also represented in the differential color space, but the color correction data is only stored for a subset of X, Y coordinate values comprising the differential color space; interpolating the correction data read from the memory to generate remapped display data; and outputting the remapped display data for subsequent display.
According to the method and system disclosed herein, the exemplary embodiment improves overall image quality of the display device by remapping display data to compensate for the color error of the display screen. The size of the table used to store the color correction data is effectively reduced by 1) executing color remapping in 2-dimensional color differential space, as opposed to remapping in 3-dimensional color space, and 2) the color correction data is compressed by storing the data only for subset of coordinates in the color differential space and then is decompressed through interpolation. Accordingly, a digital color management method and system is provided for display devices that can be performed in real-time for video applications.
The present invention relates to color management for display devices. The following description is presented to enable one of ordinary skill in the art to make and use the invention and is provided in the context of a patent application and its requirements. Various modifications to the preferred embodiments and the generic principles and features described herein will be readily apparent to those skilled in the art. Thus, the present invention is not intended to be limited to the embodiments shown, but is to be accorded the widest scope consistent with the principles and features described herein.
The embodiments disclosed herein are mainly described in terms of particular device and system provided in particular implementations. However, one of ordinary skill in the art will readily recognize that this method and system will operate effectively in other implementations. For example, the circuits and devices usable with the present invention can take a number of different forms. The present invention will also be described in the context of particular methods having certain steps. However, the method and system operate effectively for other methods having different and/or additional steps not inconsistent with the present invention.
RGB is a color space in which the colors red, green and blue can be considered as X, Y and Z axes of a 3-dimensional space, where every possible color has a unique position or coordinate. Other color spaces include an intensity or luminance signal (1-dimensional) and two color differential signals (2-dimensional color differential space). Such color spaces are referred to herein as color differential spaces. Examples types of differential color spaces include YCC, YUV, YIQ, and HSV, for instance.
YCbCr is a family of color spaces used in video systems, which is often abbreviated to YCC. YCbCr defines a color space in terms of one luminance (the brightness) and two chrominance (color) components. Y is the luma component and Cb and Cr are the blue and red chroma components, respectively. In YCbCr, the Cb and Cr components can be thought of as X and Y coordinates within 2-dimensional differential color space. The Cb, (X coordinate) values range from 0 to 255, and the Cr (Y coordinate) values range from 0 to 255. The Y component can be thought of as the Z coordinate.
In analog video systems, the YPbPr color space is used, which is numerically equivalent YCbCr. YCC is often confused with the YUV color space, which also defines a color space in terms of one luminance and two chrominance components. Y stands for the luminance component and U and V are the chrominance components. In YUV, the U and V components comprise X and Y coordinates within the 2-dimensional differential color space. YIQ is a similar color space in which the Y component represents the luma information, while I and Q represent the chrominance information. I and Q can be thought of as a second pair of axes on the same graph, rotated 33°; therefore IQ and UV represent different coordinate systems on the same plane. Another way of making the same colors is to use their hue (X axis), their saturation (Y axis) and their brightness (Z axis). This is called the HSV color space, where hue and saturation comprise X and Y coordinates within the 2-dimensional differential color space.
As explained above, the display of color on LCD displays has inherent issues of color accuracy. LCD color error produces color variations between LCD panels even if the same display signal is input. But performing color management in RGB space using 3-dimensional conversion tables that store color correction data, as done in printers, is impractical for performing real-time color correction on a flat-panel display during the display of video.
According to the exemplary embodiment, a digital color management and system is provided for correcting color errors in display devices, such as flat-panels. The color management system may include transforming RGB color space signals into differential color space, if not already in differential color space, and remapping the coordinates of the input display data locally in the 2-dimensional coordinates of the differential color space by specifying displacement of the color coordinates to a new output color coordinates, thereby compensating for the error of the display color difference caused by the display screen.
More specifically, during a configuration phase, color errors are first measured across a flat-panel display screen, and color correction data configured to correct the color errors is created. The color correction data may be considered as a displacement of input display data coordinates to new output color coordinates that compensate for the color error. The color correction data is then stored in a small memory in the flat-panel, and is preferably compressed by storing the color correction data for only a subset of coordinates comprising the differential color space. During operation of the flat-panel, the color management process receives the input display data represented in differential color space. If the input display data is originally in 3-dimensional RGB color space, then the RGB input display data is first transformed into 2-dimensional differential color space. As the flat-panel is scanned to display an image from the display data, the color correction data in the memory is decompressed by reading only the color correction data surrounding a current pixel value of the display data from the memory, and then real-time interpolation is performed on the color correction data to generate remapped display data for the current pixel. The remapped display data is then displayed on the display screen, thereby providing improved image quality.
Conventional components of the display device 100 for producing a picture on the display screen 128 include a data receive block 102, a timing receive block 104, a timing control (TCON) block 108, a backlight control (B/L CTL) block 110, a source driver 112, a gate driver 114, a LCD power control 116, a backlight power supply inverter (BLPS) 118, a backlight source 120, a backlight reflector 126, and a register block 124. In accordance with the exemplary embodiment, the display device 100 is further provided with a pixel process pipeline 106 that enhances the incoming display data 130 to improve display picture quality, as explained further below.
In one embodiment, the display screen 128 is capable of displaying display data at 8-bit resolution, meaning that 256 shades of grayscaling can be displayed. As those with ordinary skill in the art will readily understand, the term “grayscale” may apply to color displays where the brightness or perceived luminance of a colored region is to vary across a pre-determined intensity range.
Display data 130 comprising a sequence of video frames is input to the data receive block 102. Each frame is an image of RGB (Red, Green, Blue) digital pixel data. In one embodiment, each pixel in the image includes 8 or 10-bit data for each RGB component. The data receive block 102 receives the input display data 130 and outputs the display data 130 to the pixel process pipeline 106. The timing receive block 104 receives timing signals 132 from a display controller (not shown) and outputs the timing signals to the timing control block (TCON) 108, the backlight control block 110, and the pixel process pipeline 106. The timing signals 132 may include a pixel clock (PCLK) signal, a display enable (DE) bit, a horizontal sync (HS) signal, and a vertical sync (VS) signal. The timing control block (TCON) 108 generates further internal timing control signals for the pixel process pipeline 106, the source driver 112, the gate driver 114, and the LCD power control 116.
The LCD power control 116 may include a DC-to-DC converter and generates relatively high voltage for the source driver 112 and gate driver 114. The backlight control block 110 generates backlight control signals, which are output to the backlight power supply inverter 118. The backlight power supply inverter 118 generates high voltage for backlight lighting, which is supplied to the backlight source 120. The backlight reflector 126, in turn, distributes the light from the backlight source 120 as evenly as possible. The value of the high voltage depends on the type backlight source 120, e.g., CCFL (Cold Cathode Fluorescent Lamps) or LED (Light Emitted Diode). Necessary electric power is supplied by a power supply line 122 from a host computer system (not shown). The LCD power control 116 and the backlight power supply inverter 118 convert the voltage from the power supply line 122 to meet the requirements of the source driver 112, gate driver 114, and the backlight source 120. All necessary parameters for the above operations are given from a register value in the register block 124, which are written and read through a control interface (CTL INTF) signal by system software or one of peripherals from a computer system (not shown).
In accordance with the exemplary embodiment, the pixel process pipeline 106 shown in
In step 202, the pixel process pipeline 106 remaps at least a portion of the coordinate values of the input display data locally in coordinates of differential color space by reading from a memory of the display device 100 color correction data 136 that is configured to correct color errors of the display screen, wherein the color correction data is also stored as X, Y coordinate values in the differential color space, but the color correction data is only stored for a subset (i.e., less than the total number) of X, Y coordinate values comprising the differential color space. In one embodiment, the color correction data differential color coordinate values specify a displacement of input color space coordinates to new output color space coordinates, thereby remapping the input colors to colors that are most near to the correct colors.
According to one embodiment, the color correction data 136 is created and stored during a configuration stage, which could occur for example, during manufacturing/testing of the display device 100 and/or the display screen 128. During the configuration stage, color error of the display screen 128 is measured using well-known methods (e.g., color meter), and color correction data for correcting the color error is determined. The color correction data could be stored for each differential color space coordinate, but this would normally require a relatively large memory table size of 2562=64k.
According to the exemplary embodiment, the color correction data 136 is compressed to reduce storage space requirements by storing the color correction data 136 only for a subset of differential color space coordinates in one or more memories (described below) of the display device 100. According to one aspect of the exemplary embodiment, the subset of differential color space coordinates is defined by dividing the differential color space 210 into a color space grid of rows and columns, wherein points at row and column intersections of the color space grid are used to define shapes that encompass multiple differential color space coordinates, as shown in
Adjacent points at row and column intersections of the color space grid 300 are used to define a matrix of shapes 302 that encompass multiple coordinates in the differential color space 210. In an exemplary embodiment, the shapes 302 defined by the points at the row and column intersections are blocks, which are bounded by four grid points. For example, a set of Cb and Cr at coordinates (X, Y) of the differential color space 210 fall within a block defined by the four points labeled An, An−1, Bn, and Bn−1. In alternative embodiments, the points may be selected to define shapes 302 other than blocks, such as rectangles, circles, and polygons for example. In each example, each type of shape 302 should encompass sets of differential color space coordinates.
According to the exemplary embodiment, the color correction data 136 is compressed to reduce storage space requirements by storing in a memory of the display device 100 the color correction data 136 only for the grid points of the color space grid 300 that define shapes 302. In one embodiment, values for the color correction data 136 may be stored specifically for each grid point (e.g., Bn, Bn−1, Bn−2, . . . , An−n; An, An−1, An−2, . . . , An−n).
Referring again to
In step 206, the pixel process pipeline 106 outputs the remapped display data 138 for display on the display screen 128.
According to the method and system of the exemplary embodiment, a color management system for display devices is provided that remaps display data 138 to compensate for the color error of the display screen, effectively improving overall image quality of the display device. Because the color remapping is executed in 2-dimensional color differential space and compressed using the color space grid 300, it can be performed in real-time by display device 128 for video applications. Since the bi-linear interpolation of the remapping table is also carried out on a 2-dimensional table, the required table size is also much less than what would be required for 3-dimensional table.
The local color remap block 400 corrects would be color errors of the display screen 138 by remapping the RGB display data 130 within 2D differential color space using the 2D remap table 408 containing the color correction data 136, and outputs remapped color data 410. More specifically, the local color remap block 400 is the component that performs interpolation on the color correction data 136 stored in the 2D remap table 408 to generate remapped color data 410 that at least in part compensates for the color error of the display screen 128.
Referring again to
The FRC 406 optionally performs dynamic dither on the remapped display data 138 and reduces the bit width of the RGB output remapped display data 138′ from 12 to 8-bits (24-bits total) to match the data width of the display screen 128. Although gamma correction of the remapped RGB the display data 410 provided by the GLUT block 402 is shown as a part of the pixel process pipeline 106, gamma correction functions and/or functions of the FRC 606 are optional and may be performed outside the pixel process pipeline 106.
As shown, the data width of display data 130 input to, and output from, inside modules of the pixel process pipeline 106 may be changed by data processing. For example, the local color remap block 400 may increase the data width of the incoming display data 130 for more precise correction. As described above, the display data 130 may be input as 8 or 10-bit RGB each, but the local color remap block 400 outputs the remapped color data 410 as 12-bit RGB each. The GLUT block 402 also outputs the remapped display data 138 as 12-bit RGB. Thereafter, the FRC 406 is used to reduce the data width of the remapped display data 138 to match the data width of the source driver 112 prior to display. In one embodiment, the FRC 406 uses a static dither or dynamic dither algorithm and converts the 12-bit remapped display data 138 to 8-bit output remapped display data 138′ for display.
Accordingly, the local color remap block 400 may include means for converting input display data 130 from RGB color space to differential color space signals. For example, the local color remap block 400 may include a color space converter 602 that converts the input display data 130 from a color space such as RGB to a differential color space, such as YCbCr (Y=intensity and Cb and Cr=2-dimensional color), and outputs the result as differential color data 608. The following are equations that may be used by the color space converter 602 to convert the RGB display data 130 into Y601, Cb, and Cr (for one example):
Y601=0.257R+0.504G+0.098B+16
C
b=−0.148R−0.291G+0.439B+128
C
r=0.439R−0.368G−0.071B+128
Referring again to
The 2D remapper table 408 that implements the color space grid 300 and stores the color correction data 136 may comprise separate remapping tables for Cb, and Cr, respectively. These tables store only discrete grid locations (e.g., every 16/8/4 address of 256 Cb and Cr addresses). The remapper unit 604 then performs bi-linear interpolation (i.e., linear interpolation in 2-dimensional coordinates) between each discrete (every 16/8/4 address of 256 addresses) grid point to generate the remapped differential color data 610 based on the input coordinates of (Cb and Cr) and corresponding values in the internal remapping tables. In the embodiment where the remapper unit 604 receives 30-bit Yin, Cb in, and Cr in differential color data 608, the remapper unit 604 outputs 36-bit Yout, Cb out, and Cr out.
The local color remap block 400 may further include means for converting the YCC data output by the remapper unit 604 back to RGB. For example, the local color remap block 400 may include a reverse color space converter 606 that converts the remapped differential color data 610 back into RGB remapped color data 410. In the embodiment where reverse color space converter receives 36-bit Yout, Cb out, and Cr out remapped differential color data 610, the reverse color space converter outputs 36-bit RGB remapped color data 410.
The following are equations that may be used by the reverse color space converter 606 to convert Y601, Cb, and Cr back into RGB (for one example):
R=1.164(Y601−16)+1.596(Cr−128)
G=1.164(Y601−16)−0.813(Cr−128)−0.391(Cb−128)
B=1.164(Y601−16)+2.018(Cb−128)
The following is another example set of equations for color space conversions. For transforming RGB to Y709, Cb, and Cr, the color space converter 602 may use the following equations:
Y709=0.183R+0.614G+0.062B+16
C
b=−0.101R−0.338G+0.439B+128
C
r=0.439R−0.399G−0.040B+128
The remapped Y709, Cb, and Cr data may then be re-transformed into RGB space by the reverse color space converter 606 using following equations:
R=1.164(Y709−16)+1.793(Cr−128)
G=1.164(Y709−16)−0.534(Cr−128)−0.213(Cb−128)
B=1.164(Y709−16)+2.115(Cb−128)
In one embodiment, the color space converter 602, the remapper unit 604, and the reverse color space converter 606 are implemented as hardware components. However, the color space converter 602, the remapper unit 604, and the reverse color space converter 606 may be implemented as software components, or a combination of hardware and software. Although the color space converter 602, the remapper unit 604, and the reverse color space converter 606 are shown as separate components, the functionality of each may be combined into a lesser or greater number of components.
For example, the remapper unit 604 may include separate table remapper blocks 802a, 802b, and 802c (collectively referred to as table remapper blocks 802) and corresponding remap tables 804a, 804b, and 804c (collectively referred to as remap tables 804) for storing the color correction data 136 for Y, Cb, and, Cr. Inputs to each of the table remapper blocks 802 are Cb in, and Cr in.
Color correction for Yin may be performed by the 2D ΔY table remapper 802a and ΔY remap table 804a, producing Yout. The ΔY remap table 804a may store color correction data 136 for changing intensity values, producing a ΔY value 806. Yin and the ΔY value 806 are then input to an adder 808 and summed to produce Yout.
Color correction for Cb in may be performed by 2D Cb table remapper 802b and Cb remap table 802c, producing Cb out. The Cb remap table 804b may store color correction data 136 for remapping X-coordinates of the differential color space. And color correction for Cr in may be performed by 2D Cr table remapper 802c and Cr remap table 804c, producing Cr out. The Cr remap table 804c may store color correction data 136 for remapping Y-coordinates of the differential color space.
FIGS. 9 through 12A-C are diagrams graphically illustrating organization of the remapper tables 804 and the process performed by the 2D remapper blocks 802 for interpolating the color correction data stored therein. As described above, each of the 2D remap tables 804 is an implementation of the 17×17 color grid 300 shown in
The middle part of the remap tables 804 (for example, 01 to 0FH or E1 to EFH) can be interpolated using 17×17 table data. But, it is necessary to add one last table row/column (100H) to interpolate the last top/right area (F1 to FFH). Accordingly, the remap tables 804 are implemented as 17×17 memories, as shown in
Referring again to
As shown in
As shown in
According to the exemplary embodiment, the E/O bit 706 of the 10-bit Cb, and Cr, input coordinates (
According to the exemplary embodiment, although the received differential color data 608 is 10 bits, the display data used to access the table memory module 1306 can be reduced to 4-bits because only 16+1 addresses are required in the table memory module 1306, where each address is capable of storing 8-bit color correction data 136. During operation of the display device 100, the interpolation circuit 1300 converts the 8-bit color correction data 136 into 12 bit data to produce more precise color correction, while interpolating data. Accordingly, the interpolation circuit 1300 is capable of receiving input differential color data 608 having a first bit length (e.g., 10 bits), uses only a subset of the differential color data 608 (e.g., 4-bit MSB 704) as an index to the table memory 1306 to reduce the size of the table memory 1308, and performs interpolation on the color correction data 136 retrieved from the table memory 1308 to produce remapped differential color data 608 having a larger bit length (e.g., 12-bits) than the input display data 130.
According to a further aspect of the exemplary embodiment, the table memory 1308 implements the remap tables 804 and is configured as four address memory blocks EO 1220, OO 1222, EE 1224, and OE 1226. Each of the memory blocks 1220, 1222, 1224, and 1226 are capable of 4-bit address input and may include 16 addresses, and 8-bit color correction data 136. In addition, each of the four memory blocks 1220, 1222, 1224, and 1226 includes even and or odd last additional addresses.
When the differential color data 608 address is received, a portion of the differential color data 608 (e.g., 4-bit MSB 704) is used to access the table memory 1308, and the four address memory blocks EO 1220, OO 1222, EE 1224, and OE 1226 are read in parallel to retrieve the four color correction data 136 values needed for 2D interpolation. According to this aspect of the exemplary embodiment, splitting the table memory 1308 into four increases the speed of the memory reads to keep better pace with the speed of the display data 130. In this embodiment, the color correction data 136 values can be read from the table memory 1308 at the same speed as the pixel clock for real time interpolation. Although in an alternative embodiment, the table memory 1308 could be implemented as a single memory, four serial memory reads would be required to obtain the color correction data 136 values stored at odd and even addresses, respectively, which would result in decreased performance. Otherwise, the table memory 1308 would need to be read at a rate four times faster than the pixel clock speed.
Performing parallel reads of the four address memory blocks EO 1220, OO 1222, EE 1224, and OE 1226 is achieved by first separating the differential display data 608 into the most significant bit (MSB) part 704 and the least significant (LSB) part 702 (
The Y MSB address generator 1310 inputs the upper 3 bits of the Cr MSB part 704 as a Y most significant odd address (YMOA) directly to the OO 1222 and EO 1220 of the table memory 1308. The 3-bit YMOA is also input to an adder 1324 and a multiplexer 1326 of the Y MSB address generator 1310. A Y most significant even/odd address (YMEO), the lower 1-bit of the MSB part 704, is used as input to the multiplexer 1326 and to the Y direction the interpolator 1306, which is part of the 2D interpolator 1304. The output of multiplexer 1326 is a 4-bit Y most significant even address (YMEA) used for accessing the OE 1226 and the EE 1224.
Similarly, X MSB address generator 1312 receives inputs the upper 3 bits of the Cb MSB part 704 as an X most significant odd address (XMOA) directly to the OO 1222 and OE 1226 of the table memory 1308. The 3-bit XMOA is also input to an adder and a multiplexer 1328 of the X MSB address generator 30. An X most significant even/odd address (XMEO), the lower 1-bit of the MSB part 704, is used as input to the multiplexer 1330 and to the lower X direction the interpolator 1306. The output of multiplexer 1330 is a 4-bit X most significant even address (XMEA) used for accessing the EO 1220 and the EE 1224.
Data addressing of the Y MSB address generator 1310 is performed as follows. The adder 1324 adds 1 to the YMOA, and outputs the resulting value as a 4-bit address. This 4-bit address is then input to the multiplexer 1326 along with the original YMOA and the YMEO. The multiplexer 1326 then checks the value of the YMEO to determine if the address in the YMOA is odd or even. If the value of the YMEO is one, then the address is odd and the multiplexer 1326 outputs the generated 4-bit address as the YMEA, which is used to read a color correction value from the table memory 1308. If the value of the YMEO is zero, then the address is even and the multiplexer uses the 3-bit YMOA to output the 4-bit YMEA, which is used to read a remapping value from the even MSB 1308. The generated 4-bit address is discarded in this case. Although only 3 bits are required to access the memory, an additional one bit value is added to access the table memory 1308 because when the last address (i.e., the maximum data address), of the YMOA is received, an additional even address is needed to perform the interpolation, so one bit is added by the adder 1324 to generate a 4-bit even address to access the OE 1226 and EE 1224. The addressing of the X MSB address generator 1312 is similar to the preceding description.
The table memory 1308 uses the Y most significant odd address (YMOA), the X most significant even address (XMOA), and the X most significant even/odd address (XMEA) to address the EO 1220, OO 1222 to fetch the two color correction data values for the upper X interpolation from blocks OO 1222 and EO 1220. Similarly, table memory 1308 uses the Y most significant even address (XMEA), the X most significant even address (XMOA), and the X most significant even address (XMEA) to address the EE 1224, and OE 1226 to fetch the two color correction data values for the lower X interpolation from blocks OE 1226 and EE 1224. As shown, the color correction data 136 output from the four address memory blocks EO 1220, OO 1222, EE 1224, and OE 1226 is 8 bits in length. The 8-bit color correction data 136 values are received by the x direction interpolator 1318.
The X direction interpolator 1318 comprises an upper X interpolator 1320 and a lower X interpolator 1322. The upper X interpolator 1320 performs upper X interpolation between the two input correction data values fetched from EO and OO addresses (See
After the multiplexers 1402 and 1404 output the 12-bit upper and base values 1414 and 1416, interpolation between the upper and base values 1414 and 1416 is performed to generate the remapped differential color data 610. First, a delta value 1418 is generated by subtracting the base value 1416 from the upper value 1414 using subtracter 1404. Next, the LSB part 702 is multiplied with the delta value 1418 using multiplier 1420, generating multiplier output 1422. The multiplier output 1422 is then input to an adder 1408 with the base value 1416, the addition of which generates the interpolated remapped differential color data 610, Yout, Cb out, and Cr out (12-bits each, 36-bits total).
According to further aspects of the exemplary embodiments, variations of the pixel grid 300 are provided. Due to the properties of hue, saturation, and intensity (HSI space), for proper remapping of color, the number of grid points needs to be increased in the central areas of the differential, space to provide more precise remapping. Accordingly, a further aspect of exemplary embodiment provides a multi-layer color space grid that increases the number of color correction data stored at the center of the color space grid to provide improved interpolation and increased precision of the color remapping.
A method and system for managing digital color for a display device has been disclosed. The present invention has been described in accordance with the embodiments shown, and one of ordinary skill in the art will readily recognize that there could be variations to the embodiments, and any variations would be within the spirit and scope of the present invention. For example, the embodiments are not restricted to the liquid crystal display, but also CRT and plasma displays are applicable. It is also possible to use any differential color space, including but not limited to YCrCb, YUV, YIQ, YDrDb, HSI, and HSV coordinates.
In addition, the embodiments can be implemented using hardware, software, a computer readable medium containing program instructions, or a combination thereof. Software written according to the present invention is to be either stored in some form of computer-readable medium such as memory or CD-ROM, or is to be transmitted over a network, and is to be executed by a processor. Consequently, a computer-readable medium is intended to include a computer readable signal, which may be, for example, transmitted over a network. Accordingly, many modifications may be made by one of ordinary skill in the art without departing from the spirit and scope of the appended claims.