In portable electronic devices (e.g., laptop computers) configured to function using battery power, methods and systems that efficiently control power consumption are important. In particular, the power consumed by an electronic display may be significant. Therefore, methods and systems that decrease power consumption by electronic displays are desirable. Further, methods and systems that selectively combine different technologies to control power consumption by electronic displays are desirable.
For a detailed description of exemplary embodiments of the invention, reference will now be made to the accompanying drawings in which:
Certain terms are used throughout the following description and claims to refer to particular system components. As one skilled in the art will appreciate, computer companies may refer to a component by different names. This document does not intend to distinguish between components that differ in name but not function. In the following discussion and in the claims, the terms “including” and “comprising” are used in an open-ended fashion, and thus should be interpreted to mean “including, but not limited to . . . .” Also, the term “couple” or “couples” is intended to mean either an indirect or direct electrical connection. Thus, if a first device couples to a second device, that connection may be through a direct electrical connection, or through an indirect electrical connection via other devices and connections. The term “system” refers to a collection of two or more parts and may be used to refer to a computer system or a portion of a computer system. The term “graphics” refers to text, images, or other information displayable by an electronic display.
As disclosed herein, embodiments of the invention control electronic display brightness. In some embodiments this is accomplished by selectively implementing control parameters associated with different technologies. In at least some embodiments, two or more controllers are implemented. The first controller (e.g., a graphics controller) is configured to output a first control signal based on a first technology (e.g., a technology that controls display brightness based on graphics shown or graphics to be shown on an electronic display). The second controller is configured to receive and interpret the first control signal as well as control signals associated with other technologies. Each interpreted control signal is associated with a unique control parameter. The second controller selectively combines the effect of the control parameters to provide a signal that efficiently controls electronic display brightness.
A user or manufacturer may choose not to employ hardware/software or licenses necessary to implement a particular technology. Additionally, a technology may not be compatible with some embodiments. In some embodiments, if the second controller determines that the first controller is not present or is otherwise not providing a valid first control signal, the second controller is configured to automatically control electronic display brightness based on one or more of the other control signals. Therefore, some embodiments of the invention enable interpretation and combination of electronic display control signals to permit efficient power consumption by an electronic display. The control signals may be generated by controllers that operate independently of each other. Some embodiments of the invention also enable redundancy and improved efficiency in an environment in which compatibility problems may exist or may change over time.
To decrease power consumption of a display 140 illuminated, for example, by a backlight 142, the system 100 implements two controllers. The first controller is the graphics controller 118 which outputs a first control signal 120 based on graphics shown or graphics to be shown on the display 140. In at least some embodiments, the first control signal 120 is generated when the processor 102 executes a backlight application 106 and a graphics driver 108 stored in the local memory 106. Alternatively, the graphics controller 118 may execute the backlight application 106 and the graphics driver 108, thereby freeing the processor 102 to perform other tasks.
The graphics driver 108, when executed, enables the processor 102 (or the graphics controller 118) to access graphics data 109 stored in the local memory 104 and convert the graphics data 109 to a signal 148 that produces an image on the display 140. Although the graphics data 109 is described as being stored in the local memory 104, the graphics data 109 may alternatively be stored in a memory (not specifically shown) of the graphics controller 118. The graphics data 109 may be generated, for example, when the processor 102 executes or installs one or more software applications.
The backlight application 106, when executed, causes the processor 102 to examine the graphics data 109. For example, examining the graphics data 109 enables the processor 102 to determine the position/quantity of light pixels, the position/quantity of dark pixels, or an average grayscale of pixels. In response to examining the graphics data 109, the processor 102 asserts a signal 110 that causes the graphics controller 118 to output a control signal 120 capable of dynamically controlling electronic display brightness based on the graphics data 109. Alternatively, the graphics controller 118 may be configured to execute the backlight application 106 and to generate the first control signal 120 without the processor 102 nor the signal 110, thereby freeing the processor 102 to perform other tasks.
The first control signal 120 may be a pulse-width modulation (PWM) signal interpretable by a backlight inverter 136. Rather than provide the first control signal 120 directly to the backlight inverter 136, the graphics controller 118 couples to and outputs the first control signal 120 to a second controller, for example, an embedded controller 122.
As shown in
The cycle-width estimator 202 estimates the duration of a pulse-width modulation cycle by counting a number of clock cycles (of the clock signal 210) between subsequent rising edges of the first control signal 120. The pulse-width estimator 204 estimates the duration of a pulse by counting a number of clock cycles (of the clock signal 210) between rising edges and subsequent falling edges (i.e., between each pulse) of the first control signal 120. The duty-cycle estimator 208 receives a clock count from each of the cycle-width estimator 202 and the pulse-width estimator 204 and outputs a signal that indicates the estimated duty-cycle. For example, if the clock count from the cycle-width estimator 202 is 40 and the clock count from the pulse-width estimator 204 is 30, the duty-cycle estimator 208 outputs a signal that indicates the duty-cycle is 75% (i.e., the pulse is “on” or “high” for 75% of each modulated cycle).
In alternative embodiments, the cycle-width estimator 202 may simply estimate the “low-pulse” duration (i.e., when the pulse is “off” or “low”) rather than the entire modulated cycle duration. For example, the low-pulse duration may be estimated by counting a number of clock cycles (of the clock signal 210) between falling edges and subsequent rising edges (i.e., between each low pulse) of the first control signal 120. In such embodiments, the duty-cycle estimator 208 compares the clock count from the pulse-width estimator 204 with the clock count of the low-pulse duration and outputs a signal that indicates the estimated duty-cycle. For example, if the clock count from the pulse-width estimator 202 is 20 and the clock count of the low-pulse duration is 20, the duty-cycle estimator 208 may output a signal that indicates the duty-cycle is 50% (i.e., the pulse is “on” or “high” for one-half or 50% of each modulated cycle).
Optionally, if the “on” or “high” voltage associated with pulses of the first control signal 120 is not known, the pulse-height estimator 218 shown in
Returning to
In the exemplary embodiment of
Additionally or alternatively, the embedded controller 122 may be configured to receive hardware/software inventory information (e.g., information that indicates whether certain hardware/software has been installed in the system 100) that indicates whether a given signal does or should exist. If the embedded controller 122 does not receive a given signal that should exist, an alert or message may be generated to notify a user of the problem. Likewise, if the embedded controller 122 receives the given signal (e.g., the voltage level associated with the signal is equal to or greater than a threshold level), but the frequency and/or the magnitude of the given signal does not fall within a predetermined “valid” threshold associated with the given signal, the embedded controller 122 may automatically identify the given signal as invalid. Upon identifying an invalid signal, the embedded controller 122 may generate an alert or message to notify a user of the problem. In some embodiments, a value associated with a given control parameter changes based on whether a signal associated with the given control parameter exists (or is available) and whether the signal is valid. Thus, the control parameters 130 can be used to identify whether a signal (e.g., signal 120, 152, 162, 172) exists and whether a signal is valid.
In some embodiments, the backlight algorithm 128 implements the control parameters 130 and outputs a signal that takes some or all of the control parameters 130 into account. For example, the backlight algorithm 128 may differently weight each of the control parameters 130. Additionally or alternatively, the control parameters 130 may be prioritized according to a predetermined prioritization that minimizes power consumption by the backlight 142 in a variety of situations encompassed (i.e., describable) by the control parameters 142. In some embodiments, a user can adjust the effect of the control parameters 130 on the backlight algorithm 128.
As an example, the backlight illumination provided by the backlight algorithm 128 is generally described the equation (1) shown below:
Backlight illumination=F(CP1, CP2, CP3, CP4); (1)
In equation 1, the backlight illumination is a function (F) of the control parameters 130 (CP1, CP2, CP3, CP4). CP1 is a numeric value associated with the first control signal 120, CP2 is a numeric value associated with the signal 152, CP3 is a numeric value associated with the signal 162 and CP4 is a numeric value associated with the signal 172. The numeric value associated with each control parameter 130 may be unique and may be based on a range of possible values provided by the signals 120, 152, 162 and 172.
An example of the function, F(CP1, CP2, CP3, CP4), is described in the equation (2) shown below:
Backlight illumination=α*CP1+β*CP2+λ*CP3+ζ*CP4 (2)
In equation 2, each control parameter 130 (CP1, CP2, CP3, CP4) is multiplied by a variable (α, β, λ, and ζ) and the results added together. Each variable may be set or reset to a default value when the system 100 is “powered up.” The default values may be predetermined to minimize power consumption by a backlight 142 and may be adjustable by a user. In some embodiments, the value affixed to each variable may be adjusted within a range (e.g., −1.00 to 1.00 or 0.00 to 1.00) assigned to each variable. Each variable may be automatically adjusted based on the validity of each control parameter 130.
Sometimes the validity (utility) of one or more of the control parameters 130 may be affected by a manufacturer or a user of the system 100. Additionally, one or more components (e.g., the graphics controller 118, the local memory 104, the PWM interpreter 124, the input device 150, the power supply 160, the light sensor 170) of the system 100 that affect the control parameters 130 may be temporarily or permanently disabled. Therefore, embodiments of the invention enable the ability to adjust, ignore or disable one or more of the control parameters 130 while permitting uninterrupted backlight control based on remaining control parameters 130, thus, providing a wide variety of desirable functions.
For example, if one or more of the backlight application 106, the graphics driver 108 or the graphics controller 118 is not functioning (e.g., due to a fault, incompatibility or exclusion from the system 100), the first control signal 120 and, consequently, the control parameter 130 (CP1) based on the first control signal 120 is likely to be invalid or nonexistent. Therefore, the control unit 126 of the embedded controller 122 is configured to detect when the first control signal 120 (or the output from the PWM interpreter 124) is invalid or does not exist and cause the variable associated with CP, (in the above example, “α”) to equal zero. The control unit 126 may accordingly adjust the weights of the remaining control parameters 130.
The control unit 126 also may be configured to detect whether one or more of the other signals 152, 162 and 172 are invalid or nonexistent. If any of these signals is determined to be invalid, the control unit 126 may “zero out” or nullify the variable associated the consequently invalid control parameter 130 and cause the backlight algorithm 128 to continue functioning using the remaining control parameters 130.
In at least some embodiments, the function (F) of the backlight algorithm 128 allows continuous control of electronic display brightness, even when one or more components that affect the control parameters 130 stops functioning or is faulty (or not detected) when the system 100 “powers up.” Additionally, the control unit 126 may be configured to automatically activate the use of a control parameter 130 when a determination is made that a signal (e.g., the first control signal 120, the signal 152, the signal 162 or the signal 172) associated with the respective control parameter 130 is valid. Therefore, when a manufacturer or user installs (or repairs) the hardware, software, or licenses necessary to provide a valid control signal, the control unit 126 activates (or re-activates) a corresponding control parameter 130 of the backlight algorithm 128.
The control unit 126 outputs a signal to the PWM generator 132 based on the backlight algorithm 128 and the control parameters 130. The PWM generator 132 then outputs a corresponding PWM signal 134 to the backlight inverter 136. The backlight inverter 136 converts the PWM signal 134 to a signal 138 compatible with the backlight 142. The signal 138 causes the backlight 142 to emit light at an intensity determined by the PWM signal 134.
In order to control an amount of illumination provided by the backlight 306, the electronic device 300 implements the components previously described in
For example, an embedded controller (e.g., a keyboard controller or a power supply controller) as described for
For example, controlling the backlight 306 based on graphics, ambient light and power remaining in the battery 310 provides improved efficiency compared to implementing any of the techniques individually. In some embodiments, the backlight 306 is controlled automatically (e.g., based on graphic content, an amount of ambient light, and remaining battery power), while also permitting a user some degree of control. Additionally, the backlight control signal may be configured to adjust the backlight brightness slowly (e.g., over a time period such as 5 minutes) such that a user does not notice (at least the likelihood that a user notices is decreased) when the backlight brightness is changing.
At block 412, a determination is made whether a valid signal based on user input is available. If a valid signal based on user input is not available, a user input parameter of the algorithm is nullified (block 414). At block 414, a determination is made whether a valid signal based on a power supply is available. If a valid signal based on user input is not available, a power supply parameters of the algorithm is nullified (block 416). At block 420, electronic display brightness may be controlled based on the parameters that have not been nullified.
The above discussion is meant to be illustrative of the principles and various embodiments of the present invention. Numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. For example,
Number | Name | Date | Kind |
---|---|---|---|
5786801 | Ichise et al. | Jul 1998 | A |
6078302 | Suzuki et al. | Jun 2000 | A |
6094185 | Shirriff | Jul 2000 | A |
6188433 | Orbock | Feb 2001 | B1 |
6411306 | Miller et al. | Jun 2002 | B1 |
6520912 | Brooks et al. | Feb 2003 | B1 |
6795053 | Funamoto et al. | Sep 2004 | B1 |
7136076 | Evanicky et al. | Nov 2006 | B2 |
7233307 | Miura et al. | Jun 2007 | B2 |
7265743 | Funamoto et al. | Sep 2007 | B2 |
20030071657 | Soerensen et al. | Apr 2003 | A1 |
20030169226 | Yamada | Sep 2003 | A1 |
20040085276 | Kim | May 2004 | A1 |
20040104886 | Kawano | Jun 2004 | A1 |
20040160435 | Cui et al. | Aug 2004 | A1 |
Number | Date | Country |
---|---|---|
1223570 | Jul 2002 | EP |
2003319291 | Jul 2003 | JP |
2003084857 | Aug 2003 | JP |
2003226062 | Dec 2003 | JP |
Number | Date | Country | |
---|---|---|---|
20060119564 A1 | Jun 2006 | US |