1. Field of the Invention
The invention relates to display devices. More specifically, the invention describes a method and apparatus for enhancing the appearance of motion on an LCD panel display.
2. Overview
Each pixel of an LCD panel can be directed to assume a luminance value discretized to the standard set [0, 1, 2, . . . , 255] where a triplet of such pixels provides the R, G, and B components that make up an arbitrary color which is updated each frame time, typically 1/60th of a second. The problem with LCD pixels is that they respond sluggishly to an input command in that the pixels arrive at their target values only after several frames have elapsed, and the resulting display artifacts—“ghost” images of rapidly moving objects—are disconcerting. Ghosting occurs when the response speed of the LCD is not fast enough to keep up with the frame rate. In this case, the transition from one pixel value to another cannot be attained within the desired frame time since LCDs rely on the ability of the liquid crystal to orient itself under the influence of an electric field. Therefore, since the liquid crystal must physically move in order to change intensity, the viscous nature of the liquid crystal material itself contributes to the appearance of ghosting artifacts.
In order to reduce and/or eliminate this deterioration in image quality, the LC response time is reduced by overdriving the pixel values such that a target pixel value (t) is reached, or almost reached, within a single frame period. In particular, by biasing the input voltage of a given pixel to an overdriven pixel value that exceeds the target pixel value for the current frame, the transition between the starting pixel value and target pixel value is accelerated in such a way that the pixel is driven to the target pixel value within the designated frame period. However, in order to efficiently calculate the overdrive pixel value, LCD overdrive table is commonly used that provides the appropriate overdrive pixel value that corresponds to a start, target pixel pair.
Although the LCD overdrive table is a standard and effective scheme often used in practice; this invention offers an alternative that reduces the ROM table storage requirements and offers a simplified runtime operation.
In a liquid crystal display (LCD) panel having a number of LCD pixels, a method for providing a LCD pixel response time corresponding to a period of time required for a selected LCD pixel at a starting pixel value to reach a target pixel value.
Each of the LCD pixels is modeled as a second order dynamical system represented as a second order differential equation (m{umlaut over (x)}+k{dot over (x)}+x=p) wherein x, {dot over (x)}, and p represent an LCD pixel strength, an LCD pixel velocity, and an applied LCD pixel command, respectively, and wherein m and k represent an LCD pixel mass and associated pixel damping factor, respectively. The LCD pixel response of the selected pixel under the influence of an imposed command p is calculated based upon the second order differential equation when the selected LCD pixel has an initial LCD pixel strength value of x0 and an associated pixel velocity value of v0.
In yet another embodiment, computer program product for providing a LCD pixel response time corresponding to a period of time required for a selected LCD pixel at a starting pixel value to reach a target pixel value associated with an overdrive pixel value in a liquid crystal display (LCD) panel having a number of LCD pixels is described. The computer program product includes computer code for modeling each of the LCD pixels as a second order dynamical system represented as a second order differential equation (m{umlaut over (x)}+k{dot over (x)}+x=p) wherein x, {dot over (x)} and p represent an LCD pixel strength, an associated pixel velocity, and an applied LCD pixel command, respectively, and wherein m and k represent an LCD pixel mass and associated pixel damping factor, respectively. The computer program product also includes computer code for calculating LCD pixel response data of the selected pixel under the influence of an imposed command p based upon the second order differential equation when the selected LCD pixel has an initial LCD pixel strength value of x0 and an associated pixel velocity value of v0, and computer readable medium for storing the computer code.
In still another embodiment, an apparatus coupled to a liquid crystal display (LCD) panel having a number of LCD pixels for providing an overdrive pixel value associated with a LCD pixel response time corresponding to a period of time required for a selected LCD pixel at a starting pixel value to reach a target pixel value is described. The apparatus includes an overdrive pixel value generator arranged to calculate a LCD pixel response data of a selected pixel under the influence of an imposed command p based upon a second order dynamical system model represented as a second order differential equation (m{umlaut over (x)}+k{dot over (x)}+x=p) wherein x, x and p represent an LCD pixel strength, an associated pixel velocity, and an applied LCD pixel command, respectively, and wherein m and k represent an LCD pixel mass and associated pixel damping factor, respectively when the selected LCD pixel has an initial LCD pixel strength value of x0 and an associated pixel velocity value of v0.
Reference will now be made in detail to a particular embodiment of the invention an example of which is illustrated in the accompanying drawings. While the invention will be described in conjunction with the particular embodiment, it will be understood that it is not intended to limit the invention to the described embodiment. To the contrary, it is intended to cover alternatives, modifications, and equivalents as may be included within the spirit and scope of the invention as defined by the appended claims.
In order to improve the performance of slow LCD panels, the performance of the LCD panel is first characterized by, for example, taking a series of measurements that show what each pixel will do by the end of one frame time. Such measurements are taken for a representative pixel (or pixels) each being initially at a starting pixel value s that is then commanded toward a target value t (where s and t each take on integer values from 0 to 255). If the pixel value actually attained in one frame time is p, then
p=fs(t) (1)
It should be noted that for the sake of simplicity, in the remainder of this discussion, any reference to an overdrive table refers to what is known in the art as a standard overdrive table having saturation regions SM and Sm bounded by maximum effort curves M(s) and m(s), respectively. It is well to note, however, that any appropriate overdrive table, such as an extended overdrive table discussed in more detail in co-pending U.S. patent application Ser. No. ______ by Halfant that is incorporated by reference in its entirety for all purposes, is also well suited for use with the invention.
Therefore, in order to reach a pixel value p that lies within the interval [m(s), M(s)], equation (1) is solved for the argument t that produces pixel value p. The argument t is referred to as the overdrive pixel value that will achieve the goal (i.e., pixel value p) in one frame time. If p<m(s), then the overdrive pixel value is taken as having a best-effort value of 0, with m(s) being the best-effort result achieved. Likewise, if p>M(s) then the overdrive pixel is taken to be 255, with M(s) being the best-effort result. Thus, for a given start pixel s, overdrive function gs can be defined by equation 2 as
In this way, the overdrive pixel value is effective in compelling the pixel to reach its target value in the non-saturation region and M(s) and m(s) in the saturation regions SM and Sm, respectively.
Instead of relying upon a static overdrive table, a dynamical systems approach offers a simple and efficient runtime procedure for estimating an overdrive pixel value that is based on the hypothesis that LCD pixels can be adequately described as second-order linear dynamical systems, or by several such approximations each acting within a sub-region of start-target space. The dynamical systems approach embraces the notion of state, which requires knowledge of intensity (“position”) and velocity for second-order systems, and it shows how the state vector is methodically updated under the action of an imposed pixel force. The order is taken as 2, as shown in the differential equation (3)
m{umlaut over (x)}+k{dot over (x)}+x=p (3)
The general solution of (3) can be written as the sum of any particular solution and the general solution of the associated homogeneous equation
m{umlaut over (x)}+k{dot over (x)}+x=0 (4)
A particular solution of (3) is seen by inspection to be x=p. General solutions of (4) are found by substitution of the trial solution x=eαt where α is a constant:
mα2eαt+kαeαt+eαt=(mα2+kα+1)eαt=0
Since eαt never vanishes, then α must satisfy the quadratic equation
mα2+kα+=0 (5)
This admits of two roots:
If k2−4 m<0 then the roots are complex and the system oscillates about its limiting value. In the case where the damping is high and the mass is small (thus, k2−4m>0) both roots are real and in fact negative, α1 is only slightly negative it is referred to as the “slow root” and determines the system's settling rate whereas α2 is the “fast root” and influences the system's initial response behavior.
Given α1 and α2, the general solution to (3) can be written as
x=c1eα
Letting x0=x(0) and {dot over (x)}={dot over (x)}(0)=v(0)=v0, and substituting t=0 into (7) and (8), gives the pair of equations:
Solving for c1 and c2 yields
This, in conjunction with (7) and (8), is a complete solution that predicts how a pixel, starting at a given value x0 and velocity v0, will evolve under the influence of an imposed command p. Choosing the frame time ( 1/60th second) as the unit of time, the effect at the end of the frame can be resolved by substituting t=1 into (7) and (8):
This shows the iterative nature going from frame n to n+1 (instead of simply from 0 to 1 as before). The runtime coefficients A, B, . . . , F depend on α1 and α2 (or equivalently, on m and k) and can be stored in a ROM. With m, k given, the roots α1, α2 are determined from equation (6). Substituting the coefficients c1, c2 from equation (10) into equation (11) and collecting terms in x0, v0, and p on the right, gives the expressions
These are the same coefficients that enter equation (12), for they depend only on α1, α2 (or equivalently on m, k which determine them through (6)), and not on the iteration index—that is, going from 0 to 1 is the same as going from n to n+1.
During runtime, assume an initial “quiescent” state with x0 and v0 both 0 (i.e., steady black screen) and let p, be the pixel desired for frame 1, or in the general case that starts at frame n with known (or at least predicted) values xn and vn, and that pn+1 is the value that is wanted for frame n+1. That is, in (12) force xn+1=pn+1, which means what is required is a command pixel p that will force the first equation of (12) to take the form pn+1=Axn+Bvn+Cp. In this case, p is just the solution of this equation:
(It should be noted that the reciprocal of the constant C is either stored in the ROM or computed once at init time, and is afterwards used as a multiplier.) Since the applied pixel command p must be an integer in the range 0 to 255, equation (13) is replaced with
Given the hypothesis of a linear second-order dynamical system, the defining parameters m and k can be determined by any of a number of standard “system identification” techniques (such as Matlab's Identification Toolbox). Conceptually, numerous candidate pairs of m and k, taken together, are “tried” in the mathematical model, to see which pair of values causes to model to most-nearly match the measured pixel response data.
To illustrate the runtime operation, suppose that a particular panel has been characterized as being approximately a second-order linear dynamical system with m=0.5, k=2.0. Then the runtime coefficients A, B, . . . , F take on the values
Let's use x0=0, v0=0 to represent the initial pixel strength and velocity as appropriate for a video sequence starting with a steady black screen. Let's assume that the first non-black screen calls for the pixel p, to take the value 128:
p1=128
We use equation (13) to find the ideal input pixel command, ptotal, to achieve this result:
However, as shown in equation (14), this value must be clamped to 255, which is the largest applied pixel command we can issue:
p=round(Clamp(pideal, 0, 255))=255
This is the command input used in the equations (12) to compute the pixel and velocity values achieved at the end of the first frame:
As we can see, due to the truncation of Pideal we have not come very close to our target pixel value of 128; but we will now use the value we did achieve—85.40—as the starting value for the next iteration. Let's say the required pixel value for the second frame is p2=137. Using the values x1 and v1 just computed, we find the ideal pixel input command, from (13) to be:
Since pideal does not need to be clamped, we expect to get quite close to our goal of 137 using the rounded command p=190 back in the update equations (12):
In the same manner, we may use the values x2 and v2 to compute the next overdrive pixel command, p, given any new required third-frame pixel, p3.
The (m, k) pair that best fits the entire panel may work better for some regions of the start-target matrix than others. Typically we can do better if we split the space of start-target pairs into sub-domains and devise separate approximations on each. One obvious separation is along the main diagonal (where start=target): on one side, start<target and we are in the domain of brightening operations; on the other, start>target and we are in the domain of dimming operations. Let's refer to these as domains D1 and D2, respectively.
The approximations (m1, k1) and (m2, k2) on each of these respective domains is a better approximation than that afforded by the original (m, k) which had to accommodate the full scope of start-target operations. We end up with two sets of runtime coefficients:
This is easily applied at runtime: if the target pixel is greater than the start pixel, it's a brightening operation and we use the D1 coefficients; in the opposite case of a dimming operation, we use the D2 coefficients.
Further accuracy can be achieved by additional subdivisions of D1 and D2. For example, a panel brightening from the dark region (small start pixel values) may behave more sluggishly (larger m) than when starting from midrange or brighter regions. For illustration, let's use 32 as the separation point, and define two domains:
These (sub-)domains will determine two parameter pairs, (m1a, k1a) and (m1b, k1b), respectively, each in turn with its own set of derived coefficients:
But now there is a potential problem that didn't arise when working just with D1 and D2: visual artifacts may develop due to the sudden switching of coefficients when the start pixels cross the separation value of 32 (either spatially or temporally). This is a standard problem, and is handled by a technique known as blending.
To begin with, we define a transition region over which the blending will occur. In our example, let it span a region extending 5 pixel-values on either side of the separation point; that is, let it extend from T0=32−5=27 to T1=32+5=37. Thus the width of the transition region is 10, and it covers the interval (27, 37). The idea is that brightening operations with a start pixel≦27 will be handled with the D1a coefficients, those with a start pixel≧37 will be handled using the D2 coefficients, but those with a start pixel in the transition region will be handled with a blending of calculations using both sets of coefficients.
One simple approach uses transition coordinates that go from 0 to 1 on the transition region (which in our pixel coordinates goes from 27 to 37). Standard transition coordinates allow the use of standard blending functions such as β(x)=3x2−2x3, shown in the
Assuming a brightening start-target pair with the start pixel, s, lying in the transition region—say, s=30. We'll start by computing the command pixel, p, and updated pixel, x, and velocity, v, using both D1a and D1b coefficients; let's suppose the results are
As to the blending of these results, we begin by converting s to the transition-coordinate equivalent:
Schematically, the blending will take the form
(D1a)·(1−β(t))+(D1b)·β(t)
Thus, the blended command pixel and update values are
Although only a few embodiments of the present invention have been described, it should be understood that the present invention may be embodied in many other specific forms without departing from the spirit or the scope of the present invention. The present examples are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope of the appended claims along with their full scope of equivalents.
While this invention has been described in terms of a particular embodiment, there are alterations, permutations, and equivalents that fall within the scope of this invention. It should also be noted that there are many alternative ways of implementing both the process and apparatus of the present invention. It is therefore intended that the invention be interpreted as including all such alterations, permutations, and equivalents as fall within the true spirit and scope of the present invention.
The present application claims priority under 35 U.S.C. §119(e) from U.S. Provisional Patent Application No. 60/546,608 entitled “DYNAMICAL SYSTEMS APPROACH TO LCD OVERDRIVE” filed Feb. 20, 2004 (Attorney Docket No. GENSP177P), the entire disclosure of which is incorporated herein by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
60546608 | Feb 2004 | US |