This disclosure relates generally to dynamically correcting gray tracking for output devices. More particularly, but not by way of limitation, this disclosure relates to updating the correction applied to each color channel for a display device based on dynamically changing display characteristics such as white point, black point, and the like.
Modern consumer electronic devices incorporate display devices (e.g., liquid crystal display (LCD), organic light emitting diode (OLED), plasma, digital light processing (DLP), and the like) to exchange information with users and to impart visual impression. Operation characteristics of the display devices may vary from device to device, even in the same product line or manufacturing line, due to inherent properties of the display devices. For example, variations may exist in LCD components, such as backlight variations due to light emitting diode (LED) wavelength and phosphor concentration, color filter thickness, and the like. Thus, each display device may have slightly different color characteristics, white points, and the like.
Further, modern consumer electronic devices (especially, mobile devices) are increasingly being used in a multitude of different environments with different and changing lighting and/or ambient conditions (e.g., home, office, home theater, outdoors, and the like). In order to keep a viewer's perception of the displayed data relatively stable despite changes in the ambient conditions in which the display device is being viewed, image processing techniques may be employed to modify display characteristics (e.g., white point, black point, gamma, and the like) of the display device to cause the display device to adapt to the user. For example, the white point may be moved to a perceptually warmer, less blue light in a night-time environment to give a more soothing experience to the user. As another example, a color ambient light sensor may be employed to understand illumination in an environment and move the display characteristics (e.g., white point, black point, gamma, and the like) to integrate the display device into the perceptual space of the user, leading to poor gray tracking. When pixel adjustment values generated during gray tracking calibration based on a target white point are applied to pixel data after the white point is moved to a different point, the output gray levels tend to have a wandering hue that varies for gray intensity levels from black to the current set white point. That is, although the hue for different gray levels is expected to move when the white point is moved, the hue is expected to move in the same manner and consistently across all gray levels, not in a different manner for different gray levels.
The following presents a simplified summary of the disclosed subject matter in order to provide a basic understanding of some aspects of the subject matter disclosed herein. This summary is not an exhaustive overview of the technology disclosed herein. It is not intended to identify key or critical elements of the invention or to delineate the scope of the invention. Its sole purpose is to present some concepts in a simplified form as a prelude to the more detailed description that is discussed later.
In one embodiment a method includes: setting an output device to a first state in which a value of a first characteristic of the output device is set to a first value; setting pixel adjustment values for a plurality of gray levels to first pixel adjustment values in response to the output device being set to the first state, wherein the first pixel adjustment values are based on actual measured values for the plurality of gray levels measured when the first characteristic of the output device is set to the first value; changing the value of the first characteristic of the output device from the first value to a second value to set the output device to a second state; updating the pixel adjustment values for the plurality of gray levels to second pixel adjustment values in response to the output device being set to the second state, wherein the second pixel adjustment values are dynamically derived based on the second value of the first characteristic of the output device and based on the first pixel adjustment values; and correcting pixel values applied to a plurality of pixels of the output device based on the second pixel adjustment values.
In another embodiment, the method 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 on an electronic device.
While certain embodiments will be described in connection with the illustrative embodiments shown herein, the invention is not limited to those embodiments. On the contrary, all alternatives, modifications, and equivalents are included within the spirit and scope of the invention as defined by the claims. In the drawings, which are not to scale, the same reference numerals are used throughout the description and in the drawing figures for components and elements having the same structure, and primed reference numerals are used for components and elements having a similar function and construction to those components and elements having the same unprimed reference numerals.
In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the inventive concept. 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 invention. In the interest of clarity, not all features of an actual implementation are described. 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 invention, and multiple references to “one embodiment” or “an embodiment” should not be understood as necessarily all referring to the same embodiment.
It will be appreciated that in the development of any actual implementation (as in any development project), numerous decisions must be made to achieve the 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, ut would nevertheless be a routine undertaking for those of ordinary skill in the design and implementation of signal processing having the benefit of this disclosure.
The terms “a,” “an,” and “the” are not intended to refer to a singular entity unless explicitly so defined, but include the general class of which a specific example may be used for illustration. The use of the terms “a” or “an” may therefore mean any number that is at least one, including “one,” “one or more,” “at least one,” and “one or more than one.” The term “or” means any of the alternatives and any combination of the alternatives, including all of the alternatives, unless the alternatives are explicitly indicated as mutually exclusive. The phrase “at least one of” when combined with a list of items, means a single item from the list or any combination of items in the list. The phrase does not require all of the listed items unless explicitly so defined.
This disclosure pertains to updating (changing or correcting) gray tracking (e.g., gray gradient, or gray vector) in response to dynamically changing display characteristics (e.g., white point, black point, gamma, temperature, and the like) of an output device (display device) so as to appear of consistent, neutral hue. In a factory during manufacture, one or more gray tracking calibrations may be performed with a display characteristic of the display device set to have respective different values (e.g., multiple calibrations for multiple different set white points). A dynamic gray tracking engine may determine pixel adjustment values (correction tables or in the form of a parametric solution) based on actual measured colorimetric response display values for each gray tracking calibration. In one embodiment, a sampling of characteristic values for which the actual measured calibration is to be performed may be determined based on a 1D, 2D, or 3D range of possible display input values/codes the display characteristic may hold for which a correction table may have to be derived or synthesized.
During operation, when the display device is set to a target value for a display characteristic (e.g., target white point) for which actual measured gray tracking calibration data is available (e.g., adjustment values for each color channel in a correction table or LUT), the gray tracking engine may correct pixel values based on adjustment values (e.g., correction table or parametric solution) associated with the target value. Subsequently, when the target value dynamically changes to a different value (e.g., white point being constantly changed, or display panel temperature change), the gray tracking engine may update the gray vector for each color channel to correspond to the different value based on the calibration and measurement data of multiple gray tracking calibrations (LUTs or a parametric solution derived from a model generated based on the calibration data or from an analysis of the calibration data). In one embodiment, bi-linear, tri-linear, multi-linear, or tetrahedral interpolation techniques may be employed to derive a correction table of pixel adjustment values (e.g., 1D LUT for each color channel, 3D LUT, matrix, function, and the like) corresponding to the different value (e.g., moved white point) based on respective stored correction tables corresponding to the nearest two or more values for which the gray tracking calibration based on actually measured values has been performed.
In another embodiment, a mathematical model may be developed that can represent the effect of several primary, secondary, or tertiary factors (e.g., sub-pixel crosstalk, quarter wavelength shutter effects, thermal issues, and the like) that cause the gray tracking to ‘break’ (e.g., gray tracking gets de-tuned) when the display characteristic value is moved (e.g., white point is changed). The math model may include a polynomial equation developed based on actual measurements across characteristic values and component brightness levels (e.g., calibration data of different white points), and the mathematical model may be trained to represent the effect of factors influence on gray tracking for a given display to be calibrated by solving for coefficients in the polynomial equation. Then, as the value of the display characteristic dynamically changes, the model, which may be very compact as compared to the multiple correction tables based on multiple gray tracking calibrations, may synthesize a gray tracking correction table for the dynamically moved characteristic value (e.g., moved white point) of the particular display device. The model may also synthesize the correction table based on one or more alternative or additional parameters (e.g., temperature, black point, gamma, and the like). Further, instead of synthesizing the correction table, the model may directly be applied as a parametric solution (e.g., shader or bespoke hardware) to correct the pixel values of pixels of the output device based on the changed display characteristic value. The mathematical model may also be an analytical model, artificial intelligence model, or other type of model developed by analyzing the respective stored correction tables generated during the multiple gray tracking calibrations in which actual measured colorimetric response display values are measured.
To avoid colors from ‘flashing’ (e.g., colors ‘popping’ due to sudden change in hue across gray levels), the (interpolated or synthesized) changes to correct the gray tracking vector (represented by correction table or equation) may be animated by an animation engine to smooth the transition from a current gray tracking correction table (or parametric solution) to a desired gray tracking correction table (or parametric solution) that corresponds to the current display characteristic value (e.g., moved white point). For example, the current and desired tables may be linearly interpolated to successively step between intermediate tables over a short period of time to gradually transition from the current gray gradient or vector to the desired gray vector, instead of instantly snapping to the new gray vector such that the step between any two successive correction steps doesn't cause displayed color to change by more than a perceived just noticeable difference (JND) perceivable by the viewer.
The native white point of a display device may be defined by a pair of chromaticity values (x, y) that represent the color produced by the device when the device generates all colors at full power. For example, when red, green, and blue channels for a display device are all active at full power (e.g., maximum voltage applied from display driver to each of the red, green, and blue sub-pixels of the display), the chromaticity values, as measured in Cartesian coordinates x and y with respect to a chromaticity diagram, are the native white point of the display device. White points may vary among display devices of the same type due to inherent properties such that when the red, green, and blue channels for a display device are all active at full power, the resulting (x, y) chromaticity value corresponding to the white point is different from the (x, y) chromaticity value corresponding to the white point of another display device when the red, green, and blue channels for the other display device are also all active at full power.
This native or original (uncorrected) white point of each display device may be corrected in a white point calibration process to be adjusted to a target white point which is consistent across multiple display devices that are of the same type (and therefore, are expected to have the same white point). For example, the target white point may correspond to the D65 illuminant of the CIE. In the white point calibration, each device may be tuned (e.g., in a factory) to the same target white point by adjusting display control settings such as gain values for the red, green, and blue channels individually. After the white point calibration, the deviation among the multiple devices may be reduced such that the (target) white point of the devices would be within a given range of target chromaticity coordinates (x0, y0)).
In addition to white point calibration, the display devices may be also subject to gray tracking calibration to faithfully reproduce the full range of gray levels from black to white (represented by the target white point) on the display device so that the shades of gray (e.g., linear range of R=G=B from 0 to 1) at different luminance levels will all appear to have the same hue as the target white point (e.g., target chromaticity coordinates (x0, y0))of the target white point.
However, several complexities inherent to the display devices (e.g., LCD-based display devices) limit utility of the gray tracking calibration (and corresponding generated pixel adjustment values) to a particular target white point of the display device that was used during actual measurements of colorimetric response display values based on which the corresponding pixel adjustment values were generated and stored in a correction table during the gray tracking calibration. That is, the gray tracking calibration begins to ‘break’ (e.g., gray tracking calibration gets de-tuned) when the target white point of the display device is moved from the white point where the gray tracking calibration was performed to a different white point (e.g., moved to chromaticity coordinates (x1, y1) from (x0, y0)).
Referring to
Lens assembly 105 may include a single lens or multiple lens, filters, and a physical housing unit (e.g., a barrel). One function of lens assembly 105 is to focus light from a scene onto image sensor 110. Image sensor 110 may, for example, be a CCD (charge-coupled device) or CMOS (complementary metal-oxide semiconductor) imager. Device 100 may include more than one lens assembly and more than one image sensor. Each lens assembly may focus light onto a single image sensor (at the same or different times) or different portions of a single image sensor.
IPP 115 may process image sensor output (e.g., RAW image data from sensor 110) to yield a HDR image, image sequence or video sequence. More specifically, IPP 115 may perform a number of different tasks including, but not be limited to, black level removal, de-noising, lens shading correction, white balance adjustment, demosaicing operations, and the application of local or global tone curves or maps. IPP 115 may also perform gray tracking across dynamically changing white point according to one or more embodiments. IPP 115 may comprise a custom designed integrated circuit, a programmable gate-array, a central processing unit (CPU), a graphical processing unit (GPU), memory or a combination of these elements (including more than one of any given element; non-transitory program storage device; programmable control device). Some functions provided by IPP 115 may be implemented at least in part via software (including firmware).
Display element (display device, display panel, or display) 120 may be a wide gamut display and may be used to display text and graphic output as well as receiving user input via user interface 125. For example, display element 120 may be a touch-sensitive display screen. User interface 125 can also take a variety of other forms such as a button, keypad, dial, a click wheel, and keyboard.
Processor 130 may be a system-on-chip (SOC) such as those found in mobile devices and include one or more dedicated CPUs and one or more GPUs. Processor 130 may be based on reduced instruction-set computer (RISC) or complex instruction-set computer (CISC) architectures or any other suitable architecture and each computing unit may include one or more processing cores. Graphics hardware 135 may be special purpose computational hardware for processing graphics and/or assisting processor 130 perform computational tasks. In one embodiment, graphics hardware 135 may include one or more programmable GPUs each of which may have one or more cores. Audio circuit 140 may include one or more microphones, one or more speakers and one or more audio codecs. Image processing circuit 145 may aid in the capture of still and video images from image sensor 110 and include at least one video codec. Image processing circuit 145 may work in concert with IPP 115, processor 130 and/or graphics hardware 135.
Images, once captured, may be stored in memory 150 and/or storage 155. Memory 150 may include one or more different types of media used by IPP 115, processor 130, graphics hardware 135, audio circuit 140, and image processing circuitry 145 to perform device functions. For example, memory 150 may include memory cache, read-only memory (ROM), and/or random access memory (RAM). Storage 155 may store media (e.g., audio, image and video files), computer program instructions or software, preference information, device profile information, and any other suitable data. Storage 155 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).
Device sensors 160 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.
Communication interface 165 may be used to connect device 100 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 165 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)). Communication network or fabric 170 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 (e.g., a cross-bar switch). In general, one or more of processor 130, graphics hardware 135 and image processing circuit 135 may be configured to render selected information (textual or graphic) in a designated or specified region within an image or frame.
Referring now to
Information relating to the source content 200 and source profile 202 may be sent to viewer 216's device containing the system 212 for performing gamma adjustment utilizing a LUT 210. Viewer 216's device may comprise, for example, a mobile phone, PDA, HMD, monitor, television, projector, or a laptop, desktop, or tablet computer. Upon receiving the source content 200 and source profile 202, system 212 may perform a color adaptation process 206 on the received data for performing gamut mapping, or color matching across various color spaces. For instance, gamut matching tries to preserve (as closely as possible) the relative relationships between colors, even if all the colors must be systematically distorted in order to get them to display on the destination device.
Once the source image had the source to destination gamut adaptation applied, image values may enter the so-called “framebuffer” 208. In some embodiments, image values entering framebuffer 208 having come from an application or applications that have already processed the image values to be encoded with a specific implicit gamma. A framebuffer may be defined as a video output device that drives a video display from a memory buffer containing a complete frame of, in this case, image data. The implicit gamma of the values entering the framebuffer can be visualized by looking at the “Framebuffer Gamma Function,” as will be explained further below in relation to
Because the Native Display Response isn't always exactly the inverse of the Framebuffer Gamma Function, a LUT, sometimes stored on a video card or in other memory, may be used to account for the imperfections in the relationship between the encoding gamma and decoding gamma values, as well as the display's particular luminance response characteristics. Thus, if necessary, system 212 may then utilize LUT 210 to perform a so-called “gamma adjustment process.” LUT 210 may comprise a two-column table of positive, real values spanning a particular range (e.g., from zero to one). The first column values may correspond to an input image value, whereas the second column value in the corresponding row of the LUT 210 may correspond to an output image value that the input image value will be “transformed” into before being ultimately displayed on display 214. LUT 210 may be used to account for the imperfections in the display 214's luminance response curve, also known as a transfer function. In other embodiments, a LUT may have separate channels for each primary color in a color space (e.g., a LUT may have Red, Green, and Blue channels in the sRGB color space). Alternately, LUT 210 may be a 3D LUT that includes a coordinate set of colors to directly transform an input coordinate set of colors to an output coordinate set.
The transformation applied by LUT 210 to the incoming framebuffer data before the data is output to the display device may be used to ensure that a desired 1.0 gamma boost is applied to the content that is being displayed on display device 214. An overall 1.0 gamma boost corresponds to a linear relationship between the digital values and the output luminance on the display device 214. Ideally, an overall 1.0 gamma boost will correspond to the source author's intended look of the displayed content.
Referring now to
Stated another way, the gamma characteristic of a system is an approximate relationship between the encoded digital values in the system and the actual desired image luminance on whatever the eventual user display device is. In existing systems, a computer processor or other suitable programmable control device may perform gamma adjustment computations for a particular display device it is in communication with based on the native luminance response of the display device, the color gamut of the device, and the device's white point (which may be stored in an ICC profile), as well as the ICC color profile the source content's author attached to the content to specify the content's “rendering intent.”
The ICC profile is a set of data that characterizes a color input or output device, or a color space, according to standards promulgated by the International Color Consortium (ICC). ICC profiles may describe the color attributes of a particular device or viewing requirement by defining a mapping between the device source or target color space and a profile connection space (PCS). Matrix/Tone Response Curve (TRC) type of ICC profiles may be used to define a color space mapping generically in terms of three main pieces: 1) the color primaries that define the gamut; 2) the transfer function (sometimes referred to as the gamma function); and 3) the white point. ICC profiles may also contain additional information (e.g., its TRC) to provide mapping between a display's actual response and its “advertised” response. An overall 1.0 gamma boost corresponds to a linear relationship between the input encoded digital values and the output luminance on the display device, meaning there is actually no amount of gamma “boosting” being applied.
Returning now to
The x-axis of Native Display Response function 302 represents input image values spanning a particular range (e.g., from zero to one). The y-axis of Native Display Response Function 302 represents output image values spanning a particular range (e.g., from zero to one). In theory, systems in which the decoding gamma is the inverse of the encoding gamma should produce the desired overall 1.0 gamma boost.
Referring now to
In addition to accounting for gamma calibration, LUT graph 400 may also be generated so as to account for the gray tracking calibration to faithfully reproduce the full range of gray levels from black to white on the display device so that the shades of gray (e.g., linear range of R=G=B from 0 to 1) at different luminance levels will all appear to have the same neutral hue for a given white point. Gray tracking calibration evaluates and corrects for non-linearities in each color channel for each gray step for both hue and brightness. Gray tracking calibration further evaluates and corrects for other issues like sub-pixel crosstalk, quarter wavelength shutter effects, thermal issues, and the like. For example, the red, green, and blue channels may be calibrated for the display device to produce true gray levels with the same neutral hue and corresponding brightness for all gray intensity levels from black to the target white point by actually measuring from the display device, at suitable points of gray intensity levels output to the display device, colorimetric response display values of uncorrected digital values. The measured colorimetric response values (actual pixel response) may then be analyzed to determine how they deviate from ‘ideal’ values and to generate adjustment values that produce the true (‘ideal’) gray levels with the display device for the associated white point. All values of interest may then be accurately interpolated for the associated white point based on the actual measurements at the suitable points of gray intensity levels to generate the adjustment values for all gray levels for hue and brightness for the associated white point. The gray tracking calibration can, for example, be based on one or more techniques described in U.S. Pat. No. 7,777,760 by Marcu, et al., which issued Aug. 17, 2010, and is hereby incorporated by reference in its entirety.
The pixel (e.g., digital values for RGB) adjustment values for gray tracking may be stored in the same LUT as LUT 210 for gamma correction or may be stored in a different LUT for gray tracking correction. LUT 210 may include, for example, a LUT for red values between 0 and 255, a LUT for green values between 0 and 255, and a LUT for blue values between 0 and 255. The LUTs for red, green, and blue values may be independent of each other and provide respective adjustment values for red, green, and blue independently for each of red, green, and blue color. Alternately, LUT 210 may be a 3D LUT in which respective adjustment values for red, green, and blue are interdependent.
Alternately, dynamic gray tracking engine 515 may be implemented in chipset, firmware, and/or software residing in the display device (e.g., display 120, 214, 1010 in
Calibration and measurement data 520 may represent correction tables or a plurality of LUTs (e.g., LUTs 210) generated during calibration of the display device (including, at least, the gray tracking calibration). As alluded to earlier, since modern consumer electronic devices (especially, mobile devices; e.g., electronic device 100 in
For example, in a factory during manufacture (or post-manufacture using specialized measurement equipment), display 120 (or 214, 1010 in
Display 120 (or 214, 1010 in
In another embodiment, the display 120 (or 214, 1010 in
In
Returning to
Input content 505 may include any content to be displayed on the display. For example, input content 505 may correspond to content output from framebuffer 208 shown in
Based on static and dynamic display characteristics 510 and 511, dynamic gray tracking engine 515 may access relevant calibration data 520 of one or more correction tables to update gray tracking of the particular display device. For example, based on a value (e.g., x-y chromaticity value) of a current set white point as a display characteristic, dynamic gray tracking engine 515 may access calibration data 520 of a correction table that corresponds to the current set white point. If such correction table is not available (e.g., calibration based on actual measured values for the current set white point has not been performed), dynamic gray tracking engine 515 may access calibration data 520 of two or more correction tables whose respective white point values are closest to the white point value of the current set white point. For example, when the white point is settable to be any value along black body curve 610 shown in
As another example, when the white point is settable to be any value in a 2D space within color space 715 shown in
In one embodiment, pixel adjustment values 530 may be in the form of a LUT (e.g., 1D LUT for each of red, green and blue, 3D LUT, and the like). Alternately, pixel adjustment values 530 may be implemented as a matrix, parametric solution, function, or other suitable implementation to correct pixel values before output to the display. In addition, although the above examples illustrate accessing calibration data 520 based on respective associated white point values and deriving pixel adjustment values 530 based on the current set white point value, functionality of dynamic gray tracking engine 515 is not so limited. For example, calibration data 520 of each correction table may have additional or alternative corresponding display characteristic values such as respective white point values, respective black point values, respective gamma values, respective temperatures, and the like. Further dynamic (current set) display characteristics 510 may also include one or more of current set white point value, current set black point value, current temperature, current set gamma, and the like. And based on one or more of the current set display characteristic values, calibration data from one or more correction tables having closest corresponding characteristic values may be accessed to derive pixel adjustment values 530 via interpolation module 525. Thus, dynamic gray tracking engine 515 may update the gray tracking based on a change in any of white point, black point, gamma, temperature, and the like, of the display device.
Gray gradient correction generator 535 may apply derived pixel adjustment values 530 to input content 505 to generate output content 550. For example, a different gray gradient (or vector) going from black to a current set white point (or any color set as the current white point) may be applied to each of red, green, and blue channels based on the derived pixel adjustment values 530.
As explained earlier, colors may ‘flash’ (or ‘pop’) when processing of output content 550 is suddenly switched from being performed with a new gray gradient (vector) that is based on current set display characteristics. For example, when the white point is moved to a new white point, colors in output content 550 may ‘pop’ if processing of content 550 is instantaneously switched to be performed using a new gray gradient generated by gray gradient correction generator 535 corresponding to the new white point. In one embodiment, animation engine 540 may animate the change in the gray gradient (e.g., pixel adjustment values 530) smoothly over a predetermined period of time. For example, animation engine 540 may linearly interpolate (LERP) along pixel adjustment values (LUTs or parametric solution) 530 smoothly from pixel adjustment values 530 based on previous display characteristics 510 (e.g., previous white point) to new pixel adjustment values 530 derived by interpolation module 525 to correspond to a dynamically changed and current display characteristic 510 (e.g., new set white point), so as to smoothly animate changes between the pixel adjustment values.
Smoothly transitioning between adjustment values from ‘current’ values to ‘target’ values via LERPed values (e.g., intermediary correction tables) may ensure that even if the LERPed values do not accurately adjust the gray tracking based on the current display state, the gray tracking gradient (and corresponding hues at different gray levels) would shift smoothly over a period of time imperceptibly to a viewer of the display (e.g., without being noticeable to the viewer or without calling the viewer's attention). That is, since pixel adjustment values 530 may be derived via interpolation by interpolation module 525, and since the source from which pixel adjustment values 530 are derived (e.g., calibration data 520) may itself, at least partially, be the result of interpolation, pixel adjustment values 530 may not be completely accurate. And snapping instantly to the derived pixel adjustment values 530 may cause ‘flashing’. Instead, by utilizing animation engine 540 to smoothly animate from ‘current’ values to the ‘target’ values as if there were multiple LERPed intermediate steps, change caused by each step being imperceptible to the previous step, would prevent drawing unnecessary attention from the viewer and gradually update gray tracking of the display to the ‘target’ values (e.g., LUTs, gray gradient, gray vector, and the like). The time period over which animation engine 540 may smoothly animate from the ‘current’ values to the ‘target’ values may be set to be long enough so that the changes to the displayed color remain imperceptible to the viewer. Further, the number of LERPed intermediate steps may be set to be as few as possible between the ‘current’ and ‘target’ values so that each step is ‘sub-JND’ to keep the changes to the displayed color imperceptible to the viewer. Animation engine 540 may also apply the smoothing animation techniques thereof via panel self-refresh so as not to wake or burden the CPU. For example, animation engine 540 may implement the smoothing animation techniques in the TCON chip or another hardware chip in the display device itself, such that the perceptually smooth animation between gray tracking correction vectors may be imlemented without waking up a host CPU of a computer system coupled to the display device.
In contrast to system 500 shown in
It has been unexpectedly discovered that crosstalk between channels (e.g., crosstalk between red, green and blue sub-pixels) is one of the primary factors that causes the gray tracking to ‘break’ when dynamic display characteristics 510 (e.g., white point) change or are moved. The sub-pixel crosstalk may originate from a variety of sources including mechanical coupling between channels (or sub-pixels), electromagnetic coupling or interference between channels, electrical coupling, mechanical coupling, thermal coupling, optical leakage between pixels in color LCDs, and the like.
Further, it has been unexpectedly discovered that another primary factor that causes the gray tracking to ‘break’ is associated with quarter wavelength issues. One example of quarter wavelength shutter issues relate to a phenomenon in which as an LCD shutter is opened to smaller portions, the shutter begins to provide filtration on the back light that actually warps through, thereby changing the spectrum of light output from the display device.
Mathematical model 825 may be developed based on calibration and measurement data 820 that encapsulates these primary factors without having to explicitly model (e.g., measure) each primary factor individually. In one embodiment, math model 825 may be a polynomial model (or equation) of order n that captures the highest non-linearity and that is trained using calibration and measurement 820 that include calibration data representing optimized measurements across white points and component brightness levels (or alternative/additional dynamic display characteristics 510), and then solving for coefficients in the polynomial equation. After developing and training math model 825, as the white point or other display characteristic 510 is dynamically moved or changed, dynamic gray tracking engine 815 may utilize math model 825 (which is very compact as compared to interpolated LUTs 530 or calibration data 520, 820) to compute pixel adjustment values 830 as a gray tracking correction table (e.g., 1D LUT, 3D LUT, and the like) or a parametric solution, based on math model 825.
In one embodiment, math model 825 may be implemented as a system of equations in which variables may represent one or more primary factors. For example, the system of equations may model a linear system in which various sources of sub-pixel crosstalk have an additive effect on output (e.g., energizing one channel has an additive effect on another channel). An exemplary linear crosstalk system underlying math model 825 is illustrated below.
Re=Rd+GR*Gd+BR*Bd
Ge=RG*Rd+Gd+BG*Bd
Be=RB*Rd+GB*Gd+Bd
In the above crosstalk system, Re represents effective red, Rd represents desired red, Ge represents effective green, Gd represents desired green, Be represents effective blue, and Bd represents desired blue. Further, GR represents effect of the green sub-pixel (or channel) on the red sub-pixel (or channel), BR represents effect of the blue sub-pixel (or channel) on the red sub-pixel (or channel), RG represents effect of the red sub-pixel (or channel) on the green sub-pixel (or channel), BG represents effect of the blue sub-pixel (or channel) on the green sub-pixel (or channel), RB represents effect of the red sub-pixel (or channel) on the blue sub-pixel (or channel), and GB represents effect of the green sub-pixel (or channel) on the blue sub-pixel (or channel). The six coefficients GR, BR, RG, BG, RB, and GB are solved for in the calibration process, or based on the data captured at calibration.
In one embodiment, math model 825 may be trained by taking measurements that solve simultaneous equations for the six coefficients in crosstalk correlation in the exemplary linear crosstalk system identified above. Trained math model 825 may then be utilized to build (synthesize) 3×1D LUTs for red, green, and blue color channels, 3D LUT, or a parametric solution 830 implemented as a shader or bespoke hardware to correct gray tracking for any specific white point or other dynamic display characteristic 510 (e.g., black point, temperature, gamma, and the like) set for the particular display device. Math model 825 may further be trained to consider asymmetricity of the effect between sub-pixels, and/or that driving one sub-pixel might have a negative influence on driving an adjacent sub-pixel. Thus, math model 825 may be able to account for constant changes in as many characteristics 510 as desired and dynamically synthesize a LUT or parametric solution 830. In one embodiment, math model 825 may be updated so that as phenomena of additional primary, secondary, or tertiary factors that cause gray tracking to ‘break’ become well understood, the additional factors may be modeled as well based on additional independent measurements to control pixel adjustment values 830 for the additional factors.
Math model 825 may also be built as an analytical model, artificial intelligence model, polynomial model, function, or the like, based on the actually measured calibration data 520 of multiple correction tables of
In one embodiment, the precision of interpolated or computed pixel adjustment values in LUTs 530, 830 (e.g., number of bits per code) may be higher than what the display device may be capable of displaying. Image processing techniques such as spatial or temporal dithering, frame rate control, and the like may then be utilized by a display driver to display on the display device output content 550 that has been corrected using LUTs 530, 830 with the higher precision. Spatial or temporal dithering techniques may also be utilized when animation engine 540 smoothly animates from ‘current’ values to the ‘target’ values via multiple LERPed intermediate steps so that the changes to the displayed color remain imperceptible to the viewer. For example, if animation engine 540 determines that finer grained multiple LERPed intermediate steps are required to achieve ‘sub-JND’ gray tracking correction vectors for a system implemented to have a given precision level, animation engine 540 may employ spatial or temporal dithering to generate these ‘partial’ intermediate steps. In one embodiment, the dither could be of a pre-truncation, non-subtractive type, and may be applied spatially (such that identical neighboring pixels would stochastically resolve to different values), or temporally (such that successive, potentially identical frames, would stochastically resolve to different values). In either case, a reconstruction filter (inherent in human perception, and possibly in the physics of the display device) would integrate to the desired higher precision intermediate step.
Elements 530, 830 may also be implemented as a parametric solution instead of synthesizing or interpolating a correction table. That is, instead of storing calibration and measurement data 520, 820 as correction tables, the data may be analyzed and a parametric representation (e.g., system of equations) of the tables based on the analysis may be created, stored, and utilized for calculating adjustment values 530, 830 for any dynamic display characteristic 510 such as white point, black point, gamma, temperature, and the like. For example, coefficients of math model 825 may dynamically modify pixel values based on changing display characteristics 510 via a shader or other custom hardware, without utilizing a LUT.
At block 910, electronic device 100 may set one or more display characteristics (e.g., white point, black point, gamma, display panel temperature) to a first state based on sensor 160 data. Based on the set display characteristics, at block 915, dynamic gray tracking engine 515, 815 may drive the display device so that input content 505 pixel values are corrected using pixel adjustment values 530, 830 (derived via interpolation or computation) to output content 550 pixel values for output to display 120. At block 920, electronic device 100 may dynamically change one or more display characteristics 510 based on user operation or sensor 160 data. For example, electronic device 100 may detect an updated temperature reading of the display panel or may change the white point based on data from an ambient light sensor. Based on the updated display characteristics, at block 925, dynamic gray tracking engine 515, 815 may update the gray tracking using calibration and measurement data 520, 820 or based on math model 825 derived therefrom to update pixel adjustment values 530, 830. The updated correction values or equations may then be used to correct pixel values of input content 505 to generate corrected output content 550. At block 930, animation engine 540 may animate the changes to the adjustment values over time to smooth the transition from utilizing the previous pixel adjustment values or equations 530, 830 to the updated pixel adjustment values or equations 530, 830, so as to avoid drawing viewer's attention to the changing gray level hues based on the updated gray tracking. At block 935, a display driver may drive the display with the updated pixel adjustment values 530, 830 with the smoothing animation over a short period of time by animation engine 540.
Referring to
Processor 1005 may execute instructions necessary to carry out or control the operation of many functions performed by a multi-functional electronic device 1000 (e.g., such as gray tracking correction). Processor 1005 may, for instance, drive display 1010 and receive user input from user interface 1015. User interface 1015 can take a variety of forms, such as a button, keypad, dial, a click wheel, keyboard, display screen and/or a touch screen. Processor 1005 may be a system-on-chip such as those found in mobile devices and include a dedicated graphics-processing unit (GPU). Processor 1005 may represent multiple central processing units (CPUs) and may be based on reduced instruction-set computer (RISC) or complex instruction-set computer (CISC) architectures or any other suitable architecture and each may include one or more processing cores. Graphics hardware 1020 may be special purpose computational hardware for processing graphics and/or assisting processor 1005 process graphics information. In one embodiment, graphics hardware 1020 may include one or more programmable graphics-processing unit (GPU), where each such unit has multiple cores.
Sensor and camera circuitry 1050 may capture still and video images that may be processed to generate images in accordance with this disclosure. Sensor in sensor and camera circuitry 1050 may capture raw image data as red, green, and blue (RGB) data that is processed to generate an image. Output from camera circuitry 1050 may be processed, at least in part, by video codec(s) 1055 and/or processor 1005 and/or graphics hardware 1020, and/or a dedicated image-processing unit incorporated within camera circuitry 1050. Images so captured may be stored in memory 1060 and/or storage 1065. Memory 1060 may include one or more different types of media used by processor 1005, graphics hardware 1020, and camera circuitry 1050 to perform device functions. For example, memory 1060 may include memory cache, read-only memory (ROM), and/or random access memory (RAM). Storage 1065 may store media (e.g., audio, image and video files), computer program instructions or software, preference information, device profile information, and any other suitable data. Storage 1065 may include one more non-transitory storage mediums including, for example, magnetic disks (fixed, floppy, and removable) and tape, optical media such as compact disc-ROMs (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 1060 and storage 1065 may be used to retain computer program instructions or code organized into one or more modules and written in any desired computer programming language. When executed by, for example, processor 805 such computer program code may implement one or more of the methods described herein.
Referring to
As used herein, the term “computer system” or “computing system” refers to a single electronic computing device or to two or more electronic devices working together to perform the function described as being performed on or by the computing system. This includes, by way of example, a single laptop, host computer system, wearable electronic device, and/or mobile device (e.g., smartphone, tablet, and/or other smart device).
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 claimed subject matter as described herein, 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, while
At least one embodiment is disclosed and variations, combinations, and/or modifications of the embodiment(s) and/or features of the embodiment(s) made by a person having ordinary skill in the art are within the scope of the disclosure. Alternative embodiments that result from combining, integrating, and/or omitting features of the embodiment(s) are also within the scope of the disclosure. Where numerical ranges or limitations are expressly stated, such express ranges or limitations may be understood to include iterative ranges or limitations of like magnitude falling within the expressly stated ranges or limitations (e.g., from about 1 to about 10 includes, 2, 3, 4, etc.; greater than 0.10 includes 0.11, 0.12, 0.13, etc.). The use of the term “about” means ±10% of the subsequent number, unless otherwise stated.
Many other embodiments will be apparent to those of skill in the art upon reviewing the above description. The scope of the invention therefore should be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled. In the appended claims, the terms “including” and “in which” are used as the plain-English equivalents of the respective terms “comprising” and “wherein.”