This invention relates generally to the field of image display systems and more specifically to a system and method for optimizing power usage for solid-state image displays.
Sequential color display systems such as Digital Micromirror Devices (DMD) and others use solid state illuminators such as LEDs, with fixed duty cycles and minimal current variation to adjust the brightness of images. One such approach involves varying duty cycles of illuminators and overlapping primary colors of the image. This requires high fidelity control of the time line resulting in more bit planes and a complicated display driver with excess power consumption due to additional switching. To overlap primary colors, more than one illuminator at any given instance must be powered up resulting in instantaneous power draw increases and requiring a complex and expensive power supply scheme.
Another approach involves varying the intensity of solid state illuminators. This approach is based on an assumption of linear brightness response of solid state illuminators; however, these solid-state illuminators do not have linear response relationship between applied power and brightness. The linear relationship approach requires constant power usage and produces non-optimal image brightness and color drift. In this approach, the white point of the image varies as the currents are linearly adjusted. Various different approaches and related background is described in U.S. Pat. Nos. 7,982,827, 8,253,755, and 8,305,387 the descriptions of which are incorporated herein in its entirety by reference for all purposes.
In accordance with an embodiment, a method for maximizing brightness of solid-state illuminators is provided. The method includes calculating a clipping threshold for each color component of an image of a current frame of an incoming video signal based on energy of each color component, filtering the clipping threshold to generate a filtered clipping threshold; and determining a power level and a gain level for an output video signal based on the filtered clipping threshold.
In accordance with an embodiment, a device is provided. The device comprises a histogram unit, configured to calculate a clipping threshold for each color component of an image of a current frame of an incoming video signal based on energy of each color component; a filter coupled to the histogram unit, configured to filter the clipping threshold to generate a filtered clipping threshold; and a power gain calculator coupled to the filter, configured to determine a power level and a gain level for an output video signal based on the filtered clipping threshold.
In accordance with an embodiment, a display system is provided. The display system comprises a processor configured to compute a histogram of energy of each color component of an image of a current frame of an incoming video signal, calculate a clipping threshold for each color component of the image of the current frame of the incoming video signal based on the histogram, and determine an output power level and output gain level for an output video signal based on the clipping threshold; and a display unit, configured to display the output video signal based on the output power level and the output gain level.
The following description provides many different embodiments, or examples, for implementing different features of the subject matter. These descriptions are merely for illustrative purposes and do not limit the scope of the invention.
Generally, in solid-state displays, illuminators are powered based on the required brightness of a given scene assuming linear relationship between the applied power and resulting brightness of solid-state illuminators. Typically, the power supplied to solid-state illuminators is clipped for a given scene and remains constant for all frames of the given scene. The clipping artifacts become visible on the screen for dark content of the scene and the image quality degrades.
The present disclosure provides an exemplary embodiment for per frame power management using overall energy clipping for each frame of a scene to generate a color sequence of light for modulation by pixel modulators of a spatial light modulator (SLM) in the display of images for a scene. The SLMs are individually set in synchronization with variations in the light sequence from the illuminators and responsive to position setting signals developed from remotely or locally generated image pixel color and intensity (hue and saturation) data. The power of each illuminator is varied based on scene content for the image to be projected and on user-defined maximum gain.
The exemplary embodiment provides a programmable continuum between high brightness and low power. The power to each of the solid-state illuminators (red, green, & blue) is varied based on the scene content that is being displayed for each frame. Additionally, it accounts for non-linear brightness response of typically employed solid-state illuminators. Power to illuminators is varied to decrease power draw and/or increase brightness based on scene content, taking into account the nonlinear nature of the illuminators. The non-linear optimization is addressed on a per frame basis for each scene based on the image content. All brightness measurements are stored in a power/intensity look-up table (LUT) and tables are constantly updated based on brightness measurements of each frame. A low power mode is achieved by setting brightness gain to unity, and a high brightness mode is achieved by setting power to nominal power and setting brightness gain to a large value. Changes in power/intensity relationship due to temperature variability and/or poor heat management may be accounted for by measuring the brightness of each illuminator for the desired drive current during modulator “OFF” times and digitally attenuating each color channel to normalize brightness.
Referring to
The output of APL Unit 110 is input to a Histogram Calculation (HCA) Unit 120. HCA Unit 120 preferably computes histogram of all input values on a frame-by-frame basis. In HCA Unit 120, N bins are employed per each color component, where N<<[bit depth of color component]. Initially, these bins are equally spaced across the dynamic range of the corresponding color component. For an entire frame, the histogram of each median filtered color component is calculated and clipping thresholds are found. The Histogram Unit 120 generates clipping thresholds for each of the three primary colors. The three clipping thresholds are used to calculate new binning ranges for the subsequent frame.
The clipping threshold calculated by the Histogram Unit 120 are input to a Color Space Conversion (CSC) Unit 130. CSC Unit 130 can be any general purpose processor, Digital Signal Processor (DSP) or similar processing unit. CSC Unit 130 includes a Scene Change Calculation (SCC) Unit 132. The SCC Unit 132 calculates a scene change coefficient, described below, based on the absolute difference of clipping threshold values of the current frame and a previous frame. The scene change coefficient is stored in a lookup table in the memory unit 136 for future reference. The SCC Unit 132 provides clipping threshold values to be used for the current frame to a Power and Gain Calculation (PGC) Unit 138. The SCC Unit 132 also calculates a dynamic histogram of RGB input 112 color values. In convention histogram binning, a signal is either binned at its full precision, e.g., 256 bins for an 8-bit signal, or bins are simply combined due to memory constraints e.g., 32 bins are created using only the upper five bits of an 8-bit input signal.
The SCC Unit 132 uses a simple, fixed histogram bin scheme. According to an embodiment, SCC Unit 132 calculates a single 8-bit luminance (or hue) value for each input pixel. It then parses the 8-bit luminance (or hue) into 16 bins: 0-15, 16-31, . . . , 240-255. The summed absolute difference between the current and previous frame's histograms is used as an input to a look-up table in memory 136 that produces a scene change coefficient (between 0 and 1). This coefficient is used in a temporal recursive filtering algorithm described below that is applied to the clipping thresholds. When there is a large summed absolute difference signifying a scene change, the recursive coefficient will be close to zero, and the recursive filtering produces results that are heavily biased towards the current frame. Conversely, when there is a small summed absolute difference, the recursive coefficient will be close to one, and the recursive filtering produces results that are heavily biased towards the previous frame. Histogram Unit 120 calculates the clipping thresholds dynamically incorporating the binning described hereinabove. The objective is to have high precision around the previous frame's clipping thresholds. Subsequent bins and their corresponding widths can be calculated based on a programmable distribution. Luminance values are distributed according to the difference in intensities of pixels. Distribution techniques such as exponential distribution and others can used. The objective is to keep the high precision of distribution. Once the luminance values are distributed in the dynamic histogram, the resolution of the image can be determined.
Filtered clipping threshold values are then input to a Power and Gain Calculation (PGC) Unit 138, which uses the filtered clipping threshold values to generate power Gp, Rp, and Bp for each primary color as the current frame intensity. As stated above, if there is no significant difference between the luminance histograms of the current and previous frames, then the SCC Unit 132 will filter the clipping thresholds with a recursive filter that is heavily biased towards the previously generated results.
The PGC Unit 138 also calculates gain required for each primary color and provides the gain to a Gain Application (GA) Unit 140. An exemplary gain calculation algorithm is described later herein below. The GA Unit 140 uses the gain and applies it to primary colors of the incoming image and outputs gains GRN_OUT, RED_OUT, and BLU_OUT for each primary color needed for the current frame of the scene to be displayed on a display unit 150. A Histogram Bin Calculation (HBC) Unit 134 receives clipping thresholds from the HCA Unit 120 and calculates bin areas for each histogram as explained below. The bin areas calculated by the HBC Unit 134 are then stored into a Memory 136. Memory 136 also stores Lookup Table, and other data such as histograms, bin assignments, bin counts and others. Various units described herein above can be implemented either as independent structural units or can be implemented as software functions in CSC 130. These units can be implemented in a single processing unit programmed to perform various functions. Further, the entire system 100 can be implemented in a processing unit such as a general purpose processor, a DSP, a Microcontroller, a system-on-chip, other processing systems as either individual structural units or software functions, or a combination of multiple units.
Referring to
This dynamic histogram binning is optimal for video since there is a large amount of temporal redundancy between frames. Moreover, it accomplishes at least two purposes: first, it achieves high fidelity on the final clipping thresholds; and second, it has low memory requirements. With conventional histogram binning, those two characteristics are mutually exclusive. The clipping logic utilized in the example implementation is based on energy clipping. With conventional clipping, the number of pixels outside a particular range is counted. A clipping threshold is calculated based on a user-defined clipping sum, e.g., 1% of all pixels in the image. The exemplary energy clipping using dynamic histogram binning on the other hand does not use an out-of-gamut pixel count. Instead, the amount of out-of-gamut intensity is calculated. For instance, the user may define the energy clipping amount to be 1% of the input pixels at full intensity. For an 8-bit input, this implies that 1% of the pixels may be clipped from 255 to 0, or that 2% of the pixels may be clipped from 255 to 128, and so forth. In actuality, the amount of energy clipped is based on the mean energy (average picture level) in each color component. This minimizes the appearance of clipping artifacts.
An example algorithm that can be employed for brightness gain and power calculation by PGC Unit 138 can be as follows:
Brightness Gain Calculation Equations:
(Gain)*[(Rt)(Rc)+(Gt)(Gc)+(Bt)(Bc)]≥1;
Ri=(Gain)(Re);
Gi=(Gain)(Ge); and
Bi=(Gain)(Gc).
Rmin≤Ri≤Rmax;
Gmin≤Gi≤Gmax; and
Bmin≤Bi≤Bmax.
Power Equations
(Rt)(Rp)+(Gt)(Gp)+(Bt)(Bp)≤Np; and
Rp=Rf(Ri);
Gp=Gf(Gi); and
Bp=Bf(Bi).
Where:
Rc, Gc, and Bc=clipping threshold for Red, Green, Blue signals respectively (≤1). This employs energy clipping technique with adaptive histogram bins, described below).
Ri, Gi, Bi=relative intensity of Red, Green, Blue LEDs respectively;
Rmin, Gmin, Bmin=minimum relative intensity of Red, Green, Blue LEDs respectively determined by the minimum power that may be applied to each illuminator;
Rmax, Gmax, Bmax=maximum relative intensity of Red, Green, Blue LEDs respectively determined by the maximum power that may be applied to each illuminator;
Gain=brightness gain (≥1);
Rp, Gp, Bp=power for Red, Green, Blue LEDs respectively;
Rt, Gt, Bt=duty cycles for Red, Green, Blue LEDs respectively (e.g., 0.4, 0.45, & 0.15);
Rf, Gf, Bf=function relating relative intensity to power for Red, Green, & Blue LEDs respectively; and
Np=nominal power=power when fixed duty cycles are employed.
This exemplary implementation employs a new energy-based clipping technique. The conventional clipping approaches specify the number of pixels to clip. In the energy-based approach, the total energy is clipped equivalent to a percentage of the input resolution at full ON scale. For example, with an 800×600 SVGA input, a clipping percentage=1%, and average picture level at full ON scale (255), the clipping amount can be calculated as follows:
Thus, 1% of the input pixels may be clipped from 255 to zero, or 2% of the input pixels may be clipped from 128 to zero, and so forth. Energy clipping results in minimal temporal variability as clipped objects move in and out of the frame. Conventional, count-based clipping, on the other hand, results in harsh boundaries. In a typical scenario, the clipping may be set to 0.25-1.5% of input resolution. The trade-off is between large gain and loss of highlight detail.
In the exemplary embodiment, a hard clipping threshold is not used and reaction time supports smooth scene change transfer function. It is determined how fast power to each illuminator may change for a given amount of hue (or luma) difference between the current and previous frames. If there is little to no hue/luma change, little to no change in power is enforced. The exemplary embodiment uses the transfer function specification through look-up table and minimum recursive coefficient settings.
Compared to conventional approaches, the exemplary embodiment may be accomplished with a lower number of bit planes (e.g., 24 vs. 64). Fewer bit planes means minimum switching and less power draw from the DMD. The exemplary embodiment does not employ overlapping primaries resulting in a simpler and cost effective power supply. Compared to conventional Automatic Gain Control (AGC), the exemplary embodiment achieves larger gains. AGC gain is given by 1/max(Rc, Gc, Bc). In contrast, the exemplary embodiment accounts for nonlinear relationships between brightness and power of each illuminator using a nonlinear optimization algorithm. With the nonlinear optimization algorithm, color drift (white point variation) are minimized or eliminated.
The following exemplary equation provides an example for calculating clipping threshold for a given color component. The equation can be repeated for each color component.
Let p=user defined % pixels to clip
Let r=resolution of input source
Let apl=average picture level (calculation described above)
Let h[n]=histogram bin count for bin n, 0≤n≤N
Let e_amt=energy clipping amount=(apl)(r)(p)
Let ps=pixel summation
Let ce=clipped energy summation
Let ub[n]=upper threshold of bin h[n]
Let lb[n]=lower threshold of bin h[n]
Let c=clipping threshold
Clipped energy summation ce=0
Pixel Summation ps=0
For n=N to 0
Above illustration is just an example of calculating clipping threshold for a frame. One skilled in the art will appreciate that the clipping threshold can be calculated in various different ways using concepts and teachings of the exemplary embodiments described herein for optimizing the non-liner relationship of power and image brightness of solid-state illuminators.
Conventional pixel count based clipping results in hard thresholds that produce step-function responses. In other words, flickering artifacts are present in the image. Energy clipping method of exemplary embodiment described herein eliminates the step response of conventional method and produces smooth, flicker-free results. Additionally, by adapting the clipping amount to scene brightness, the appearance of clipping artifacts is minimized.
As described hereinabove, clipping thresholds are filtered to minimize the potential flickering artifacts. An exemplary filtering equations that can be implemented by is given below.
Let Rc, Gc, Bc=clipping thresholds for Red, Green, & Blue signals, normalized between 0 & 1, for the current frame
Let Rc_prev, Gc_prev, Bc_prev=clipping thresholds for Red, Green, & Blue signals, normalized between 0 & 1, for the previous frame
Let Rf, Gf, Bf=filtered clipping thresholds for Red, Green, & Blue signals, normalized between 0 & 1, for the current frame
Let Rf_prev, Gf_prev, Bf_prev=filtered clipping thresholds for Red, Green, & Blue signals, normalized between 0 & 1, for the previous frame
Let sc_amt=scene change amount
Let s[sc_amt]=recursive coefficient transfer function, a programmable look-up table (LUT).
Let r=recursive coefficient, between 0 & 1
sc_amt=maximum(absolute(Rc-Rc_prev),absolute(Gc-Gc_prev),absolute(Bc-Bc_prev))
r=s[sc_amt]
Rf=(Rc)(1−r)+(Rf_prev)(r)
Gf=(Gc)(1−r)+(Gf_prev)(r)
Bf=(Bc)(1−r)+(Bf_prev)(r)
The recursive coefficient transfer function can be programmed to produce small r values (close to 0) for a large sc_amt and large r values (close to 1) for a small sc_amt. This implies that the filtered clipping thresholds can change instantly for a true scene cut and enforce stability when no scene transition is present. These filtered clipping thresholds can then be used to calculate power and gain for the current frame. In the exemplary embodiment, the adaptive histogram bin allocation process uses un-filtered clipping thresholds.
To compensate for non-linear brightness response of solid-state illuminators, an iterative approach can be employed to find the optimal power distribution among illuminators. An exemplary approach is described herein below.
Parameters
Let Rc, Gc, Bc=clipping thresholds for Red, Green, & Blue signals, normalized between 0 & 1
Let Ri, Gi, Bi=relative intensity of Red, Green, & Blue solid-state illuminators, normalized between 0 & 1
Let Rmin, Gmin, Bmin=minimum relative intensity of Red, Green, & Blue illuminators, normalized between 0 & 1. This is determined by the minimum power that may be applied to each illuminator.
Let Rmax, Gmax, Bmax=maximum relative intensity of Red, Green, & Blue illuminators, normalized between 0 & 1. This is determined by the maximum power that may be applied to each illuminator.
Let G=brightness gain (≥1)
Let Rp, Gp, Bp=power for Red, Green, & Blue illuminators
Let Rt, Gt, Bt=duty cycles for Red, Green, & Blue illuminators (each between 0 & 1, sum to 1)
Let Rf, Gf, Bf=function relating relative intensity to power for Red, Green, & Blue illuminators
Let Rn, Gn, Bn=function relating power to relative intensity for Red, Green, & Blue illuminators (inverse of Rf, Gf, Bf)
Let Np=nominal power
Let step_size=illumination step size used to maximize power utilization
Constraint Equations
Exemplary Brightness Equations
(G)[(Rt)(Rc)+(Gt)(Gc)+(Bt)(Bc)]≥1
Ri=(G)(Rc),
Gi=(G)(Gc),
Bi=(G)(Gc)
Rmin≤Ri≤Rmax,Gmin≤Gi≤Gmax,Gmin≤Gi≤Gmax,
Exemplary Power Equations
(Rt)(Rp)+(Gt)(Gp)+(Bt)(Bp)≤Np
Exemplary Iterative Solution
First, the maximum achievable gain is calculated.
PREV_G=0
G=1/maximum(Rc Gc Bc)
iteration=0
While (iteration<max_iteration) AND (absolute(PREV_G−G)≥G_THR)
Continue iterative optimization until either maximum iteration is hit or gain has reached
Steady State.
The above exemplary recursive optimization equations can be executed during the vertical blanking of video signal. Once active data is present, the gain, G, is applied to each color component and each illuminator is set to their most optimal power setting, Rp, Gp, & Bp. In the example implementation, the system may be set to either a maximum brightness mode, by setting max_gain to a large value, or to a low power mode, by setting max_gain to unity. By making max_gain programmable, a continuum of options between these two modes is also available.
The described solution allows one to achieve maximum brightness for a given power draw (high brightness mode), minimum power usage for a given brightness (low power mode), or a programmable continuum between these two modes. Moreover, it accomplishes this by keeping the duty cycles constant, avoiding the need for high fidelity control of the time line. Additionally, it accounts for the non-linear brightness response of typical solid-state illuminators.
The foregoing outlines features of several embodiments so that those of ordinary skill in the art may better understand various aspects of the present disclosure. Those of ordinary skill in the art should appreciate that they may readily use the present disclosure as a basis for designing or modifying other processes and structures for carrying out the same purposes and/or achieving the same advantages of various embodiments introduced herein. Those of ordinary skill in the art should also realize that such equivalent constructions do not depart from the spirit and scope of the present disclosure, and that they may make various changes, substitutions, and alterations herein without departing from the spirit and scope of the present disclosure.
Although the subject matter has been described in language specific to structural features or methodological acts, it is to be understood that the subject matter of the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing at least some of the claims. Various operations of embodiments are provided herein. The order in which some or all of the operations are described should not be construed to imply that these operations are necessarily order dependent. Alternative ordering will be appreciated having the benefit of this description. Further, it will be understood that not all operations are necessarily present in each embodiment provided herein. Also, it will be understood that not all operations are necessary in some embodiments.
Moreover, “exemplary” is used herein to mean serving as an example, instance, illustration, etc., and not necessarily as advantageous. Also, although the disclosure has been shown and described with respect to one or more implementations, equivalent alterations and modifications will occur to others of ordinary skill in the art based upon a reading and understanding of this specification and the annexed drawings. The disclosure comprises all such modifications and alterations and is limited only by the scope of the following claims. In particular regard to the various functions performed by the above described components (e.g., elements, resources, etc.), the terms used to describe such components are intended to correspond, unless otherwise indicated, to any component which performs the specified function of the described component (e.g., that is functionally equivalent), even though not structurally equivalent to the disclosed structure. In addition, while a particular feature of the disclosure may have been disclosed with respect to only one of several implementations, such feature may be combined with one or more other features of the other implementations as may be desired and advantageous for any given or particular application.
This application claims priority to the U.S. provisional patent application Ser. No. 62/028,154, filed Jul. 23, 2014, the entirety of which is hereby incorporated herein by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
4549212 | Bayer | Oct 1985 | A |
4561022 | Bayer | Dec 1985 | A |
5410617 | Kidd | Apr 1995 | A |
5774593 | Zick | Jun 1998 | A |
7003518 | Lee | Feb 2006 | B2 |
7349574 | Sodini | Mar 2008 | B1 |
7847782 | Sohn | Dec 2010 | B2 |
7924261 | Kerofsky | Apr 2011 | B2 |
7982827 | Clatanoff et al. | Jul 2011 | B2 |
8223113 | Kerofsky | Jul 2012 | B2 |
8253755 | Russell et al. | Aug 2012 | B2 |
8305387 | Russell et al. | Nov 2012 | B2 |
8525934 | Okui | Sep 2013 | B2 |
8674926 | Nitta | Mar 2014 | B2 |
20030201968 | Itoh | Oct 2003 | A1 |
20030218432 | Song | Nov 2003 | A1 |
20040160439 | Xavier | Aug 2004 | A1 |
20060262111 | Kerofsky | Nov 2006 | A1 |
20060267923 | Kerofsky | Nov 2006 | A1 |
20070025683 | Nobori | Feb 2007 | A1 |
20070092139 | Daly | Apr 2007 | A1 |
20070146236 | Kerofsky | Jun 2007 | A1 |
20070247391 | Someya | Oct 2007 | A1 |
20070268524 | Nose | Nov 2007 | A1 |
20080037867 | Lee | Feb 2008 | A1 |
20080088650 | Chen | Apr 2008 | A1 |
20080094346 | De Greef | Apr 2008 | A1 |
20080100645 | Nitta | May 2008 | A1 |
20080129679 | Yamamoto | Jun 2008 | A1 |
20090167751 | Kerofsky | Jul 2009 | A1 |
20090201320 | Damberg | Aug 2009 | A1 |
20100277518 | Oh | Nov 2010 | A1 |
20100328535 | Okui | Dec 2010 | A1 |
20110001807 | Myokan | Jan 2011 | A1 |
20110293176 | Abe | Dec 2011 | A1 |
20130021363 | Nobori | Jan 2013 | A1 |
20140240201 | Takahashi | Aug 2014 | A1 |
20150109346 | Taniguchi | Apr 2015 | A1 |
20160140924 | Heo | May 2016 | A1 |
Number | Date | Country | |
---|---|---|---|
20160027365 A1 | Jan 2016 | US |
Number | Date | Country | |
---|---|---|---|
62028154 | Jul 2014 | US |