Unlike cathode ray tubes (CRTs), liquid crystal displays (LCDs) do not produce light by themselves. They must be illuminated to produce a visible image. In LCDs this illumination source is referred to as a “backlight.” Backlight illumination may come from the side (edge illumination) or from behind the LCD (backlight illumination). Edge-illuminated backlight systems use multiple light sources placed at the edges of a light-guide which distributes the light behind the LCD panel. Direct backlight systems use either a single light source (e.g., a electroluminescence panel or ELP) or multiple lighting elements placed directly behind the LCD panel. In some implementations, for example, a two-dimensional (2D) array of light emitting diodes (LEDs) may be placed behind the LCD panel.
In one embodiment the disclosed concepts provide a method to dynamically control a display panel's backlight based on image content. The method includes obtaining an image having pixels (each pixel having a value); determining an initial brightness value for each of a plurality of backlight elements, where each backlight element is associated with a corresponding plurality of image pixels; determining a first proposed brightness value for each of the backlight elements, each first proposed brightness value based on a backlight element's initial brightness value and corresponding image pixel values; determining a second proposed brightness value for each of the backlight elements, each second proposed brightness value based on a backlight element's first proposed brightness value and a halo risk value; setting each backlight element's brightness value based the backlight element's second proposed brightness value; and displaying the image in conjunction with setting each backlight element's brightness value. In one or more embodiments, initial values may be predetermined (e.g., full-on, full-off, somewhere between full-on and full-off) or set to the brightness value a prior displayed frame/image (e.g., the immediately prior displayed frame). In other embodiments, determining first and second proposed brightness values may be repeated a specified number of times or until some criteria is met. In such embodiments, the second proposed brightness value of a first iteration may be used as an initial brightness value for the next iteration. In still other embodiments, the various methods may be embodied in computer executable program code and stored in a non-transitory storage device. In yet another embodiment, the method may be implemented in an electronic device having image display capabilities.
The patent or application file contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawing(s) will be provided by the Office upon request and payment of the necessary fee.
This disclosure pertains to systems, methods, and computer readable media to improve the operation of display systems. In general, techniques are disclosed for dynamically adjusting backlight elements based on image content. More particularly, a backlight element's intensity may be targeted for boosting (i.e., increasing) based on content of the backlight element's corresponding image region, where after a check may be made to determine if the proposed increase is likely to risk generation of a halo. If the proposed intensity increase would risk a halo, the backlight element's proposed intensity may be dimmed a bit. Repeating the boost/dim cycle in an iterative fashion permits an image to be displayed with brighter highlights and deeper blacks.
In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the disclosed concepts. As part of this description, some of this disclosure's drawings represent structures and devices in block diagram form in order to avoid obscuring the novel aspects of the disclosed concepts. In the interest of clarity, not all features of an actual implementation may be described. Further, as part of this description, some of this disclosure's drawings may be provided in the form of flowcharts. The boxes in any particular flowchart may be presented in a particular order. It should be understood however that the particular sequence of any given flowchart is used only to exemplify one embodiment. In other embodiments, any of the various elements depicted in the flowchart may be deleted, or the illustrated sequence of operations may be performed in a different order, or even concurrently. In addition, other embodiments may include additional steps not depicted as part of the flowchart. Moreover, the language used in this disclosure has been principally selected for readability and instructional purposes, and may not have been selected to delineate or circumscribe the inventive subject matter, resort to the claims being necessary to determine such inventive subject matter. Reference in this disclosure to “one embodiment” or to “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the disclosed subject matter, and multiple references to “one embodiment” or “an embodiment” should not be understood as necessarily all referring to the same embodiment.
Embodiments of a display system as set forth herein can assist with improving the functionality of computing devices or systems. Computer functionality can be improved by enabling such computing devices or systems to provide more faithful replication or display of high dynamic range (HDR) images. In addition, all images may be displayed with brighter highlights and deeper blacks than can conventional display systems. Use of a display system as disclosed herein can also reduce wasted computational resources. For example, because individual background elements may be dimmed independent of other background elements, system power may be reduced by dimming some backlight elements (when not needed for proper display) when other backlight elements need to be brighter for proper display.
It will be appreciated that in the development of any actual implementation (as in any software and/or hardware development project), numerous decisions must be made to achieve a developers' specific goals (e.g., compliance with system- and business-related constraints), and that these goals may vary from one implementation to another. It will also be appreciated that such development efforts might be complex and time-consuming, but would nevertheless be a routine undertaking for those of ordinary skill in the design and implementation of display systems having the benefit of this disclosure.
Referring to
Referring to
grayscale_value=min(R,G,B),
grayscale_value=max(R,G,B) or
grayscale_value=avg(R,G,B).
Here, R, G and B represent the red, green and blue values of the pixel being converted, min( ) represents a function that returns the smaller of its arguments, max( ) represents a function that returns the larger of its arguments, and avg( ) represents a function that returns the average or mean of its arguments. Once converted, the grayscale image 210A may be used to determine the backlight levels for individual backlight elements (block 215), where after backlight elements 105 may be set (block 220) and image 205A displayed (block 225).
Referring to
Before considering how all of the backlight elements interact to produce an overall backlight illumination (see block 305), consider how the light from a single backlight element may spread across backlight array 105. Referring to
Referring again to
Referring now to
In one embodiment, a backlight element's backlight demand value may be set to the maximum value of any image pixel in its corresponding region. In another embodiment, a backlight element's backlight demand value may be set to the average value of the image pixels in its corresponding region. In yet another embodiment, a backlight element's backlight demand value may be set to some function of its corresponding region's pixels' maximum value, or minimum value, or average value or some combination thereof. In one particular embodiment, a backlight element's demand value may be determined as follows:
BLdmd=max(BLmin,α×pmean+(1−α)pmax), where
max( ) acts as described above, α represents some function of a backlight element's corresponding pixel values, BLmin represents a minimum backlight value (chosen, for example, to make sure small and fine objects in the image remain visible), pmean represents the mean or average value of the backlight element's corresponding pixels, and pmax represents the maximum value of the backlight element's corresponding pixels. In various embodiments, α may be some function of the backlight element's corresponding pixels' minimum, maximum, mean or median values. For example,
α=pmeank, or
α=pmeank/k, or
α=pmaxk, where
“k” represents some constant that may be determined, for example, by performing front-of-screen tests. In one or more embodiments, BLmin may be established in any manner desired. In some embodiments, BLmin may be set as follows:
In one embodiment, and based on front-of-the-screen tests to identify well displayed images and the above described approach to determining BLdmd, k may be set to a value between 0.1 and 0.4.
Given each backlight element's currently determined proposed intensity (e.g., from block 305), and BLdmd and BLmin values as determined above, the amount to boost a backlight element's proposed intensity in accordance with block 310 may be given as follows:
BLnew=ƒ(BLcur,BLdmd,BLmin,c), where
BLnew represents a new proposed intensity value for the backlight element (i.e., after being boosted in accordance with block 310), BLcur represents the backlight element's current proposed intensity value (e.g., as determined during block 305), BLdmd and BLmin are as defined above, and “c” represents one or more constants that, in general, depend on the PSF of the backlight element. The precise nature of ƒ( ) may be determined by the anticipated use of the target display system. In one illustrative embodiment, BLnew for a given backlight element may be determined in accordance with the pseudo-code provided in Table 1.
Here, ƒ( ) represents a function of BLdlta, c1 is a constant that can be related to the backlight element's full-on value and c2 is another constant related to how aggressive the designer wishes to make the boost function embodied in block 310. The functional relationship ƒ(BLdlta) may incorporate any function found beneficial by the designer. By way of example, but not limitation, functional ƒ(BLdlta) may represent a power function (e.g., xy where y=−X . . . 0 . . . Y). While Table 1 describes how to boost a single backlight element, all of the backlight element's boosted values may be represented in matrix form as [BLboost]; a (M×N) matrix in accordance with
Returning again to
BLΔhalo=ƒ(BLpsf,BLrisk), where
ƒ( ) represents some function selected by the designer to meet their application's goal (e.g., a two-dimensional convolution), BLpsf represents the backlight element's point-spread-function as described above, and BLrisk represents the backlight element's risk of generating a halo based on the backlight element's corresponding proposed image pixel value.
Referring to
Returning yet again to
[BLhaloest]=[BLboost]⊗[BLΔhalo], where
[BLboost] and [BLΔhalo] are as described above, and the ‘⊗’ operator represents a pair-wise matrix multiplication. For M×N matrices A and B:
In some embodiments, once the amount of halo, based on the current proposed backlight level and image content, has been estimated (BLhaloest), it may be compared to a value indicative of the maximum allowed amount of halo in accordance with the pseudo-code in Table 2.
where BLhalomax represents the maximum amount of halo permitted as determined by front-of-screen tests, BLdim represents the value by which the backlight should be reduced in accordance with block 320, and BLhaloest is a selected value from the matrix [BLhaloest]. In one embodiment, BLhalomax may be a constant. In another embodiment BLhalomax may be a constant determined in accordance with the current image (e.g., image 210A). In yet another embodiment, each element in [BLhalomax] may be a constant, but values may change from element to element.
With the backlight array's proposed values adjusted in accordance with block 320, a check may be made to determine if additional iterations through operation 215 need to be made (block 625). If additional iterations are desirable or needed (the “NO” prong of block 625), processing resumes at block 305 with the current proposed backlight levels or values taken as input (i.e., initial proposed backlight values). If no more iterations are to be performed (the “YES” prong of block 325), operation 215 moves to 220 (set backlight element in accordance with 215) and 225 (display image). In one embodiment, operations 305-320 may be performed a specified number of times (e.g., 1, 3, 5 or 8). In another embodiment operations 305-320 may be performed until a specified criteria is met (e.g., backlight element intensity convergence, processing time limit, etc.). In general, as the number of iterations increases so too does the visual quality of the displayed image. Increased iterations also take more processing time.
Referring to
Processor module or circuit 705 may include one or more processing units each of which may include at least one central processing unit (CPU) and/or at least one graphics processing unit (GPU); each of which in turn may include one or more processing cores. Each processing unit may be based on reduced instruction-set computer (RISC) or complex instruction-set computer (CISC) architectures or any other suitable architecture. Processor module 705 may be a system-on-chip, an encapsulated collection of integrated circuits (ICs), or a collection of ICs affixed to one or more substrates. Memory 710 may include one or more different types of media (typically solid-state, but not necessarily so) used by processor 705, graphics hardware 720, device sensors 725, image capture module 730, communication interface 735, user interface adapter 740 and display adapter 745. For example, memory 710 may include memory cache, read-only memory (ROM), and/or random access memory (RAM). Storage 715 may include one more non-transitory storage mediums including, for example, magnetic disks (fixed, floppy, and removable) and tape, optical media such as CD-ROMs and digital video disks (DVDs), and semiconductor memory devices such as Electrically Programmable Read-Only Memory (EPROM), and Electrically Erasable Programmable Read-Only Memory (EEPROM). Memory 710 and storage 715 may be used to retain media (e.g., audio, image and video files), preference information, device profile information, computer program instructions or code organized into one or more modules and written in any desired computer programming languages, and any other suitable data. When executed by processor(s) 705 and/or graphics hardware 720 and/or functional elements within image capture module 730 such computer program code may implement one or more of the methods described herein. Graphics hardware module or circuit 720 may be special purpose computational hardware for processing graphics and/or assisting processor 705 perform computational tasks. In one embodiment, graphics hardware 720 may include one or more GPUs, and/or one or more programmable GPUs and each such unit may include one or more processing cores. Device sensors 725 may include, but need not be limited to, an optical activity sensor, an optical sensor array, an accelerometer, a sound sensor, a barometric sensor, a proximity sensor, an ambient light sensor, a vibration sensor, a gyroscopic sensor, a compass, a barometer, a magnetometer, a thermistor sensor, an electrostatic sensor, a temperature sensor, a heat sensor, a thermometer, a light sensor, a differential light sensor, an opacity sensor, a scattering light sensor, a diffractional sensor, a refraction sensor, a reflection sensor, a polarization sensor, a phase sensor, a florescence sensor, a phosphorescence sensor, a pixel array, a micro pixel array, a rotation sensor, a velocity sensor, an inclinometer, a pyranometer and a momentum sensor. Image capture module or circuit 730 may include one or more image sensors, one or more lens assemblies, and any other known imaging component that enables image capture operations (still or video). In one embodiment, the one or more image sensors may include a charge-coupled device (CCD) or complementary metal oxide semiconductor (CMOS) sensor. Image capture module 730 may also include an image signal processing (ISP) pipeline that is implemented as specialized hardware, software, or a combination of both. The ISP pipeline may perform one or more operations on raw images (also known as raw image files) received from image sensors and can also provide processed image data to processor 705, memory 710, storage 715, graphics hardware 720, communication interface 735 and display adapter 745. Communication interface 735 may be used to connect computer system 700 to one or more networks. Illustrative networks include, but are not limited to, a local network such as a Universal Serial Bus (USB) network, an organization's local area network, and a wide area network such as the Internet. Communication interface 735 may use any suitable technology (e.g., wired or wireless) and protocol (e.g., Transmission Control Protocol (TCP), Internet Protocol (IP), User Datagram Protocol (UDP), Internet Control Message Protocol (ICMP), Hypertext Transfer Protocol (HTTP), Post Office Protocol (POP), File Transfer Protocol (FTP), and Internet Message Access Protocol (IMAP)). User interface adapter 740 may be used to connect microphone(s) 750, speaker(s) 755, pointer device(s) 760, keyboard 765 (or other input device such as a touch-sensitive element), and a separate image capture element 770—which may or may not avail itself of the functions provided by graphics hardware 720 or image capture module 730. Display adapter 745 may be used to connect one or more display units 775 which may also provide touch input capability. System bus or backplane 750 may be comprised of one or more continuous (as shown) or discontinuous communication links and be formed as a bus network, a communication network, or a fabric comprised of one or more switching devices. System bus or backplane 750 may be, at least partially, embodied in a network router or hub, a wireless access point (AP) or repeater, a set-top box, or a combination thereof.
Referring to
Processor 805, display 810, user interface 815, graphics hardware 820, device sensors 825, communications circuitry 845, image capture module or circuit 850, memory 860 and storage 865 may be of the same or similar type and serve the same function as the similarly named component described above with respect to
It is to be understood that the above description is intended to be illustrative, and not restrictive. The material has been presented to enable any person skilled in the art to make and use the disclosed subject matter as claimed and is provided in the context of particular embodiments, variations of which will be readily apparent to those skilled in the art (e.g., some of the disclosed embodiments may be used in combination with each other). For example,
Number | Name | Date | Kind |
---|---|---|---|
8736543 | Kubota | May 2014 | B2 |
8760385 | Kwon | Jun 2014 | B2 |
8896638 | Kurabayashi | Nov 2014 | B2 |
9142157 | Wurzel | Sep 2015 | B2 |
20100194791 | Ogi | Aug 2010 | A1 |
20100259653 | Kimura | Oct 2010 | A1 |
20110316829 | Oka | Dec 2011 | A1 |
20120007896 | Kwon | Jan 2012 | A1 |
20140160181 | Takeda | Jun 2014 | A1 |
20140192078 | Gilbert | Jul 2014 | A1 |
20140285511 | Hoshino | Sep 2014 | A1 |
20150055025 | Gotoh | Feb 2015 | A1 |
20150269895 | Kao | Sep 2015 | A1 |
20160117993 | Buckley | Apr 2016 | A1 |
20160260390 | Diao | Sep 2016 | A1 |
20160307523 | Huang | Oct 2016 | A1 |
20180061330 | Jeon | Mar 2018 | A1 |
Number | Date | Country | |
---|---|---|---|
20180247609 A1 | Aug 2018 | US |