Not applicable.
The present invention relates to techniques for the modification of sub-pixels.
The most commonly used method for displaying images on a color mosaic display is to pre-filter and re-sample the pixels of the image to the display. In the process, the R, G, B values of selected color pixels are mapped to the separate R, G, B elements of each display pixel. These R, G, B elements of a display pixel are sometimes also referred to as sub-pixels. Because the display device does not typically allow overlapping color elements, the sub-pixels can only take on one of the three R, G, or B colors. The color's amplitude, however, can be varied throughout the entire grey scale range (e.g., 0-255). Accordingly, a rendering that maps image pixels to display sub-pixels is performed.
Referring to
Active matrix liquid crystal display panels achieve their images, in part, because of the individual transistor and capacitor placed at each sub-pixel. The transistor and capacitor latch the data to the pixel electrode that controls the amount of backlight that passes through a given sub-pixel. Occasionally, one or more transistors will malfunction, resulting in one or more defective sub-pixels. There are at least two ways a transistor can fail. One failure mode, a permanently open circuited transistor, results in an always-off or always-on sub-pixel. Another mode of failure, a permanently short circuited transistor, results in a sub-pixel whose brightness value varies over time but in a way not directly tied to the image data to which it should be associated. Also, the sub-pixel may be stuck at an intermediate constant value or may vary in some manner based upon the state of the display, such as the data currently in the frame buffer.
Always-on sub-pixels appear as randomly placed red, blue, and/or green elements on an all-black background. Always-off sub-pixels appear as black or colored dots on all-white or colored backgrounds. The probability of always-on and always-off sub-pixel defects depends on the LCD process. In the most general case, a defective sub-pixel is a sub-pixel whose output light value can not be controlled.
By way of example, the data in the frame buffer may vary the pixel value when the row driver connection to the defective sub-pixel is damaged such that the sub-pixel is always “enabled.” In this case, as the scan lines are written to the column drivers, the signal to the faulty sub-pixels will fluctuate according to the instantaneous values in the column buffer for that column. The slow temporal response will tend to make the output of the defective sub-pixel a constant for the duration of (at least) a frame period. That constant is approximately given by
where pi is the signal input to the ith sub-pixel in the column containing the defective sub-pixel, N is the number of display lines, and f accounts for the temporal response of the sub-pixel and the transfer function between signal and light output. This value will generally be different from the desired output were the sub-pixel operating properly.
Referring to
The foregoing and other objectives, features, and advantages of the invention will be more readily understood upon consideration of the following detailed description of the invention, taken in conjunction with the accompanying drawings.
Embodiments may be described with reference to “RGB” images or domains, or “additive color domains”, or “additive color images.” These terms refer to any form of multiple component image domain with integrated luminance and chrominance information, including, but not limited to, RGB domains. Embodiments may also be described with reference to “YCbCr” images or domains, “opponent color” domains, images or channels, or “color difference” domains or images. These terms refer to any form of multiple component image domain with channels which comprise distinct luminance channels and chrominance channels including, but not limited to, YCbCr, LAB, YUV, and YIQ domains. Color domains where one or more channels have an enhanced luminance component with respect to the other channels may likewise be used. One potential measure of such enhancements is if a channel has >60%, >70%, >80%, >90%, or >95% of the luminance. In addition, the enhanced luminance color domain may be as a result of implicit processing in another color domain as opposed to a traditional color transformation from one color space to another.
The system is generally described with respect to non-overlapping pixels, or otherwise spatially discrete color sub-pixels (e.g., color mosaic or matrix displays). However, the embodiments described herein may likewise be used with colors that are overlapping to a greater or lesser degree. Moreover, the images may be displayed using different sizes of pixels and/or any different colors of sub-pixels. In addition, while some of the preferred embodiments are described with respect to rectangular pixels and sub-pixels, other shapes of pixels and sub-pixels may likewise be used. Also, any particular pixel may be formed by a plurality of sub-pixels in any arrangement, some of which may be duplicated. Moreover, the display may include any structure of different colored sub-regions.
The preferred technique for defect hiding is based upon a constrained optimal rendering framework described below. An unconstrained technique suitable for optimal rendering filter design on a striped display is first discussed followed by a constrained technique for optimal rendering filter design on arbitrary display geometries. An unconstrained optimization may be based upon a desire to minimize a perceptually relevant error, (α), between a scan line of color co-sited image samples, x, sampled at the sub-pixel locations of the target display, and the corresponding flat panel display scan line of R, G, and B sub-pixels, α.
Each xn is a vector valued quantity that represents the RGB value of the incoming image pixel at position n. Scalar valued display sub-pixels are denoted by αn. The RGB striped display geometry dictates that αn alternatively represents a red, green, or blue sub-pixel as a function of n mod 3.
The error (α) to be minimized with respect to α is constructed by first forming the spatial error signal:
En=Mnαn−Cxn
where C is a 3×3 color transformation matrix that maps xn into a perceptually relevant opponent color space, and where Mn=3Cn mod 3, Cn being the nth column of C. The error signal E is then transformed to the Fourier domain and the opponent color components of the transformed signal are perceptually weighted. Finally (α) is formed as the sum of the 12 norms of the weighted Fourier color components. Thus is a weighted quadratic function of the Fourier transform of {En} and hence possesses a unique minimum.
The optimal solution, α, satisfies ∇(α)=0. That is, α is the scan line of sub-pixel values that minimizes (α). The quadratic form of implies that the gradient may be written as an affine system ∇=Aα−r. Furthermore, the structure of A allows one to extract, from the solution to this equation, rendering filter kernels which, when convolved in the proper way with the incoming scan line, yields α.
It may be observed that this rendering filter design is an unconstrained optimization procedure. No explicit mathematical constraints were imposed during the optimization technique described above. There are, to be sure, implicit constraints in the formation of , namely those inherent in the definition of α. The color of a particular αn may be one component color of the input color space, typically not a vector combination of primaries. Furthermore, the sequence of colors that αn encodes is determined implicitly by Mn. In other words, the sub-pixel geometry of the RGB striped display is implicitly assumed by a color vector, Mnαn, that varies cyclically (modulo 3) with the position of the rendered sub-pixel.
One may further observe that a different sub-pixel geometry, perhaps containing additional primaries, may require a re-definition of En as well as a re-working of the solution to ∇(α)=0. This framework may be extended to general two-dimensional multi-primary sub-pixel geometries by recasting the problem as a constrained optimization. Doing this de-couples the definition of the sub-pixel geometry could be de-coupled from the formation of .
Using constrained optimization images may be optimally rendered on a wide variety of regularly tessellated color matrix displays. De-coupling the sub-pixel geometry from the definition of may be done by formulating a constrained optimization of the form:
where the Gi are constraint functions determined by the sub-pixel geometry, the λi are associated Lagrange multipliers, and where is a weighted quadratic function of the two-dimensional transform {Emn} similar to that described above. Emn may be defined as
Emn=C({tilde over (x)}mn−xmn)
where C is the color transformation matrix previously described, xmn is the sampled scene, and {tilde over (x)}mn is an unconstrained full-color display sample at the sub-pixel indexed by (m,n). Before the constraints are imposed, an assumption is that each of the ‘sub-pixels’ of the target display have full color capability. To simplify the analysis one may also assume that the scene is sampled on the same lattice as {tilde over (x)}.
The steps to the formation of the perceptual error function, ({tilde over (x)}), are shown in
Before constraints are imposed one may assume that “sub-pixels” of the target display have full-color capability. The constraint functions, Gi, control the behavior of each sub-pixel in the display. For example, to make a green sub-pixel at display lattice location (m,n), one defines two linear constraint functions:
Gi
where {tilde over (x)}mnc is the cth color component of {tilde over (x)}mn. Equation 3 states that the 0th (red) and 2nd (blue) components of {tilde over (x)}mn will be forced to zero when equation 2 is applied. In other words, starting with a sub-pixel having a potential of red, green, and blue colors the constraints limit the sub-pixel to a single color component, namely, green.
The quadratic form of implies that the first term in equation 1 is linear: ∇=A{tilde over (x)}−r. Thus equations 1 and 2 may take the form
where G′ is the (Jacobean) derivative of G, and thus G′T has ∇Gi as its ith column. In general, this system is non-linear due to G and G′. But constraint functions of the type used to define sub-pixel geometries are linear so G({tilde over (x)}) reduces to G{tilde over (x)} and G′({tilde over (x)}) is independent of {tilde over (x)}. Therefore equation 4 can be rewritten as an augmented linear system as follows:
The operators A, G′ and G depend only on the display and not on the scene data. Only r is a function of the scene data. Furthermore, the simplicity of the constraint functions makes G′ and G sparse, reducing the complexity of numerical solution. Also, as in the unconstrained case, the structure of A allows the extraction of convolutional, shift-invariant, rendering filters which operate on the scene and yield the optimal {tilde over (x)}. This is a consequence of the periodic nature of the applied constraints—they are the same from macro-pixel to macro-pixel.
The constraints applied to one dimensional striped geometry is illustrated in
In a panel the color range of each sub-pixel is limited to its particular color hue. One may insure this condition by imposing two constraints at each of the three sub-pixel sites that must be zero in order for the macro-pixel to behave properly. The zero valued sub-pixels are represented by the hollow rectangles. The six constraint functions for this macro-pixel are
Gi
Gi
Gi
Gi
Gi
Gi
This leaves three degrees of freedom—the three actual sub-pixel intensities to be adjusted by the optimization procedure. When the optimization is performed on an interval of constrained macro-pixels within a scan line, the system of equation 5 can be solved and shift-invariant rendering filters extracted.
The extracted filter kernels for the previous example form an array, or matrix, of one dimensional scalar valued resampling filters, as illustrated in
Equation 6 expresses
The matrix multiplication may be interpreted as substituting for the multiplications of the inner products the convolution (·) operator for the usual scalar multiplications. Hence, for example,
{tilde over (x)}g=(hr→g·xr)+(hg→g·xg)+(hb→g·xb).
One may observe from equation 6 that the sum of three individual convolutions are used to compute each component of the vector valued (r, g, b) output signal {tilde over (x)} from the vector valued (r, g, b) input signal x.
The constraints applied to an example two dimensional geometry is illustrated in
Gi
Gi
Gi
Gi
Next, four green constraints, Gi
The constraints applied to another two dimensional geometry is illustrated in
Seven constraints on the {tilde over (x)}m,n yield the desired macro-pixel pattern. The last three constraints force the four blue elements to act as a single blue sub-pixel within the macro-pixel.
Gi
Gi
Gi
Gi
Gi
Gi
Gi
This has five degrees of freedom, i.e., five independently adjustable sub-pixel values, remain after applying these constraints. The value of each sub-pixel is again determined by all three input color components, so that a total of 15 filter kernels will be extracted from the solution of equation 5.
The matrix of the filters for this geometry are shown in
This general constrained optimization framework may be used to mask defective sub-pixels in a visually optimal manner. There are several types of defects, as previously noted. Examples of some potential geometries are illustrated in
The general framework provides that the sub-pixel defects can be incorporated into the framework by the addition of defect constraints similar in form to those that define the geometry itself. For example, the three always-off defects in the 2nd panel from the left in
Gi
Gi
Gi
in addition to the geometry constraints already discussed. The subscripts on {tilde over (x)} are the (row, column) coordinates of the defect relative to an origin in the upper left corner. Similarly, the green always-on defect in the third panel from the left can be described by an affine constraint function,
Gi
where the intensity range of a sub-pixel is assumed to be [0.1].
The system of rendering filters that result are now shift varying, in contrast to those used for defect free rendering. The convolution of a signal with a FIR filter is usually represented algebraically by an expression like
where N1≦N2 are integers, x and {tilde over (x)} are, respectively, the input and output signals, and h is the filter kernel of length N2−N1+1 with discrete support on the set {N1, N+1, . . . , N2}.
The two summations are equivalent but the second one is suggestive of the usual graphical interpretation of convolution as a fixed input signal, x(k), over which slides (from left to right) a reversed, shift-invariant, filter kernel, h(n−k). At each potion of the kernel, the filter coefficients are multiplied by the signal and the products are added to give the output value, {tilde over (x)}(n).
A shift-varying filter is one whose kernel changes as it shifts along the input data, as illustrated in
An outcome of introducing defect constraints into the rendering filter design process is that the filters, which are normally shift invariant on panels with no defects, become shift-varying when one or more defect constrains are introduced. This is a consequence of the defects not being regularly tessellated on the display as in the sub-pixel pattern of the macro-pixels.
The plots of
On the other hand, when rendering onto a panel with blue sub-pixel defect at sub-pixel number 18, the shapes of these filters vary considerably in the vicinity of the defective sub-pixel, as shown for the different positions of the filter kernels shown in
It is noteworthy that the kernel whose position corresponds to shift position 18 is identically zero. This is expected because the technique has set the blue output to zero at this point. Another observation is that as the defect masking filters move away from the defect, they converge to the shape of the invariant rendering filters. The implication is that the rendering filters and the masking filters can be combined to operate in a seamless way along the scan line without any ‘boundary transition’ artifacts.
The shift varying nature of the defect masking filters gives them a certain intelligence as they render the sub-pixels in the vicinity of a defect so as to mask its visibility from the viewer who is looking at the panel from a normal viewing distance. This intelligence derives from the fact that the weighting functions used in the rendering filter design process are preferably based on the CSFs of the human visual system and therefore have contained within them the relative sensitivity of the HVS to grey scale and color detail. This is shown by the theoretical luminance and chrominance CSF curves plotted in
The behavior of the rendering filters is depicted in
The defect masking described above may be used during the manufacturing process or subsequent to purchase by the user to decrease the visual effects of defects. It is desirable to include features in the display so that the user may even more readily decrease the effects (or otherwise mask) of defects located by a consumer after purchase. These defects may be located automatically by the system or otherwise located with interaction by the user. Once the location and type of defect is determined by the system, the defect is masked, thus hiding its presence and reducing its annoyance.
Several components may be used to facilitate the creation of a defect masking system which can be updated following manufacture. Some of the components include: (1) defect list consisting of anticipated display defect positions and types, (2) defect masking filter(s) for each anticipated type of defect, (3) defect masking processor for applying the appropriate filters, and (4) a mechanism of determining defect type and location via user feedback based upon test patterns produced by the display. The system may modify its list by removing or adding additional defects and their corresponding masking filters. The defect masking processor selects the appropriate masking filters from the stored set of filters. Defect masking uses a set of filters to modify sub-pixel values in a neighborhood of the defect. An updatable set of defect masking filters is designed offline for each expected defect type and provided with the display. Defect masking is accomplished using a list of known defects which specifies for each defect the location, color, and type of the defect. During operation, a processor applies defect masking filters in a neighborhood of each member of the list to reduce the visibility of the defect.
A block diagram illustrating the basic defect masking system is shown in
Another masking system is illustrated in
The use of user interaction to assist in updating the defect list is discussed in greater detail below. Briefly, the system will enter a mode where defects can be added. The microprocessor generates test patterns to guide the user and prompt user's responses to simple questions. Based upon the user's response to questions the system determines the color and type of defect. The location of the defect is determined by having the user place an indicator (overlaid on the displayed test pattern) over the observed defect. The test patterns are designed to facilitate user-friendly classification and location of defects as well as to indicate those defects already present in the system.
The defect list contains a detailed description of defects on the panel. This defect list is used to control the defect masking operation by primarily selecting the defect masking filters to apply and where to apply them in the image. An example defect list is in Table 1. Note the defects are ordered in raster scan order for convenience.
Defect hiding may consist of selecting for each defect a set of one or more defect masking filters based on the defect color and type and, modifying the image values in a neighborhood determined by the row and column of the defect. The ability to update the defect list allows the system to mask defects found after manufacturing or sale.
The defect list can be populated and/or modified in several different ways, three of which are described herein, namely, (1) during inspection, (2) automatically (during operation), and (3) by user interaction. During manufacturing an inspection is conducted which can determine the location, color, and type of each defect. Such inspection may be part of the manufacturing process. Information about the defects is used to initially populate the defect list. The ability to automatically detect defects relies upon additional circuitry built into the panel. During manufacturing this additional circuitry can be used in place of the inspection process with the results stored into the defect list. A panel equipped with this additional circuitry can also scan itself after the panel is sold and thereafter adding the results to the defect list (and potentially obtaining any additional filters, as needed). This scan could be conducted during power on or periodically. User feedback may be used to modify the defect list allowing defect masking following sale.
The interactive mode may be entered by a user or repair technician when a defect is observed. User interaction is used to supply the location, color and type of a panel defect. This information is then placed into the defect list for subsequent masking. A user based system may use an interactive diagnosis mode for determining the information about defects. In this interactive diagnosis mode, the system provides test targets and queries to the user to determine the color and type of defect. The user then specifies the position using an interactive on-screen locator such as movable cross-hairs driven from, for example, the “arrow-key” thumb pad on the remote control. The test patterns selected preferably tend to enhance the visibility of defects and facilitate determining their color and type. Additionally, defects already known to the system may be indicated.
The preferred procedure is to generate test patterns for different colors and types of defects, once the display system is switched to an interactive diagnosis mode. Following each image the user is prompted if any defects are visible. An affirmative answer is followed by the user specifying the coordinates of the defect using an appropriate interactive mechanism and typically involving the remote control of the display device, and LCD TV, to facilitate convenient user interaction. The defect is then added to the defect list.
Different test patterns can be used with this technique. The system should be able to ascertain the type and color of a defect based on presenting images to the user and responses to simple questions. Four test patterns may be used where each test pattern is designed to enhance the visibility of particular defect(s). (For the sake of convenience to the user in locating the new defects, the a priori known defects may be surrounded by a square or other distinguishing feature. The example below will illustrate this aspect.) The test pattern is designed to determine the defect type and color, the color will be asked for Always On defects. Defects known to the system are indicated in the test image. Test images with empty defect list and defect free display are shown below:
In the discussion below, six test patterns are shown one for each defect type, always on/always off, and defect color, red, green, or blue, combination. Each test pattern is designed to enhance the visibility of a particular class of defect(s). (For the sake of convenience to the user in locating the new defects, the a priori known defects may be surrounded by a square or other distinguishing feature. The example below will illustrate this aspect.) The test pattern is designed to determine the defect type and color, the color will be asked for when evaluating always on defects. Sample test patterns generated for by the system when the defect list is empty and seen on a defect free display are depicted below in
Next is illustrated a sequence of images scene by the user when the test patterns of
After seeing this test pattern the user is asked: “Did you see any black spots in the regular pattern of green lines unknown to the system?” An affirmative response in this example activates a control allowing the user to navigate to the position of the defect and select it. Once selected, the coordinates of the defect are added to the defect list, as a green always-off defect in this case. The test pattern is modified by surrounding the known defect with a white square, or other distinguishing feature, and the user is again asked if any defects are seen. The image of the modified test pattern seen by the user is depicted in
A second defect is unknown to the system and appears as a black spot in the regular pattern of green lines. After seeing this test image the user is asked: “Did you see any black spots unknown to the system in the regular pattern of green lines?” An affirmative response activates a control allowing the user to navigate to the position of the defect and select it. Once selected, the coordinates of the defect are added to the defect list, as a green always off defect in this case. This additional defect is added to the defect list. It is surrounded with a white square in the test pattern and the user is again asked if any defects are seen (see
The red and blue always off defects are treated similarly. The always on defects are addressed slightly differently. A single test image is used for all colors and the user is asked for the color of the defect seen.
The user's view of the always on test image on a display with two always on defects is shown in
The process is repeated and the red defect is entered into the system. The resulting test image is shown in
Some of the techniques discussed herein are for discovering the position, color, and type of all pixel defects after the display panel has been sold to the customer, so that those defects not already known to the panel firmware can be entered and masked. However, the actual procedures for use described or implied herein are also appropriate for a repair technician (or savvy user). For example, it is comparatively difficult on a 45″ display to visually find a single “always off” sub-pixel defect whose location is not known beforehand using the patterns, especially if the color of the defect is also not known beforehand. Hence one may also consider modification to the suggested or implied usage described above. The following scenario is merely by way of example of another embodiment.
The expected “use pattern” for a typical user might be as follows. The user, while viewing a program on television, notices, say, an “always off” green defect. He gets up and moves closer to the screen to see what the speck is, and realizes it is, in fact, a defect. Of course he has no idea what color the defect is since the average user knows nothing about subtractive color. A green defect on a white background will appear roughly red to the user.
At this point the user uses his remote control and pushes a button labeled (for example) “Correct Defects”. Up comes (say) a 256×256 full white patch on a black background together with an indication that this is steerable around the screen and a brief instruction to move the patch around so that the defect appears somewhere inside the patch. Since he will remember the approximate location of the defect he just saw, he easily steers the patch over the defect. The small size of the patch enables him to easily locate the defect once it is inside the patch. He is then asked what color the defect appears to be: reddish, light blue, or yellow. His answer indirectly gives the system the true color of the always-off defect. Finally, a steerable means of locating the defect is presented and the user locates the defect and enters it (by means of a button push) into the system.
Since locating the defect is an important aspect and tends to be an error-prone part of the procedure, the user should also be given a means of deleted a defect from the internal list or disabling the masking of a defect in case he enters the wrong position. In addition, it may be better, during location, to substitute for the white patch a 256×256 version of the patterns based on the color entered, so as to make the defect position easier to see. This would also serve to verify that the user did, indeed, pick the correct color. Various verification queries along the way should be used to keep the user from mistakes.
The terms and expressions which have been employed in the foregoing specification are used therein as terms of description and not of limitation, and there is no intention, in the use of such terms and expressions, of excluding equivalents of the features shown and described or portions thereof, it being recognized that the scope of the invention is defined and limited only by the claims which follow.