This application is directed, in general, to liquid crystal display (LCD) drive circuitry and, more specifically, to a circuit and method for overdriving an LCD with correctly interpolated values.
Common thin-film transistor (TFT) LCD varieties, including twisted nematic (TN), in-plane switching (IPS) and patterned vertical alignment (PVA), have a relatively slow intermediate gray scale response (e.g., as a pixel transitions from one gray level, or GL, to another) due to fundamental characteristics of the LCD structure constituting the pixels of the display. This slow response gives rise to poor dynamic contrast for motion video, resulting in display artifacts commonly known as “ghosting,” “blurring” and “streaking.” The best current solution to slow LCD response is response time compensation (RTC), often called “overdrive.” Overdrive compensates for slow intermediate gray scale response (so-called gray-to-gray, or GtG, transitions) by adjusting the gray scale values used to drive the LCD to achieve desired final values.
For example, it is not possible with current LCDs to drive a pixel from GL 20 to GL 180 in 8 ms. However, by initially driving the pixel from GL 20 toward GL 200 and then to GL 180 after a short delay, it is possible to achieve such a GtG transition in 8 ms.
LCDs typically use FROM-TO lookup tables (LUTs) to implement overdrive. A FROM-TO LUT takes the form of an N×N table that indicates the GL to which a pixel should be driven when going from one GL to another GL. However, a FROM-TO LUT that includes entries for every possible FROM and TO GL (e.g., 0 to 255) would be needlessly large. Instead, a typical FROM-TO LUT may be 17×17 and contain FROM-TO entries for 0 and 255 and multiples of 16 between the two, i.e. 0, 16, 32, . . . , 255. Interpolation is required for the remaining FROM and TO GLs that are not entered in the LUT. Bi-linear interpolation is used for this purpose and requires the four LUT entries corresponding to the closest GLs both less than or equal to and greater than both the FROM and TO GL.
One aspect provides an LCD overdrive interpolation circuit. In one embodiment, the circuit includes: (1) a diagonal interpolator operable to perform a diagonal interpolation along a diagonal direction in a lookup table based on TO and FROM GLs and (2) a further interpolator coupled to the diagonal interpolator and operable to perform a further interpolation based on a result of the diagonal interpolation and the FROM GL.
Another aspect provides an LCD overdrive interpolation method. In one embodiment, the method includes: (1) performing a diagonal interpolation along a diagonal direction in a lookup table, (2) performing a further interpolation based on a result of the diagonal interpolation and (3) employing a result of the further interpolation to overdrive the liquid crystal display.
Yet another aspect provides an LCD drive system. In one embodiment, the LCD drive system includes: (1) a graphics subsystem having a graphics processing unit and a frame buffer coupled thereto operable to store a TO GL, (2) a previous frame buffer operable to store a FROM GL and (3) an interpolation circuit coupled to the frame buffer and the previous frame buffer and having: (3a) a diagonal interpolator operable to perform a diagonal interpolation along a diagonal direction in a lookup table based on the TO and FROM GLs and (3b) a further interpolator coupled to the diagonal interpolator and operable to perform a further interpolation based on a result of the diagonal interpolation and the FROM GL.
Reference is now made to the following descriptions taken in conjunction with the accompanying drawings, in which:
In the description below, the GL to which the pixel is overdriven is referred to as the final GL, as it is the final result of the interpolation process. As stated above, bi-linear interpolation is conventionally used for the purpose of calculating the final GL for FROM and TO GLs that are not explicitly entered in the FROM-TO LUT. However, it is realized herein that a challenge arises when the FROM GL equals the TO GL, namely that the GL to which the pixel is driven should be equal to both the FROM and TO GLs. After all, a pixel is at a steady state when the FROM GL is the same as the TO GL, and overdriving is unnecessary.
While explicit FROM-TO LUT entries lying along the diagonal, e.g., (0,0), (16,16), (32,32), are the same as the FROM and TO GLs to which they correspond, it is realized herein that bi-linear interpolation between LUT entries along the diagonal often results in GLs that differ from the FROM and TO GLs to which they correspond. Consequently, static images displayed on an LCD can have an incorrect color for pixels that are interpolated.
A stopgap measure to combat this issue is to provide a threshold function that forces the TO GL to be used in lieu of the interpolated value when the FROM and TO GLs are within a threshold value of each other. Unfortunately, while the threshold function settles static images, it introduces a discontinuity into what should instead be a monotonically changing overdrive function, and adversely affects dynamic images. The discontinuity may be subtle when overdrive is modest (e.g., for monoscopic video), but more pronounced and annoying when overdrive is aggressive (e.g., for sequential stereoscopic video).
It is realized herein that an interpolation technique superior to bi-linear interpolation is needed. Moreover, it is realized that the novel interpolation technique should guarantee that if the FROM and TO GLs are the same, then the overdrive GL equals the FROM and TO values as well. It is specifically realized that an interpolation technique having a unity function along the diagonal mathematically guarantees such an overdrive GL.
Accordingly, introduced herein are various embodiments of a circuit and method for LCD overdrive interpolation. The embodied interpolation is carried out in three steps. A diagonal interpolation is initially carried out along a diagonal of a rectangle. Next, a further interpolation is carried out along a horizontal side of the rectangle. Finally, another interpolation is conducted using results from the diagonal and further interpolations. The further and other interpolations follow different formulas depending on whether the interpolation target is above the diagonal or not.
This is mathematically different from bi-linear interpolation, in which interpolation is initially carried out along opposing edges of a rectangle and then between the two resulting interpolated values. The difference is significant, because bi-linear interpolation fails to guarantee equality of the final GL result with the FROM and TO GL inputs.
The novel interpolation is described below using an exemplary embodiment, wherein FROM and TO GL values are between 0 and 255, inclusive, and final GL values are stored in a 17×17 LUT corresponding to FROM and TO GL values of 0, 16, 32, . . . , and 256. The example further assumes that calculations are conducted in floating point precision and that in the LUT, horizontal and vertical axes are the TO and FROM dimensions, respectively.
To interpolate a final GL value for a target (i.e. a pair of target TO and FROM values), the appropriate interpolation rectangle in the LUT is first identified. The interpolation rectangle is the smallest rectangle the vertices of which are four LUT points bracketing the target TO and FROM values. If the target TO value is equal to a LUT value, the rectangle is chosen such that the larger of the two LUT TO values is strictly larger than the target, implying that the smaller LUT value may be equal to the target. The same approach is used if a target FROM value is equal to a LUT FROM value.
t=(TO mod 16)/16.0, and
f=(FROM mod 16)/16.0.
The fractions t 130 and f 135 indicate the local position of the interpolation target point 110 inside the interpolation rectangle 120.
A diagonal interpolation is conducted to find D, the interpolated value at the point 140 on the diagonal line 145, according to:
D=T00+t*(T11−T00).
As described below, the diagonal interpolation is conducted whether the interpolation target 110 is below or above the diagonal line 145. In
In addition, a horizontal interpolation is conducted along the top horizontal line 150 to find H, the interpolated value at the point 155:
H=T00+t*(T10−T00).
A final interpolation is then conducted to find the final GL value F, using the earlier results D and H:
F=H+(D−H)*f/t.
D=T00+f*(T11−T00).
In addition, a vertical interpolation is conducted along the vertical line 170 to find V, the interpolated value at the point 175:
V=T00+f*(T01−T00).
A final interpolation is then conducted to find the final GL value F at the target interpolation point 190, using the earlier results D and V:
F=V+(D−V)*t/f.
In the step 260, a further (e.g., vertical) interpolation is performed between LUT points T01 and T11.
In the step 270, another (e.g., final) interpolation is performed. The method ends in an end step 280.
Disclosed embodiments are advantageous over bi-linear interpolation. These embodiments guarantee the equality of the final GL with the TO and FROM GLs. In addition, discontinuities in the final GL for TO and FROM GLs off the diagonal are avoided.
In other embodiments, the diagonal interpolation is conducted either before or after determining whether or not the interpolation target point lies above the diagonal. Furthermore, two or more steps may be combined into a single formula and carried out in a single step. Also, the embodied interpolation method may be used only when the interpolation target is near the LUT diagonal, for example when the interpolation target is inside a LUT bin through which the LUT diagonal passes. In yet other embodiments, the further interpolations may be both horizontal and the other interpolations may be both vertical, the further interpolations may be both vertical and the other interpolations may be both horizontal, the further interpolation and the other interpolation may be horizontal if the interpolation target point is below the diagonal and vertical if the interpolation target point is above the diagonal.
In one alternative embodiment, any division operations required in the interpolation are replaced by multiplication by considering only a limited number of the top bits of the t fraction and using the result as an index into a multiplication table. Since overdrive tables are by nature imprecise, some precision can be sacrificed for efficiency. Simulations indicate that using only the top three bits of the t fraction produces results that are still much superior to bi-linear interpolation. This is particularly advantageous since some commercial field-programmable gate arrays (FPGAs) support eight-entry coefficient tables in their digital signal processor (DSP) multipliers and can be used for this purpose.
One alternative embodiment employs fixed-precision logic to carry out interpolation, with the understanding that diagonal entries will likely be imprecise. In such an embodiment, it may be advantageous to include logic to guarantee desired values for elements along the diagonal.
Those skilled in the art to which this application relates will appreciate that other and further additions, deletions, substitutions and modifications may be made to the described embodiments.
Number | Name | Date | Kind |
---|---|---|---|
6133957 | Campbell | Oct 2000 | A |
7382349 | Kuhns | Jun 2008 | B1 |
9041750 | Dai et al. | May 2015 | B2 |
20020030690 | Someya | Mar 2002 | A1 |
20030072016 | Dalrymple et al. | Apr 2003 | A1 |
20060267893 | Kim et al. | Nov 2006 | A1 |
20100110240 | Thebault | May 2010 | A1 |
20120147162 | Park et al. | Jun 2012 | A1 |
20140300650 | Dai et al. | Oct 2014 | A1 |
Number | Date | Country |
---|---|---|
101425267 | Oct 2011 | CN |
Number | Date | Country | |
---|---|---|---|
20150228055 A1 | Aug 2015 | US |