US20190107875A1 - Latency-Based Energy Storage Device Selection - Google Patents

Latency-Based Energy Storage Device Selection Download PDF

Info

Publication number
US20190107875A1
US20190107875A1 US15/944,500 US201815944500A US2019107875A1 US 20190107875 A1 US20190107875 A1 US 20190107875A1 US 201815944500 A US201815944500 A US 201815944500A US 2019107875 A1 US2019107875 A1 US 2019107875A1
Authority
US
United States
Prior art keywords
energy storage
latency
power
storage devices
devices
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US15/944,500
Inventor
Anirudh Badam
Ranveer Chandra
Nissanka Arachchige Bodhi Priyantha
Jonathan Alan Dutra
Julia L. Meinershagen
Stephen E. Hodges
Thomas Moscibroda
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Microsoft Technology Licensing LLC
Original Assignee
Microsoft Technology Licensing LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Microsoft Technology Licensing LLC filed Critical Microsoft Technology Licensing LLC
Priority to US15/944,500 priority Critical patent/US20190107875A1/en
Assigned to MICROSOFT TECHNOLOGY LICENSING, LLC reassignment MICROSOFT TECHNOLOGY LICENSING, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DUTRA, Jonathan Alan, HODGES, STEPHEN E., PRIYANTHA, NISSANKA ARACHCHIGE BODHI, MOSCIBRODA, THOMAS, BADAM, ANIRUDH, CHANDRA, RANVEER, MEINERSHAGEN, JULIA L.
Publication of US20190107875A1 publication Critical patent/US20190107875A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/263Arrangements for using multiple switchable power supplies, e.g. battery and AC
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3206Monitoring of events, devices or parameters that trigger a change in power modality
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/329Power saving characterised by the action undertaken by task scheduling

Definitions

  • Mobile computing devices provide various functionality to users, allowing the user to interact with the device to check email, surf the web, compose text messages, interact with applications, and so on.
  • One challenge that faces developers of mobile computing devices is efficient power management and extension of battery life. For example, extended processing of tasks by processors at or near capacity may drain the device battery, causing the device to shut down.
  • Various power management strategies may be applied to control processor and battery utilization generally at the expense of overall device performance. If power management implemented for a device fails to strike a good balance between performance and battery life, user dissatisfaction with the device and manufacturer may result.
  • latency behavior of computing tasks performed by a computing device is predicted for a period of time. Based on the predicted latency behavior of the computing device over the period of time, an assessment is made regarding which of the multiple heterogeneous energy storage devices are most appropriate to service the system workload. For example, high power density devices may be favored for latency sensitive tasks whereas high energy density devices may be favored when latency sensitivity is not a concern.
  • a combination of energy storage devices to service the current workload is selected based upon the latency considerations and then power supply settings are adjusted to cause supply of power from the selected combination of energy storage devices during the time period. This may involve setting a power ratio to control power draw from the multiple heterogeneous energy storage devices as designated for the predicted latency behavior.
  • FIG. 1 illustrates an operating environment in accordance with one or more embodiments.
  • FIG. 2 depicts example details of a computing device having an energy storage device system with heterogeneous energy storage devices in accordance with one or more implementations.
  • FIG. 3 depicts one illustrative example arrangement of an energy storage device system having multiple energy storage devices that are battery cells.
  • FIG. 4 depicts example details of a system having heterogeneous energy storage devices in accordance with one or more implementations.
  • FIG. 5 is a flow diagram that describes details of an example procedure for latency-based energy storage device selection in accordance with one or more implementations
  • FIG. 6 is a flow diagram that describes details of another example procedure for latency-based energy storage device selection in accordance with one or more implementations.
  • FIG. 7 illustrates an example system that includes an example computing device that is representative of one or more computing systems and/or devices that may implement the various techniques described herein.
  • Latency-based energy storage device selection is described for a device having an energy storage device system with heterogeneous energy storage devices, such as heterogeneous battery cells.
  • the heterogeneous energy storage devices include two or more energy storage devices having various different characteristics such as different sizes, capacities, technologies, chemistries, shapes, state of charge (SOC), age, temperature, cycle counts, and so forth. These different characteristics result in different energy storage devices being better suited for different types of operations and scenarios.
  • one energy storage device may be a high power density device more efficient at providing larger amounts of energy over shorter amounts of time (e.g., during latency sensitive tasks such as video processing) and another energy storage device may be a high energy density device more efficient at providing smaller amounts of energy over longer amounts of time (e.g., while a device is in a low-power usage or energy saving mode).
  • a high power density device charges fast and are capable of supplying a high power output.
  • a high energy density device is designed to operate efficiently, but provides lower power output and may be more susceptible to aging and degradation from repeated charge cycles.
  • the techniques discussed herein use latency behavior information regarding applications, computing tasks, interaction scenarios and/or past usage of a computing device to assess latency sensitivity of a workload and adjust power draws across multiple heterogeneous energy storage devices. Adjusting the combination of storage devices used for different levels of latency sensitivity as discussed in this document improves performance and efficiency of the energy storage device system both in the short term for handling latency sensitive tasks and over time as individual devices age and cycle counts increase.
  • a section titled “Operating Environment” is provided and describes one example environment in which one or more implementations can be employed. Following this, a section titled “Latency-Based Energy Storage Device Selection System Details” describes example details and procedures in accordance with one or more implementations. Last, a section titled “Example System” describes example computing systems, components, and devices that can be utilized for one or more implementations of latency-based energy storage device selection.
  • FIG. 1 illustrates an operating environment in accordance with one or more embodiments, generally at 100 .
  • the environment 100 includes a computing device 102 having a processing system 104 with one or more processors and devices (e.g., CPUs, GPUs, microcontrollers, hardware elements, fixed logic devices, etc.), one or more computer-readable media 106 , an operating system 108 , and one or more applications 110 that reside on the computer-readable media and which are executable by the processing system.
  • the processing system 104 may be configured to include multiple independent processors configured in parallel or in series and one or more multi-core processing units.
  • a multi-core processing unit may have two or more processors (“cores”) included on the same chip or integrated circuit.
  • the processing system 104 may include multiple processing cores that provide a range of performance capabilities, processing efficiencies, and power usage characteristics.
  • the processing system 104 may retrieve and execute computer-program instructions from applications 110 to provide a wide range of functionality to the computing device 102 , including but not limited to gaming, office productivity, email, media management, printing, networking, web-browsing, and so forth.
  • applications 110 may also be included, examples of which include game files, office documents, multimedia files, emails, data files, web pages, user profile and/or preference data, and so forth.
  • the computing device 102 can be embodied as any suitable computing system and/or device such as, by way of example and not limitation, a gaming system, a desktop computer, a portable computer, a tablet or slate computer, a handheld computer such as a personal digital assistant (PDA), a cell phone, a set-top box, a wearable device (e.g., watch, band, glasses, etc.), and the like.
  • a gaming system e.g., a desktop computer, a portable computer, a tablet or slate computer, a handheld computer such as a personal digital assistant (PDA), a cell phone, a set-top box, a wearable device (e.g., watch, band, glasses, etc.), and the like.
  • PDA personal digital assistant
  • the computing device 102 can be implemented as a television client device 112 , a computer 114 , and/or a gaming system 116 that is connected to a display device 118 to display media content.
  • the computing device may be any type of portable computer,
  • a computing device may also be configured as a wearable device 124 that is designed to be worn by, attached to, carried by, or otherwise transported by a user.
  • wearable devices 124 depicted in FIG. 1 include glasses, a smart band or watch, and a pod device such as clip-on fitness device, media player, or tracker.
  • Other examples of wearable devices 124 include but are not limited to badges, a key fob, an access card, and a ring, an article of clothing, a glove, or a bracelet, to name a few examples.
  • Any of the computing devices can be implemented with various components, such as one or more processors and memory devices, as well as with any combination of differing components.
  • One example of a computing system that can represent various systems and/or devices including the computing device 102 is shown and described below in relation to FIG. 7 .
  • the computer-readable media can include, by way of example and not limitation, all forms of volatile and non-volatile memory and/or storage media that are typically associated with a computing device. Such media can include ROM, RAM, flash memory, hard disk, removable media and the like. Computer-readable media can include both “computer-readable storage media” and “communication media,” examples of which can be found in the discussion of the example computing system of FIG. 7 .
  • the computing device 102 may also include a power manager 126 that includes or makes use of a latency estimator 127 , and an energy storage device system 128 having multiple heterogeneous energy storage devices that operate as described above and below.
  • the power manager 126 represents functionality operable to manage power for the computing device in various ways. For example the power manager 126 may assess system-wide power management considerations and manage availability heterogeneous energy storage devices, processors, and/or processing cores based on the assessment.
  • the power manager 126 is configured to implement a switching policy established based on power management considerations to control the battery system 128 . The switching policy depends at least upon latency considerations as discussed herein.
  • the latency estimator 127 represents functionality that the power manager may include, invoke, or otherwise make use of to determine latency behavior for a current workload (also referred to herein as usage behavior) of the computing device 102 and manage heterogeneous energy storage devices of the energy storage device system 128 accordingly. This may involve analyzing factors including but not limited to energy storage device characteristics, latency sensitivity of different tasks, application specific latency considerations, estimated or predicted future usage and latency behavior of the computing device 102 , estimated future energy usage of the computing device 102 over a given time period (e.g., a day), and so forth.
  • the assessment may further involve analyzing other factors including but not limited to, charge levels/states, the device power state, actual and expected workloads, thermal conditions, user presence, processor/core utilization, application context, device context, priority, contextual clues, and other suitable performance metrics that may be used to drive power management decisions at the system level.
  • Different types of applications, tasks, and scenarios may be assigned pre-computed latency sensitivity values that are used by the latency estimator 127 to determine latency behavior for a current workload.
  • Latency estimator 127 may additionally operate to estimate or predict latency sensitivity values “on-demand” using the various factors when pre-computed values are not available.
  • the power manager 126 is further configured to apply the switching policy to adjust the performance of the battery system 128 based on the assessment of system-wide performance metrics and conditions (e.g., analyzing an operational context for the device), including at least latency sensitivity associated with current workload. Applying the switching policy may involve controlling modes of different energy storage devices (e.g., cells), states of individual energy storage devices and/or availability of heterogeneous energy storage devices included with an energy storage system 128 .
  • the power manager 126 is operable to communicate control signals or otherwise interact with the energy storage system 128 to direct operation of switching hardware to switch between heterogeneous battery cells to service the load in accordance with the switching policy and analysis of the operational context.
  • the energy storage device system 128 is configured to include multiple heterogeneous energy storage devices. Energy storage devices may be configured in various ways and be implemented in various combinations of as discussed in greater detail below.
  • the power manager 126 and energy storage device system 128 may be provided using any suitable combination of hardware, software, firmware, and/or logic devices. As illustrated, the power manager 126 and energy storage device system 128 may be configured as separate, standalone systems. In addition or alternatively, the power manager 126 may also be configured as a system or module that is combined with the operating system 108 or implemented via a controller or other component of the energy storage device system 128 . Details regarding these and other aspects of latency-based energy storage device selection are discussed in the following section.
  • the environment 100 further depicts that the computing device 102 may be communicatively coupled via a network 130 to a service provider 132 , which enables the computing device 102 to access and interact with various resources 134 made available by the service provider 132 .
  • the resources 134 can include any suitable combination of content and/or services typically made available over a network by one or more service providers.
  • content can include various combinations of text, video, ads, audio, multi-media streams, applications, animations, images, webpages, and the like.
  • Some examples of services include, but are not limited to, an online computing service (e.g., “cloud” computing), an authentication service, web-based applications, a file storage and collaboration service, a search service, messaging services such as email and/or instant messaging, and a social networking service.
  • FIG. 2 depicts generally at 200 example details of a computing device 102 having an energy storage device system 128 with heterogeneous energy storage devices in accordance with one or more implementations.
  • Computing device 102 also includes processing system 104 , computer readable media 106 , operating system 108 and applications 110 as discussed in relation to FIG. 1 .
  • a power manager 126 is also shown as being implemented as a component of the operating system 108 .
  • the energy storage device system 128 is depicted as having energy storage devices 202 and an energy storage device controller 204 .
  • the energy storage devices 202 are representative of various different kinds of energy storage devices that may be included with the computing device 102 . These energy storage devices can include, for example, battery cells, supercapacitors, and so forth. It should be noted that these energy storage devices include various devices that store energy as opposed to being an external plug-in AC power source. As mentioned, energy storage devices 202 include energy storage devices having different characteristics such as different sizes/capacities, chemistries, battery technologies, shapes, state of charge (SOC), age, temperature, and so forth (heterogeneous energy storage devices).
  • heterogeneous energy storage devices may include either or both of different types of devices designed with different properties and devices having the same or similar properties by design, but having different state characteristics.
  • the energy storage device system 128 includes a diverse combination of multiple energy storage devices at least some of which have different characteristics one to another.
  • some energy storage devices 202 may be the same and still be part of the energy storage device system 128 (e.g., the energy storage devices 202 may include three battery cells, two of which have the same characteristics and a third of which has one or more characteristics that are different than the first two battery cells).
  • energy storage devices may be heterogeneous despite sharing one or more characteristics (e.g., two battery cells may have the same capacities but have different battery technologies and different shapes).
  • Various combinations of energy storage devices 202 may be utilized to provide a range of capacities, performance capabilities, efficiencies, and power usage characteristics.
  • the energy storage devices 202 include a combination including at least one high energy density device and one high power energy device. This type of combination enables high power delivery in some situations for critical and latency sensitive tasks, and fast charging in other situations to keep the computing device operational and increase overall battery life.
  • high power density devices are more efficient at providing larger amounts of energy over shorter amounts of time (e.g., during latency sensitive tasks such as video processing).
  • the high power density devices may charge fast and provide high power output.
  • high energy density devices are designed to operate efficiently and may have larger capacities. However, the high energy density devices supply less power and may not be suitable for latency sensitive tasks.
  • the high energy density devices are more susceptible to increases cycle counts, which can accelerate aging and degradation over time.
  • Situationally selecting an appropriate combination of different batteries to use, charge, and drain in accordance with techniques described herein enables increase performance and more efficient use of the energy storage device system 128 . Additionally, cycle counts can be controlled and balanced to avoid having some energy storage devices 202 age much faster than other energy storage devices 202 .
  • a bulk of the power can be supplied via high power density device, which enables support for greater processing performance without adversely affecting the cycle count and lifetime of the high energy density devices.
  • the energy storage device controller 204 is representative of a control system to control operation of the energy storage device system 128 and delivery of power from the energy storage devices 202 to service a system load of the computing device 102 .
  • the system load refers to the energy required by the computing device 102 at any given point in time in order to operate.
  • the energy storage device controller 204 may be configured using various logic, hardware, circuitry, firmware, and/or software suitable to connect the energy storage devices 202 one to another, supply power to the system, switch between the energy storage devices, and so forth.
  • the energy storage device controller 204 in FIG. 2 is depicted as including switching hardware 206 and control logic 208 that is operable to selectively switch between different designated energy storage devices 202 at different times.
  • Control logic 208 may reflect different switching modes that switch between drawing power from different ones of the energy storage devices 202 so that power is drawn from energy storage devices 202 in accordance with a particular power ratio as determined by the power manager 126 .
  • switching hardware 206 can be utilized to set-up a switching scheme to select different energy storage devices based on different factors and workload patterns for the computing device 102 .
  • control logic 208 may reflect different switching modes that switch between providing power to different energy storage devices 202 to charge energy storage devices 202 in accordance with a particular power ratio as determined by the power manager 126 .
  • charging and discharging modes depend at least in part upon latency considerations as discussed herein.
  • selection of an energy storage device 202 occurs under the influence of the power manager 126 .
  • the power manager 126 represents functionality operable to manage the energy storage devices 202 and makes policy decisions regarding how to charge and discharge the device according to various criteria.
  • the selection of an energy storage device 202 refers to selection of a particular one or more of the energy storage devices 202 and an amount of power that is to be drawn from each of the selected one or more energy storage devices. This selection of the amount of power that is to be drawn can be identified by a power ratio of one energy storage device to another. A power ratio of x:y can be used, where x refers to power drawn from a first energy storage device and y refers to power drawn from a second energy storage device.
  • a power ratio of 4:1 indicates that four times the amount of power is to be drawn from the first energy storage device than from the second energy storage device.
  • Similar power ratios can be used in situations in which there are three or more energy storage devices, such as a power ratio x1:x2: . . . :xm, where x1 refers to power drawn from a first energy storage device, x2 refers to power drawn from a second energy storage device, and xm refers to power drawn from an mth energy storage device.
  • a power ratio of 4:2:1:1 indicates that: the amount of power to be drawn from the first energy storage device is twice the amount of power to be drawn from the second energy storage device and four times the amount of power to be drawn from each of the third and fourth energy storage devices, the amount of power to be drawn from the second energy storage device is twice the amount of power to be drawn from each of the third and fourth energy storage devices, and the amount of power to be drawn from the third energy storage device is the same as the amount of power to be drawn from the fourth energy storage device.
  • the selection of an energy storage device 202 and setting of power ratio is based at least in part upon latency considerations.
  • Functionality to assess latency behavior for tasks, applications, and workloads is represented by the latency estimator 127 , which the power manager 126 may rely upon to inform power management decisions.
  • the latency behavior assessment involves identifying latency sensitive tasks, applications, and workloads that benefit from higher power and processing frequencies (e.g., a high power mode). The assessment may also be based upon the priority assigned to tasks and the current state of the energy storage device system.
  • latency sensitivity is determined to exceed an established threshold associated with a “high” level of sensitivity, the power manager 126 is configured to favor use of high power density devices over high energy density device to increase performance (e.g., reduce latency).
  • the power manager 126 is configured to favor use of high energy density devices over high power density devices to conserve charge and availability of the high power density devices.
  • a table, list, file or other suitable data structure that correlates different tasks, applications, and scenarios to latency sensitivity is compiled and maintained via the latency estimator 127 .
  • This latency data is used to assess the latency for a particular workload over a period time (e.g., an epoch) based on the set of tasks, applications, scenarios, etc. corresponding to the workload.
  • a period time e.g., an epoch
  • latency data can be used to look-up sensitivity for individual applications/tasks listed in the latency data and make an overall determination regarding the degree to which the current workload is latency sensitive.
  • the latency estimator 127 may operate to predict the latency sensitivity for such items. Information regarding sensitivity that is predicted may be used to update the listed tasks/applications. The predictions may be based on similarity to known items. For example, different applications of the same class (e.g., video players, image editors, desktop productivity apps, email clients, etc.) may be assigned similar values with respect to latency based on similarity. Additionally, the latency estimator 127 may also consider the processing context to predict whether items may benefit from higher processing performance or not. For example, if an application is network bandwidth or I/O bottlenecked then increasing power is unlikely to have a substantial effect.
  • the computing device is operating with low power and the processing system is at or near the applicable power cap, there may be room to increase performance by favoring high power energy density devices.
  • information regarding latency sensitivity may be available through a service via a service provider 132 .
  • the data structure that correlates different tasks, applications, and scenarios to latency sensitivity may be obtained and updated through interaction with the service.
  • Various other techniques to assess latency sensitivity are also contemplated.
  • the power manager 126 operates to make power management decisions based as least in part upon the latency assessments as just described. Although this document focuses on latency-based decisions and selections, power management decisions may also depend upon other factors including but not limited to predicted energy consumption, expected usage of the computing device, availability of charging opportunities, user behavior and schedules, geographic location, and characteristics of the energy storage device systems and individual devices, to name a few examples. Such additional factors may be employed in combination with latency considerations and also in connection with non-latency sensitive workloads to control both charging and discharging of the system of heterogeneous energy storage devices.
  • the power manager 126 uses predicted latency as determined by the latency estimator 127 , alone or in combination with other factors, to select an appropriate combination of energy storage devices to service the current workload and direct changes to switching hardware 206 to use the selected combination. For example, the power manager 126 may communicate control signals or other suitable data that is interpreted and applied by the control logic 208 to operate switching hardware 206 to draw power as specified by the power manager 126 for a given time frame or epoch. In one or more implementations, selection of the combination of energy storage devices involves setting a power ratio for drawing power from the energy storage device 202 to control the division of the power load among the energy storage devices. This power ratio is used by the control logic 208 to determine which energy storage device(s) to draw power from at any given time.
  • the power ratio may reflect decimal or fractional values for the division of the power.
  • the power ratio may also be expressed as amounts of power draw (e.g., number of watts) for each individual device.
  • a number of modes corresponding to different ratios may be established and the mode may be selected based upon the latency assessment.
  • the power manager 126 may include or otherwise make use of a power ratio estimator module 210 and power ratio data 212 .
  • the power ratio estimator module 210 represents functionality operable to use the information gathered and generated by power manager 126 to determine the ratios in which power is to be drawn from the various energy storage devices in the energy storage device system 128 .
  • the power ratio estimator module 210 determines ratios to utilize for a period of time (e.g., epoch) based at least upon predicted latency sensitivity during the period of time. Such determinations can be made by the power ratio estimator module 210 at various regular or irregular intervals. For example, the power ratio estimator module 210 can make this determination every minute or second, after the amount of time in a current epoch elapses (e.g., at the beginning of each epoch), and so forth.
  • the power ratio data 212 represents data used by the power ratio estimator module 210 .
  • the power ratio data 212 can be implemented as any of a variety of different data structures (e.g., a table, list, or other record), or as any of a variety of different formulas, rules, algorithms, and so forth.
  • the power ratio specifies a division of an overall power load between different energy storage devices. This may be expressed in terms of percentage loads, amounts of power draw, time factors, or otherwise.
  • the power ratio data 218 is a table of threshold values for latency and corresponding power ratios.
  • the power ratio estimator module 210 accesses the power ratio data 212 , compares the combined estimated latency to the threshold values in the power ratio data 212 , and sets the power ratio for the computing device as the power ratio corresponding to the threshold values.
  • Table I illustrates an example table that can be used as power ratio data 218 . It should be noted that the table illustrated in Table I is an example, and that other data structures, formulas, algorithms, and so forth can be used.
  • an energy storage device system 128 having multiple diverse energy storage devices may be configured in various ways and employ a variety of different types of energy storage devices.
  • different energy storage devices 202 included with a system have different characteristics, such as differences in one or more of battery chemistry, capacity, voltage, size, shapes and/or state of charge (SOC), to name a few examples.
  • SOC state of charge
  • Using different types of energy storage devices provides flexibility for design of the energy storage device system and circuit boards, and consequently enables device developers to make better utilization of internal space to provide devices having increased battery life and efficiency.
  • the different energy storage devices are arranged in a circuit that enables selective switching among the energy storage devices.
  • FIG. 3 depicts generally at 300 one illustrative example arrangement of an energy storage device system 128 having multiple energy storage devices 202 that are battery cells.
  • the energy storage devices 202 may be connected in a circuit that includes an energy storage device controller 204 that implements switching hardware 206 and control logic 208 to switch back and forth among the energy storage devices 202 .
  • Each of the energy storage devices 202 may be represented according to a battery model 302 an example of which is depicted in FIG. 3 .
  • Each of the battery cells may also be coupled to a capacitor buffer 304 , which is provided to smooth out the supplied power when the switching hardware 206 is employed to switch between cells.
  • a battery model 302 is shown in FIG. 3 , it is to be appreciated that the concepts described herein are not limited to a particular model and various different models may be utilized, individually or in combination.
  • multiple energy storage devices 202 are arranged together with switching hardware 206 that enables switching between the energy storage devices.
  • the switching circuit may also include a mechanism to smooth the current draw from different energy storage devices, such as the example capacitor buffer 304 or other smoothing components.
  • the switching circuit includes control logic 208 or comparable functionality to designate and control which of the energy storage devices are used to service the load, the mode of operation of the energy storage devices, and the amount of power that is drawn from each energy storage device.
  • the control logic 208 controls the amount of power that is drawn from each energy storage device in accordance with the power ratio determined by the schedule-based energy storage device selection system 126 .
  • the battery controller 204 and switching hardware 206 may be configured to support multiple different modes of operation for energy storage devices 202 .
  • the switching hardware 206 is controlled to select one energy storage device at a time from which current is drawn to support the load. The particular energy storage device that is selected at any given time is dependent upon the determined power ratio.
  • the switching hardware 206 is controlled to cycle rapidly between two or more different energy storage devices to draw a percentage of the overall load current from each energy storage device.
  • the switching hardware 206 is cycled at a relatively high frequency to pull current from different energy storage devices according to the determined power ratio. Effectively, the rapid cycling in this mode enables servicing of the load by drawing different portions of load current from different cells at the same time. For example, for an energy storage device system having three cells and a determined power ratio of 7:2:1, seventy percent of the load may be drawn from a first energy storage device, twenty percent from a second energy storage device, and ten percent from a third energy storage device.
  • the switching hardware 206 is controlled to cycle rapidly between or connect to two or more different energy storage devices to draw a specified amount of current at substantially the same time (e.g., simultaneously) from two or more energy storage devices being used to support the load.
  • the amount of current supplied by each energy storage device is designated as opposed to setting percentages or weight factors. Again, rapid cycling in this mode enables servicing of the load by drawing different portions of load current from different energy storage devices at the same time, but in this case within constraints for the amount of current that is supplied from each cell.
  • FIG. 3 further depicts an equivalent circuit model 306 for the energy storage device system 128 .
  • the equivalent circuit model 306 represents switching hardware 206 that can be used to provide current I to a load 308 using an arrangement of multiple battery energy storage devices 202 .
  • four different battery cells 310 ( 1 )- 310 ( 4 ) are connectable to the load 308 via a switch 312 .
  • the switch 312 may be implemented as a solid state switch or other suitable hardware switching device.
  • the example battery cells 310 ( 1 )- 310 ( 4 ) represent different heterogeneous batteries configured to provide respective amounts of current I 1 , I 2 , I 3 , and I 4 .
  • the load current I may be supplied using one or a combination of the battery cells 310 ( 1 )- 310 ( 4 ).
  • the switch 312 may be controlled via the control logic 208 to service the load in accordance with a determined power ratio as described previously.
  • the switch 312 is also used to implement the various different switching modes described above and below.
  • the switch 312 may be positioned to select one of the battery cells 310 ( 1 )- 310 ( 4 ) and service the load via the selected cell.
  • the switch 312 may also be cycled rapidly to different positions associated with different cells to effectively draw a portion of the overall current I at the same time from each battery.
  • Portions of current obtained from each cell may be specified in various ways such as by associating percentages, weight factors, thresholds, or designated amounts with the cells.
  • FIG. 4 depicts generally at 400 example details of a system having heterogeneous energy storage devices in accordance with one or more implementations.
  • the example of FIG. 4 depicts a system having energy storage devices 202 that may be integrated with a computing device 102 .
  • Power is supplied via the energy storage devices using the techniques discussed herein, such as via an energy storage device controller 204 , which includes switching hardware 206 and control logic 208 .
  • the energy storage device controller 204 is implemented via a power management integrated circuit (PMIC) 402 that is adapted to support heterogeneous energy storage device switching and latency-based energy storage device selection.
  • PMIC power management integrated circuit
  • the PMIC or other energy storage device controller is adapted to include registers 404 to facilitate policy enforcement of a switching policy.
  • the registers 404 may be configured to hold various parameters that the control logic 208 makes use of to control operation of switching hardware 206 and supply power from the energy storage devices accordingly.
  • registers 404 may include registers indicative of the determined power ratio, the switching policy, a selected switching mode, a timing register, and battery cell specific registers indicative of battery states, characteristics, and designated current switching constraints (amounts, weights, percentages, thresholds, etc.). Registers may be assigned default values selected for general usage in typical scenarios. Registers may then be selectively adapted under the influence of the operating system and/or user input to implement policy settings for different use cases.
  • the registers 404 implemented by the energy storage device controller are exposed to enable operating system 108 and/or application 110 level control over switching.
  • the registers 404 provide user accessible control over heterogeneous energy storage device switching.
  • parameter values for the registers 404 may be set and updated dynamically via an application programming interface (API) 406 that is exposed via the operating system 108 as represented in FIG. 4 .
  • API messages and or other control signals may be exchanged between the energy storage device controller 204 and operating system over a suitable communication bus 408 , one example of which is an I 2 C bus.
  • Information regarding energy storage device states, workload, and characteristics of energy storage devices 202 may also be communicated to the operating system 108 and/or schedule-power manager 126 via the control signals and/or API to facilitate assessments of the operational context and policy decisions based on the operational context.
  • the operating system 108 may make policy decisions such as mode selection and energy storage device constraints setting for energy storage device switching. Policy decisions are made based upon performance parameters indicative of an operational context including at least information regarding battery states and characteristics obtained from the battery controller 204 . As represented, policy decisions may be made under the influence of a latency estimator 127 that determines and supplies information regarding latency sensitivity of tasks, applications, workloads, and interaction scenarios.
  • the API 406 provides a mechanism by which control signals are communicated to the energy storage device controller 204 to set the registers 404 in accordance with the policy decisions.
  • the operating system 108 and/or power manager 126 may direct operation of energy storage device controller 204 to implement policy enforcement of a selected policy by setting the registers 404 and causing operation of switching hardware 206 to effectuate the operational modes and energy storage device constraints specified by the policy. Power is then supplied to the system via one or more of the energy storage devices in accordance with the policy decisions.
  • FIG. 5 is a flow diagram that describes details of an example procedure 500 for latency-based energy storage device selection in accordance with one or more implementations.
  • the procedure 500 describes details of drawing power from multiple heterogeneous energy storage devices based upon latency considerations.
  • the procedure 500 can be implemented by way of a suitably configured computing device, such as by way of an operating system 108 , power manager 126 , latency estimator 127 , and/or other functionality described in relation to the examples of FIGS. 1-4 .
  • Latency behavior of computing tasks performed via a computing device having multiple heterogeneous energy storage devices over a period of time is predicted (block 502 ).
  • the latency behavior of tasks associated with the workload can be predicted in various ways as discussed above.
  • the latency behavior can be determined, for example, based on an assessment of applications, tasks, and interaction scenarios that are currently being performed and/or are expected to be performed during a time period. This may involve analyzing applications that are launched and corresponding tasks associated with the applications.
  • a data structure that correlates different items e.g., applications, tasks, workloads, scenarios, etc.
  • latency sensitivity values may be refereed to look-up applicable values.
  • predictions can be made based upon a similarity assessment of applications/tasks that are not enumerated in the data structure to items that are enumerated and mapped to latency sensitivity values via the data structure.
  • similar items may be assigned the same or similar latency sensitivity values.
  • a combination of energy storage devices to use for performance of the computing tasks is selected in dependence upon the predicted latency (block 504 ). For example, batteries or energy devices that are better suited to the particular level of latency sensitivity determined for the tasks may be selected or favored based on the analysis. As noted, higher power density devices may be favored in latency sensitive scenarios and higher energy density devices may be favored in situation that are not deemed latency sensitive. Power draws between available energy storage devices are adjusted according to the latency sensitive levels determined for the time period.
  • a power manager 126 may operate to direct operation of an energy storage device controller 204 to implement policy decisions as previously discussed. In at least some implementations, this involves communications between the power manager 126 and energy storage device controller 204 effective to control switching hardware to draw levels of power for different energy storage devices as specified by the power manager. For example, different energy storage devices may be activated and deactivated based on determined policy settings. The policy settings are based at least partially upon latency considerations as described herein. In addition or alternatively, policy settings may specify power ratios that are mapped to the predicted latency behavior as described previously.
  • the policy settings may be configured to cause implementation of different pre-established operating modes such as a high power mode, balanced mode, or low power mode.
  • power draws for different energy storage devices are specified by the selected mode. Accordingly, adjustments to power draws based on latency considerations may be made in various example ways enumerated as well as using other suitable techniques to change power draws for a set of heterogeneous energy storage devices in dependence upon assessments of latency behavior for computing tasks.
  • FIG. 6 is a flow diagram that describes details of another example procedure 600 for latency-based energy storage device selection in accordance with one or more implementations.
  • the procedure 600 describes details of adjusting power draw between multiple heterogeneous energy storage device including high power density devices and high energy density device.
  • the procedure 600 can be implemented by way of a suitably configured computing device, such as by way of an operating system 108 , power manager 126 , and/or other functionality described in relation to the examples of FIGS. 1-4 .
  • the determination is made in relation to a computing device including an energy storage device system with at least one high power density device and at least one high energy density device (block 602 ).
  • latency sensitivity of a workload can be determined in various ways as discussed herein including using preset values or predicting latency sensitivity on demand. In one example, the determination is performed by comparing items associated with the workload to items contained in a data structure that correlates different tasks, applications, and scenarios to levels of latency sensitivity to assess latency sensitivity of the workload.
  • different threshold levels of latency sensitivity can be established and related to power management settings, such as power ratios or modes of operation as noted in this description.
  • threshold levels for latency sensitivity may be correlated to different power ratios as represented and discussed in relation to Table 1 above. Accordingly, different determined levels of latency sensitivity may trigger different corresponding responses to adjust power draws between heterogeneous energy storage devices of an energy storage device system.
  • a power ratio for the energy storage device system is adjusted to increase a percentage of power to service the workload supplied from the high power density device (block 604 ).
  • the level of latency sensitivity that is determined indicates that the workload may benefit from increased power supply and/or processing performance. Accordingly, the power ratio is adjusted accordingly to favor the high power density device.
  • the balance of total power supplied by the energy storage device system may be adjusted to increase power from one or more high power density devices under appropriate circumstance. In some scenarios, a majority or bulk of the overall power is supplied via high power density devices when a corresponding threshold is exceeded.
  • just high power density devices may be employed, in which case other low power density devices (e.g., high energy density devices) may be suspended or shut-off.
  • Increased power supply favoring the one or more high power density devices may continue for a specified period of time as long as power from the devices remains available (e.g., the devices/battery cells have available charge) and the latency sensitive workload is ongoing. A return to a more balanced or different division of power draw may occur in response to conclusion of the latency sensitive workload and a corresponding change in the level of latency sensitivity.
  • conclusion of latency sensitive tasks associated with the workload is recognized (block 606 ).
  • the system recognizes that the particular tasks and/or interaction with applications that causes the elevated level of latency sensitivity are completed. Because of this, a corresponding drop in the level of latency sensitivity occurs and the system is able to detect this drop.
  • the power ratio is readjusted to divide power supply from the energy storage device system according to factors designated for non-latency sensitive workloads.
  • power ratios are generally adjusted to rely more heavily on high energy density devices and preserve charge of the high power density devices for subsequent, higher demand tasks. For example, assuming that the drop in latency sensitivity falls below a lowest applicable threshold, power ratios may be adjusted to increase reliance upon high energy density devices and/or to minimize usage of high power density devices. Naturally, intermediate levels of latency sensitivity may prompt corresponding adjustments to power ratios to balance the division of power between high power density devices and high energy density devices accordingly.
  • a range of such intermediate balances and power ratios between fully using high power devices/modes and fully using lower power devices/modes are contemplated.
  • latency sensitivity is determined to be at levels designated as high, action is taken to favor high power density devices to reduce latency.
  • latency sensitivity is determined to be below levels designated as high, action is taken to favor high energy density devices to conserve power for future computing tasks and workloads that may be latency sensitive.
  • FIG. 7 illustrates an example system 700 that includes an example computing device 702 that is representative of one or more computing systems and/or devices that may implement the various techniques described herein.
  • the computing device 702 may be, for example, a server of a service provider, a device associated with a client (e.g., a client device), an on-chip system, and/or any other suitable computing device or computing system.
  • the example computing device 702 as illustrated includes a processing system 704 , one or more computer-readable media 706 , and one or more I/O interfaces 708 that are communicatively coupled, one to another.
  • the computing device 702 may further include a system bus or other data and command transfer system that couples the various components, one to another.
  • a system bus can include any one or combination of different bus structures, such as a memory bus or memory controller, a peripheral bus, a universal serial bus, and/or a processor or local bus that utilizes any of a variety of bus architectures.
  • a variety of other examples are also contemplated, such as control and data lines.
  • the processing system 704 is representative of functionality to perform one or more operations using hardware. Accordingly, the processing system 704 is illustrated as including hardware elements 710 that may be configured as processors, functional blocks, and so forth. This may include implementation in hardware as an application specific integrated circuit or other logic device formed using one or more semiconductors.
  • the hardware elements 710 are not limited by the materials from which they are formed or the processing mechanisms employed therein.
  • processors may be comprised of semiconductor(s) and/or transistors (e.g., electronic integrated circuits (ICs)).
  • processor-executable instructions may be electronically-executable instructions.
  • the computer-readable media 706 is illustrated as including memory/storage 712 .
  • the memory/storage 712 represents memory/storage capacity associated with one or more computer-readable media.
  • the memory/storage 712 may include volatile media (such as random access memory (RAM)) and/or nonvolatile media (such as read only memory (ROM), Flash memory, optical disks, magnetic disks, and so forth).
  • RAM random access memory
  • ROM read only memory
  • Flash memory optical disks
  • magnetic disks magnetic disks, and so forth
  • the memory/storage 712 may include fixed media (e.g., RAM, ROM, a fixed hard drive, and so on) as well as removable media (e.g., Flash memory, a removable hard drive, an optical disc, and so forth).
  • the computer-readable media 706 may be configured in a variety of other ways as further described below.
  • Input/output interface(s) 708 are representative of functionality to allow a user to enter commands and information to computing device 702 , and also allow information to be presented to the user and/or other components or devices using various input/output devices.
  • input devices include a keyboard, a cursor control device (e.g., a mouse), a microphone for voice operations, a scanner, touch functionality (e.g., capacitive or other sensors that are configured to detect physical touch), a camera (e.g., which may employ visible or non-visible wavelengths such as infrared frequencies to detect movement that does not involve touch as gestures), and so forth.
  • Examples of output devices include a display device (e.g., a monitor or projector), speakers, a printer, a network card, tactile-response device, and so forth.
  • the computing device 702 may be configured in a variety of ways as further described below to support user interaction.
  • modules include routines, programs, objects, elements, components, data structures, and so forth that perform particular tasks or implement particular abstract data types.
  • module generally represent software, firmware, hardware, or a combination thereof.
  • the features of the techniques described herein are platform-independent, meaning that the techniques may be implemented on a variety of commercial computing platforms having a variety of processors.
  • Computer-readable media may include a variety of media that may be accessed by the computing device 702 .
  • computer-readable media may include “computer-readable storage media” and “communication media.”
  • Computer-readable storage media refers to media and/or devices that enable storage of information in contrast to mere signal transmission, carrier waves, or signals per se. Computer-readable storage media does not include signal bearing media, transitory signals, or signals per se.
  • the computer-readable storage media includes hardware such as volatile and non-volatile, removable and non-removable media and/or storage devices implemented in a method or technology suitable for storage of information such as computer readable instructions, data structures, program modules, logic elements/circuits, or other data.
  • Examples of computer-readable storage media may include, but are not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, hard disks, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or other storage device, tangible media, or article of manufacture suitable to store the desired information and which may be accessed by a computer.
  • Communication media may refer to signal-bearing media that is configured to transmit instructions to the hardware of the computing device 702 , such as via a network.
  • Communication media typically may embody computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as carrier waves, data signals, or other transport mechanism.
  • Communication media also include any information delivery media.
  • modulated data signal means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal.
  • communication media include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media.
  • hardware elements 710 and computer-readable media 706 are representative of instructions, modules, programmable device logic and/or fixed device logic implemented in a hardware form that may be employed in some embodiments to implement at least some aspects of the techniques described herein.
  • Hardware elements may include components of an integrated circuit or on-chip system, an application-specific integrated circuit (ASIC), a field-programmable gate array (FPGA), a complex programmable logic device (CPLD), and other implementations in silicon or other hardware devices.
  • ASIC application-specific integrated circuit
  • FPGA field-programmable gate array
  • CPLD complex programmable logic device
  • a hardware element may operate as a processing device that performs program tasks defined by instructions, modules, and/or logic embodied by the hardware element as well as a hardware device utilized to store instructions for execution, e.g., the computer-readable storage media described previously.
  • software, hardware, or program modules including the operating system 108 , applications 110 , power manager 126 , and other program modules may be implemented as one or more instructions and/or logic embodied on some form of computer-readable storage media and/or by one or more hardware elements 710 .
  • the computing device 702 may be configured to implement particular instructions and/or functions corresponding to the software and/or hardware modules. Accordingly, implementation of modules as a module that is executable by the computing device 702 as software may be achieved at least partially in hardware, e.g., through use of computer-readable storage media and/or hardware elements 710 of the processing system.
  • the instructions and/or functions may be executable/operable by one or more articles of manufacture (for example, one or more computing devices 702 and/or processing systems 704 ) to implement techniques, modules, and examples described herein.
  • the example system 700 enables ubiquitous environments for a seamless user experience when running applications on a personal computer (PC), a television device, and/or a mobile device. Services and applications run substantially similar in all three environments for a common user experience when transitioning from one device to the next while utilizing an application, playing a video game, watching a video, and so on.
  • PC personal computer
  • television device a television device
  • mobile device a mobile device. Services and applications run substantially similar in all three environments for a common user experience when transitioning from one device to the next while utilizing an application, playing a video game, watching a video, and so on.
  • multiple devices are interconnected through a central computing device.
  • the central computing device may be local to the multiple devices or may be located remotely from the multiple devices.
  • the central computing device may be a cloud of one or more server computers that are connected to the multiple devices through a network, the Internet, or other data communication link.
  • this interconnection architecture enables functionality to be delivered across multiple devices to provide a common and seamless experience to a user of the multiple devices.
  • Each of the multiple devices may have different physical requirements and capabilities, and the central computing device uses a platform to enable the delivery of an experience to the device that is both tailored to the device and yet common to all devices.
  • a class of target devices is created and experiences are tailored to the generic class of devices.
  • a class of devices may be defined by physical features, types of usage, or other common characteristics of the devices.
  • the computing device 702 may assume a variety of different configurations, such as for computer 714 , mobile 716 , and television 718 uses. Each of these configurations includes devices that may have generally different constructs and capabilities, and thus the computing device 702 may be configured according to one or more of the different device classes. For instance, the computing device 702 may be implemented as the computer 714 class of a device that includes a personal computer, desktop computer, a multi-screen computer, laptop computer, netbook, and so on.
  • the computing device 702 may also be implemented as the mobile 716 class of device that includes mobile devices, such as a mobile phone, portable music player, portable gaming device, a tablet computer, a multi-screen computer, and so on.
  • the computing device 702 may also be implemented as the television 718 class of device that includes devices having or connected to generally larger screens in casual viewing environments. These devices include televisions, set-top boxes, gaming consoles, and so on.
  • the techniques described herein may be supported by these various configurations of the computing device 702 and are not limited to the specific examples of the techniques described herein. This is illustrated through inclusion of the power manager 126 and the energy storage device system 128 on the computing device 702 .
  • the functionality represented by power manager 126 and other modules/applications may also be implemented all or in part through use of a distributed system, such as over a “cloud” 720 via a platform 722 as described below.
  • the cloud 720 includes and/or is representative of a platform 722 for resources 724 .
  • the platform 722 abstracts underlying functionality of hardware (e.g., servers) and software resources of the cloud 720 .
  • the resources 724 may include applications and/or data that can be utilized while computer processing is executed on servers that are remote from the computing device 702 .
  • Resources 724 can also include services provided over the Internet and/or through a subscriber network, such as a cellular or Wi-Fi network.
  • the platform 722 may abstract resources and functions to connect the computing device 702 with other computing devices.
  • the platform 722 may also serve to abstract scaling of resources to provide a corresponding level of scale to encountered demand for the resources 724 that are implemented via the platform 722 .
  • implementation of functionality described herein may be distributed throughout the system 700 .
  • the functionality may be implemented in part on the computing device 702 as well as via the platform 722 that abstracts the functionality of the cloud 720 .
  • Example implementations of techniques described herein include, but are not limited to, one or any combinations of one or more of the following examples:
  • a method implemented by a computing device having multiple heterogeneous energy storage devices comprising: predicting latency behavior of computing tasks performed via the computing device for a period of time; selecting a combination of energy storage devices to use for performance of the computing tasks in dependence upon the predicted latency behavior; and causing adjustments to switching hardware to supply power for performance of the computing tasks from the selected combination of energy storage devices during the period of time.
  • predicting the latency behavior includes assessing latency sensitivity of individual computing tasks associated with a workload for the period of time and establishing overall latency sensitivity for the period of time based on the latency sensitivity for the individual computing tasks.
  • predicting the latency behavior includes determining latency sensitivity associated with applications executing on the computing device for the period of time.
  • predicting the latency behavior comprises referencing a data structure configured to correlate different computing tasks and applications to corresponding levels of latency sensitivity.
  • selecting the combination of energy storage devices comprises: comparing predicted latency behavior to one or more defined threshold levels of latency sensitivity; determining a threshold level that corresponds to the predicted latency behavior; and setting a division of an overall power load between the multiple heterogeneous energy storage devices as designated for the threshold level that corresponds to the predicted latency behavior
  • causing adjustments to switching hardware comprises setting a power ratio for an energy storage system including the multiple heterogeneous energy storage devices to control power draw from the multiple heterogeneous energy storage devices as designated for the predicted latency behavior.
  • the multiple heterogeneous energy storage devices include at least one high power density device and at least one high energy density device; and selecting the combination comprises balancing a division of power draw between the high power density device and the high energy density device based on the predicted latency behavior.
  • causing adjustments to switching hardware comprises communicating control signals to a controller for an energy storage system including the multiple heterogeneous energy storage devices and the switching hardware to direct operation of switching hardware to draw power from the selected combination of energy storage devices.
  • control signals are configured to designate a switching mode for the multiple heterogeneous energy storage devices based on the predicted latency behavior.
  • a computing device comprising: an energy storage device system including multiple heterogeneous energy storage devices; and a power manager configured to direct operations of the energy storage device system to control power draw from the multiple heterogeneous energy storage devices based at least in part upon an assessment of latency sensitivity of a workload performed via the computing device for a period of time, including: causing a division of power draw between the multiple heterogeneous energy storage devices to favor high power density devices included with the multiple heterogeneous energy storage devices to reduce latency when latency sensitivity is at levels designated as high; and causing the division of power draw between the multiple heterogeneous energy storage devices to favor high energy density devices included with the multiple heterogeneous energy storage devices to conserve power for future workloads when latency sensitivity is below the levels designated as high.
  • causing the division of power comprises: determining a power ratio based upon the assessment of latency sensitivity; and communicating the determined power ratio for use by the energy storage device system, thereby directing operation of switching hardware of the energy storage device system to apply the power ratio to implement the corresponding division of power draw.
  • the power manager includes a latency estimator configured to perform the assessment of latency sensitivity for the workload including analyzing one or more of energy storage device characteristics, latency sensitivity of different tasks, application-specific latency considerations, estimated device usage, or estimated energy usage to predict latency sensitivity for the workload.
  • the latency estimator is further configured to select a combination of energy storage devices to use for performance of the workload in dependence upon the predicted latency sensitivity, the division of power draw corresponding to the combination of energy storage devices that is selected.
  • the power manager includes a power ratio estimator configured to derive a power ratio that specifies the division of power draw based upon the assessment of latency sensitivity.
  • a computing device comprising: an energy storage device system with multiple heterogeneous energy storage devices including at least on high power density device and at least one high energy density device; one or more processors; and one or more computer-readable storage media having stored thereon instructions that, responsive to execution by the one or more processors, cause the one or more processors to perform operations including: determining that latency sensitivity of a workload for the computing device exceeds a threshold associated with high latency sensitivity; and responsive to determining that latency sensitivity exceeds the threshold, adjusting a power ratio for the energy storage device system to increase a percentage of power to service the workload supplied from the high power density device.
  • the computing device as described in any one or more of the examples in this section, wherein the instructions further cause the one or more processors to perform operations including: recognizing conclusion of latency sensitive tasks associated with the work load; and responsive to recognizing conclusion of the latency sensitive tasks, readjusting the power ratio to divide power supply from the energy storage device system according to factors designated for non-latency sensitive workloads.
  • the computing device as described in any one or more of the examples in this section, wherein the factors designated for non-latency sensitive workloads include one or more of predicted energy consumption, expected usage of the computing device, availability of charging opportunities, user behavior and schedules, geographic location, or characteristics of the energy storage device system.
  • the computing device as described in any one or more of the examples in this section, wherein the instructions further cause the one or more processors to perform operations including: determining latency sensitivity of the workload by comparing items associated with the workload to items contained in a data structure that correlates different tasks, applications, and scenarios to levels of latency sensitivity.
  • the multiple heterogeneous energy storage devices have different characteristics including one or more of different sizes, capacities, technologies, chemistries, shapes, state of charge (SOC), age, temperatures, or cycle counts.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Power Engineering (AREA)
  • Charge And Discharge Circuits For Batteries Or The Like (AREA)
  • Environmental & Geological Engineering (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Hardware Design (AREA)
  • Computing Systems (AREA)

Abstract

Latency-based selections of energy storage devices are described herein. In implementations, latency behavior of computing tasks performed by a computing device is predicted for a period of time. Based on the predicted latency behavior of the computing device over the period of time, an assessment is made regarding which of multiple heterogeneous energy storage devices are most appropriate to service the system workload. For example, high energy density devices may be favored for latency sensitive tasks whereas high energy density devices may be favored when latency sensitivity is not a concern. A combination of energy storage devices to service the current workload is selected based upon the latency considerations and then power supply settings are adjusted to cause supply of power from the selected combination of energy storage devices during the time period.

Description

    BACKGROUND
  • As technology has advanced, mobile computing devices have become increasingly commonplace. Mobile computing devices provide various functionality to users, allowing the user to interact with the device to check email, surf the web, compose text messages, interact with applications, and so on. One challenge that faces developers of mobile computing devices is efficient power management and extension of battery life. For example, extended processing of tasks by processors at or near capacity may drain the device battery, causing the device to shut down. Various power management strategies may be applied to control processor and battery utilization generally at the expense of overall device performance. If power management implemented for a device fails to strike a good balance between performance and battery life, user dissatisfaction with the device and manufacturer may result.
  • SUMMARY
  • In accordance with one or more embodiments, in a computing device having multiple heterogeneous energy storage devices, latency behavior of computing tasks performed by a computing device is predicted for a period of time. Based on the predicted latency behavior of the computing device over the period of time, an assessment is made regarding which of the multiple heterogeneous energy storage devices are most appropriate to service the system workload. For example, high power density devices may be favored for latency sensitive tasks whereas high energy density devices may be favored when latency sensitivity is not a concern. A combination of energy storage devices to service the current workload is selected based upon the latency considerations and then power supply settings are adjusted to cause supply of power from the selected combination of energy storage devices during the time period. This may involve setting a power ratio to control power draw from the multiple heterogeneous energy storage devices as designated for the predicted latency behavior.
  • This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 illustrates an operating environment in accordance with one or more embodiments.
  • FIG. 2 depicts example details of a computing device having an energy storage device system with heterogeneous energy storage devices in accordance with one or more implementations.
  • FIG. 3 depicts one illustrative example arrangement of an energy storage device system having multiple energy storage devices that are battery cells.
  • FIG. 4 depicts example details of a system having heterogeneous energy storage devices in accordance with one or more implementations.
  • FIG. 5 is a flow diagram that describes details of an example procedure for latency-based energy storage device selection in accordance with one or more implementations
  • FIG. 6 is a flow diagram that describes details of another example procedure for latency-based energy storage device selection in accordance with one or more implementations.
  • FIG. 7 illustrates an example system that includes an example computing device that is representative of one or more computing systems and/or devices that may implement the various techniques described herein.
  • DETAILED DESCRIPTION
  • Overview
  • Latency-based energy storage device selection is described for a device having an energy storage device system with heterogeneous energy storage devices, such as heterogeneous battery cells. The heterogeneous energy storage devices include two or more energy storage devices having various different characteristics such as different sizes, capacities, technologies, chemistries, shapes, state of charge (SOC), age, temperature, cycle counts, and so forth. These different characteristics result in different energy storage devices being better suited for different types of operations and scenarios. For example, one energy storage device may be a high power density device more efficient at providing larger amounts of energy over shorter amounts of time (e.g., during latency sensitive tasks such as video processing) and another energy storage device may be a high energy density device more efficient at providing smaller amounts of energy over longer amounts of time (e.g., while a device is in a low-power usage or energy saving mode). Generally, a high power density device charges fast and are capable of supplying a high power output. In contrast, a high energy density device is designed to operate efficiently, but provides lower power output and may be more susceptible to aging and degradation from repeated charge cycles.
  • The techniques discussed herein use latency behavior information regarding applications, computing tasks, interaction scenarios and/or past usage of a computing device to assess latency sensitivity of a workload and adjust power draws across multiple heterogeneous energy storage devices. Adjusting the combination of storage devices used for different levels of latency sensitivity as discussed in this document improves performance and efficiency of the energy storage device system both in the short term for handling latency sensitive tasks and over time as individual devices age and cycle counts increase.
  • In the discussion that follows, a section titled “Operating Environment” is provided and describes one example environment in which one or more implementations can be employed. Following this, a section titled “Latency-Based Energy Storage Device Selection System Details” describes example details and procedures in accordance with one or more implementations. Last, a section titled “Example System” describes example computing systems, components, and devices that can be utilized for one or more implementations of latency-based energy storage device selection.
  • Operating Environment
  • FIG. 1 illustrates an operating environment in accordance with one or more embodiments, generally at 100. The environment 100 includes a computing device 102 having a processing system 104 with one or more processors and devices (e.g., CPUs, GPUs, microcontrollers, hardware elements, fixed logic devices, etc.), one or more computer-readable media 106, an operating system 108, and one or more applications 110 that reside on the computer-readable media and which are executable by the processing system. The processing system 104 may be configured to include multiple independent processors configured in parallel or in series and one or more multi-core processing units. A multi-core processing unit may have two or more processors (“cores”) included on the same chip or integrated circuit. In one or more implementations, the processing system 104 may include multiple processing cores that provide a range of performance capabilities, processing efficiencies, and power usage characteristics.
  • The processing system 104 may retrieve and execute computer-program instructions from applications 110 to provide a wide range of functionality to the computing device 102, including but not limited to gaming, office productivity, email, media management, printing, networking, web-browsing, and so forth. A variety of data and program files related to the applications 110 can also be included, examples of which include game files, office documents, multimedia files, emails, data files, web pages, user profile and/or preference data, and so forth.
  • The computing device 102 can be embodied as any suitable computing system and/or device such as, by way of example and not limitation, a gaming system, a desktop computer, a portable computer, a tablet or slate computer, a handheld computer such as a personal digital assistant (PDA), a cell phone, a set-top box, a wearable device (e.g., watch, band, glasses, etc.), and the like. For example, as shown in FIG. 1 the computing device 102 can be implemented as a television client device 112, a computer 114, and/or a gaming system 116 that is connected to a display device 118 to display media content. Alternatively, the computing device may be any type of portable computer, mobile phone, or portable device 120 that includes an integrated display 122. A computing device may also be configured as a wearable device 124 that is designed to be worn by, attached to, carried by, or otherwise transported by a user. Examples of wearable devices 124 depicted in FIG. 1 include glasses, a smart band or watch, and a pod device such as clip-on fitness device, media player, or tracker. Other examples of wearable devices 124 include but are not limited to badges, a key fob, an access card, and a ring, an article of clothing, a glove, or a bracelet, to name a few examples. Any of the computing devices can be implemented with various components, such as one or more processors and memory devices, as well as with any combination of differing components. One example of a computing system that can represent various systems and/or devices including the computing device 102 is shown and described below in relation to FIG. 7.
  • The computer-readable media can include, by way of example and not limitation, all forms of volatile and non-volatile memory and/or storage media that are typically associated with a computing device. Such media can include ROM, RAM, flash memory, hard disk, removable media and the like. Computer-readable media can include both “computer-readable storage media” and “communication media,” examples of which can be found in the discussion of the example computing system of FIG. 7.
  • The computing device 102 may also include a power manager 126 that includes or makes use of a latency estimator 127, and an energy storage device system 128 having multiple heterogeneous energy storage devices that operate as described above and below. The power manager 126 represents functionality operable to manage power for the computing device in various ways. For example the power manager 126 may assess system-wide power management considerations and manage availability heterogeneous energy storage devices, processors, and/or processing cores based on the assessment. In one or more implementations, the power manager 126 is configured to implement a switching policy established based on power management considerations to control the battery system 128. The switching policy depends at least upon latency considerations as discussed herein.
  • In this context, the latency estimator 127 represents functionality that the power manager may include, invoke, or otherwise make use of to determine latency behavior for a current workload (also referred to herein as usage behavior) of the computing device 102 and manage heterogeneous energy storage devices of the energy storage device system 128 accordingly. This may involve analyzing factors including but not limited to energy storage device characteristics, latency sensitivity of different tasks, application specific latency considerations, estimated or predicted future usage and latency behavior of the computing device 102, estimated future energy usage of the computing device 102 over a given time period (e.g., a day), and so forth.
  • The assessment may further involve analyzing other factors including but not limited to, charge levels/states, the device power state, actual and expected workloads, thermal conditions, user presence, processor/core utilization, application context, device context, priority, contextual clues, and other suitable performance metrics that may be used to drive power management decisions at the system level. Different types of applications, tasks, and scenarios may be assigned pre-computed latency sensitivity values that are used by the latency estimator 127 to determine latency behavior for a current workload. Latency estimator 127 may additionally operate to estimate or predict latency sensitivity values “on-demand” using the various factors when pre-computed values are not available.
  • The power manager 126 is further configured to apply the switching policy to adjust the performance of the battery system 128 based on the assessment of system-wide performance metrics and conditions (e.g., analyzing an operational context for the device), including at least latency sensitivity associated with current workload. Applying the switching policy may involve controlling modes of different energy storage devices (e.g., cells), states of individual energy storage devices and/or availability of heterogeneous energy storage devices included with an energy storage system 128. For example, the power manager 126 is operable to communicate control signals or otherwise interact with the energy storage system 128 to direct operation of switching hardware to switch between heterogeneous battery cells to service the load in accordance with the switching policy and analysis of the operational context.
  • As mentioned, the energy storage device system 128 is configured to include multiple heterogeneous energy storage devices. Energy storage devices may be configured in various ways and be implemented in various combinations of as discussed in greater detail below. The power manager 126 and energy storage device system 128 may be provided using any suitable combination of hardware, software, firmware, and/or logic devices. As illustrated, the power manager 126 and energy storage device system 128 may be configured as separate, standalone systems. In addition or alternatively, the power manager 126 may also be configured as a system or module that is combined with the operating system 108 or implemented via a controller or other component of the energy storage device system 128. Details regarding these and other aspects of latency-based energy storage device selection are discussed in the following section.
  • The environment 100 further depicts that the computing device 102 may be communicatively coupled via a network 130 to a service provider 132, which enables the computing device 102 to access and interact with various resources 134 made available by the service provider 132. The resources 134 can include any suitable combination of content and/or services typically made available over a network by one or more service providers. For instance, content can include various combinations of text, video, ads, audio, multi-media streams, applications, animations, images, webpages, and the like. Some examples of services include, but are not limited to, an online computing service (e.g., “cloud” computing), an authentication service, web-based applications, a file storage and collaboration service, a search service, messaging services such as email and/or instant messaging, and a social networking service.
  • Having described an example operating environment, consider now example details and techniques associated with one or more implementations of latency-based energy storage device selection.
  • Latency-Based Energy Storage Device Selection System Details
  • To further illustrate, consider the discussion in this section of example devices, components, procedures, and implementation details that may be utilized to provide latency-based energy storage device selection as described herein. In general, functionality, features, and concepts described in relation to the examples above and below may be employed in the context of the example procedures described in this section. Further, functionality, features, and concepts described in relation to different figures and examples in this document may be interchanged among one another and are not limited to implementation in the context of a particular figure or procedure. Moreover, blocks associated with different representative procedures and corresponding figures herein may be applied together and/or combined in different ways. Thus, individual functionality, features, and concepts described in relation to different example environments, devices, components, figures, and procedures herein may be used in any suitable combinations and are not limited to the particular combinations represented by the enumerated examples in this description.
  • Example Device
  • FIG. 2 depicts generally at 200 example details of a computing device 102 having an energy storage device system 128 with heterogeneous energy storage devices in accordance with one or more implementations. Computing device 102 also includes processing system 104, computer readable media 106, operating system 108 and applications 110 as discussed in relation to FIG. 1. In the depicted example, a power manager 126 is also shown as being implemented as a component of the operating system 108.
  • By way of example and not limitation, the energy storage device system 128 is depicted as having energy storage devices 202 and an energy storage device controller 204. The energy storage devices 202 are representative of various different kinds of energy storage devices that may be included with the computing device 102. These energy storage devices can include, for example, battery cells, supercapacitors, and so forth. It should be noted that these energy storage devices include various devices that store energy as opposed to being an external plug-in AC power source. As mentioned, energy storage devices 202 include energy storage devices having different characteristics such as different sizes/capacities, chemistries, battery technologies, shapes, state of charge (SOC), age, temperature, and so forth (heterogeneous energy storage devices). The different characteristics may include different “properties” of the energy storage devices (e.g., chemistries, sizes, capacities) and different “states” in which the energy storage devices are currently operating (e.g., “SoC”, age, temperature). Thus, in the context of the techniques described herein heterogeneous energy storage devices may include either or both of different types of devices designed with different properties and devices having the same or similar properties by design, but having different state characteristics.
  • Accordingly, the energy storage device system 128 includes a diverse combination of multiple energy storage devices at least some of which have different characteristics one to another. However, it should be noted that some energy storage devices 202 may be the same and still be part of the energy storage device system 128 (e.g., the energy storage devices 202 may include three battery cells, two of which have the same characteristics and a third of which has one or more characteristics that are different than the first two battery cells). It should also be noted that energy storage devices may be heterogeneous despite sharing one or more characteristics (e.g., two battery cells may have the same capacities but have different battery technologies and different shapes). Various combinations of energy storage devices 202 may be utilized to provide a range of capacities, performance capabilities, efficiencies, and power usage characteristics. In at least some implementations, the energy storage devices 202 include a combination including at least one high energy density device and one high power energy device. This type of combination enables high power delivery in some situations for critical and latency sensitive tasks, and fast charging in other situations to keep the computing device operational and increase overall battery life.
  • Generally, high power density devices are more efficient at providing larger amounts of energy over shorter amounts of time (e.g., during latency sensitive tasks such as video processing). The high power density devices may charge fast and provide high power output. On the other hand, high energy density devices are designed to operate efficiently and may have larger capacities. However, the high energy density devices supply less power and may not be suitable for latency sensitive tasks. Additionally, the high energy density devices are more susceptible to increases cycle counts, which can accelerate aging and degradation over time. Situationally selecting an appropriate combination of different batteries to use, charge, and drain in accordance with techniques described herein enables increase performance and more efficient use of the energy storage device system 128. Additionally, cycle counts can be controlled and balanced to avoid having some energy storage devices 202 age much faster than other energy storage devices 202. In the context of latency sensitive tasks, a bulk of the power can be supplied via high power density device, which enables support for greater processing performance without adversely affecting the cycle count and lifetime of the high energy density devices.
  • The energy storage device controller 204 is representative of a control system to control operation of the energy storage device system 128 and delivery of power from the energy storage devices 202 to service a system load of the computing device 102. The system load refers to the energy required by the computing device 102 at any given point in time in order to operate. The energy storage device controller 204 may be configured using various logic, hardware, circuitry, firmware, and/or software suitable to connect the energy storage devices 202 one to another, supply power to the system, switch between the energy storage devices, and so forth. By way of example and not limitation, the energy storage device controller 204 in FIG. 2 is depicted as including switching hardware 206 and control logic 208 that is operable to selectively switch between different designated energy storage devices 202 at different times. Control logic 208 may reflect different switching modes that switch between drawing power from different ones of the energy storage devices 202 so that power is drawn from energy storage devices 202 in accordance with a particular power ratio as determined by the power manager 126. Thus, rather than merely interconnecting energy storage devices in parallel or series, switching hardware 206 can be utilized to set-up a switching scheme to select different energy storage devices based on different factors and workload patterns for the computing device 102. Similarly, control logic 208 may reflect different switching modes that switch between providing power to different energy storage devices 202 to charge energy storage devices 202 in accordance with a particular power ratio as determined by the power manager 126. Thus, charging and discharging modes depend at least in part upon latency considerations as discussed herein.
  • In one approach, selection of an energy storage device 202 occurs under the influence of the power manager 126. As noted previously, the power manager 126 represents functionality operable to manage the energy storage devices 202 and makes policy decisions regarding how to charge and discharge the device according to various criteria. The selection of an energy storage device 202 refers to selection of a particular one or more of the energy storage devices 202 and an amount of power that is to be drawn from each of the selected one or more energy storage devices. This selection of the amount of power that is to be drawn can be identified by a power ratio of one energy storage device to another. A power ratio of x:y can be used, where x refers to power drawn from a first energy storage device and y refers to power drawn from a second energy storage device. For example, a power ratio of 4:1 indicates that four times the amount of power is to be drawn from the first energy storage device than from the second energy storage device. Similar power ratios can be used in situations in which there are three or more energy storage devices, such as a power ratio x1:x2: . . . :xm, where x1 refers to power drawn from a first energy storage device, x2 refers to power drawn from a second energy storage device, and xm refers to power drawn from an mth energy storage device. For example, a power ratio of 4:2:1:1 indicates that: the amount of power to be drawn from the first energy storage device is twice the amount of power to be drawn from the second energy storage device and four times the amount of power to be drawn from each of the third and fourth energy storage devices, the amount of power to be drawn from the second energy storage device is twice the amount of power to be drawn from each of the third and fourth energy storage devices, and the amount of power to be drawn from the third energy storage device is the same as the amount of power to be drawn from the fourth energy storage device.
  • As noted, the selection of an energy storage device 202 and setting of power ratio is based at least in part upon latency considerations. Functionality to assess latency behavior for tasks, applications, and workloads is represented by the latency estimator 127, which the power manager 126 may rely upon to inform power management decisions. The latency behavior assessment involves identifying latency sensitive tasks, applications, and workloads that benefit from higher power and processing frequencies (e.g., a high power mode). The assessment may also be based upon the priority assigned to tasks and the current state of the energy storage device system. When latency sensitivity is determined to exceed an established threshold associated with a “high” level of sensitivity, the power manager 126 is configured to favor use of high power density devices over high energy density device to increase performance (e.g., reduce latency). For non-sensitive tasks, the power manager 126 is configured to favor use of high energy density devices over high power density devices to conserve charge and availability of the high power density devices.
  • In one approach, a table, list, file or other suitable data structure that correlates different tasks, applications, and scenarios to latency sensitivity is compiled and maintained via the latency estimator 127. This latency data is used to assess the latency for a particular workload over a period time (e.g., an epoch) based on the set of tasks, applications, scenarios, etc. corresponding to the workload. Based on the applications that are launched and tasks that are scheduled, latency data can be used to look-up sensitivity for individual applications/tasks listed in the latency data and make an overall determination regarding the degree to which the current workload is latency sensitive. For unknown applications and tasks (e.g., items not available in the compiled list) the latency estimator 127 may operate to predict the latency sensitivity for such items. Information regarding sensitivity that is predicted may be used to update the listed tasks/applications. The predictions may be based on similarity to known items. For example, different applications of the same class (e.g., video players, image editors, desktop productivity apps, email clients, etc.) may be assigned similar values with respect to latency based on similarity. Additionally, the latency estimator 127 may also consider the processing context to predict whether items may benefit from higher processing performance or not. For example, if an application is network bandwidth or I/O bottlenecked then increasing power is unlikely to have a substantial effect. On the other hand, if the computing device is operating with low power and the processing system is at or near the applicable power cap, there may be room to increase performance by favoring high power energy density devices. In addition or alternatively, information regarding latency sensitivity may be available through a service via a service provider 132. In this approach, the data structure that correlates different tasks, applications, and scenarios to latency sensitivity may be obtained and updated through interaction with the service. Various other techniques to assess latency sensitivity are also contemplated.
  • The power manager 126 operates to make power management decisions based as least in part upon the latency assessments as just described. Although this document focuses on latency-based decisions and selections, power management decisions may also depend upon other factors including but not limited to predicted energy consumption, expected usage of the computing device, availability of charging opportunities, user behavior and schedules, geographic location, and characteristics of the energy storage device systems and individual devices, to name a few examples. Such additional factors may be employed in combination with latency considerations and also in connection with non-latency sensitive workloads to control both charging and discharging of the system of heterogeneous energy storage devices.
  • The power manager 126 uses predicted latency as determined by the latency estimator 127, alone or in combination with other factors, to select an appropriate combination of energy storage devices to service the current workload and direct changes to switching hardware 206 to use the selected combination. For example, the power manager 126 may communicate control signals or other suitable data that is interpreted and applied by the control logic 208 to operate switching hardware 206 to draw power as specified by the power manager 126 for a given time frame or epoch. In one or more implementations, selection of the combination of energy storage devices involves setting a power ratio for drawing power from the energy storage device 202 to control the division of the power load among the energy storage devices. This power ratio is used by the control logic 208 to determine which energy storage device(s) to draw power from at any given time. The power ratio may reflect decimal or fractional values for the division of the power. The power ratio may also be expressed as amounts of power draw (e.g., number of watts) for each individual device. In another approach, a number of modes corresponding to different ratios may be established and the mode may be selected based upon the latency assessment.
  • Accordingly, the power manager 126 may include or otherwise make use of a power ratio estimator module 210 and power ratio data 212. The power ratio estimator module 210 represents functionality operable to use the information gathered and generated by power manager 126 to determine the ratios in which power is to be drawn from the various energy storage devices in the energy storage device system 128. At any given time, the power ratio estimator module 210 determines ratios to utilize for a period of time (e.g., epoch) based at least upon predicted latency sensitivity during the period of time. Such determinations can be made by the power ratio estimator module 210 at various regular or irregular intervals. For example, the power ratio estimator module 210 can make this determination every minute or second, after the amount of time in a current epoch elapses (e.g., at the beginning of each epoch), and so forth.
  • The power ratio data 212 represents data used by the power ratio estimator module 210. The power ratio data 212 can be implemented as any of a variety of different data structures (e.g., a table, list, or other record), or as any of a variety of different formulas, rules, algorithms, and so forth. The power ratio specifies a division of an overall power load between different energy storage devices. This may be expressed in terms of percentage loads, amounts of power draw, time factors, or otherwise. In one or more embodiments, the power ratio data 218 is a table of threshold values for latency and corresponding power ratios. The power ratio estimator module 210 accesses the power ratio data 212, compares the combined estimated latency to the threshold values in the power ratio data 212, and sets the power ratio for the computing device as the power ratio corresponding to the threshold values.
  • Table I illustrates an example table that can be used as power ratio data 218. It should be noted that the table illustrated in Table I is an example, and that other data structures, formulas, algorithms, and so forth can be used.
  • TABLE I
    Latency Sensitivity Value Power Ratio
    Below threshold 1 Ratio 1
    Between threshold 1 and threshold 2 Ratio 2
    Above threshold 2 Ratio 3

    Thus, as shown in Table I, three different power ratios are available, depending on the combined latency sensitivity. Although only three power ratios and two threshold values (threshold 1 and threshold 2) are shown, any number of power ratios and threshold values can be used. The power manager 126 is thus able to manage heterogeneous energy storage devices to select different combinations of devices and set power draw ratios and/or divisions of power based upon the latency behavior and perceived latency sensitivity of different tasks, applications, workloads, and interaction scenarios.
  • Example Battery Cell Arrangement
  • Generally speaking, an energy storage device system 128 having multiple diverse energy storage devices may be configured in various ways and employ a variety of different types of energy storage devices. In one or more implementations, different energy storage devices 202 included with a system have different characteristics, such as differences in one or more of battery chemistry, capacity, voltage, size, shapes and/or state of charge (SOC), to name a few examples. Using different types of energy storage devices provides flexibility for design of the energy storage device system and circuit boards, and consequently enables device developers to make better utilization of internal space to provide devices having increased battery life and efficiency. The different energy storage devices are arranged in a circuit that enables selective switching among the energy storage devices.
  • In particular, FIG. 3 depicts generally at 300 one illustrative example arrangement of an energy storage device system 128 having multiple energy storage devices 202 that are battery cells. The energy storage devices 202 may be connected in a circuit that includes an energy storage device controller 204 that implements switching hardware 206 and control logic 208 to switch back and forth among the energy storage devices 202.
  • Each of the energy storage devices 202 may be represented according to a battery model 302 an example of which is depicted in FIG. 3. Each of the battery cells may also be coupled to a capacitor buffer 304, which is provided to smooth out the supplied power when the switching hardware 206 is employed to switch between cells. Although one illustrative example of a battery model 302 is shown in FIG. 3, it is to be appreciated that the concepts described herein are not limited to a particular model and various different models may be utilized, individually or in combination. Generally, multiple energy storage devices 202 are arranged together with switching hardware 206 that enables switching between the energy storage devices. The switching circuit may also include a mechanism to smooth the current draw from different energy storage devices, such as the example capacitor buffer 304 or other smoothing components. Additionally, the switching circuit includes control logic 208 or comparable functionality to designate and control which of the energy storage devices are used to service the load, the mode of operation of the energy storage devices, and the amount of power that is drawn from each energy storage device. The control logic 208 controls the amount of power that is drawn from each energy storage device in accordance with the power ratio determined by the schedule-based energy storage device selection system 126.
  • The battery controller 204 and switching hardware 206 may be configured to support multiple different modes of operation for energy storage devices 202. In one mode, the switching hardware 206 is controlled to select one energy storage device at a time from which current is drawn to support the load. The particular energy storage device that is selected at any given time is dependent upon the determined power ratio.
  • In another mode, the switching hardware 206 is controlled to cycle rapidly between two or more different energy storage devices to draw a percentage of the overall load current from each energy storage device. In other words, the switching hardware 206 is cycled at a relatively high frequency to pull current from different energy storage devices according to the determined power ratio. Effectively, the rapid cycling in this mode enables servicing of the load by drawing different portions of load current from different cells at the same time. For example, for an energy storage device system having three cells and a determined power ratio of 7:2:1, seventy percent of the load may be drawn from a first energy storage device, twenty percent from a second energy storage device, and ten percent from a third energy storage device.
  • In yet another mode, the switching hardware 206 is controlled to cycle rapidly between or connect to two or more different energy storage devices to draw a specified amount of current at substantially the same time (e.g., simultaneously) from two or more energy storage devices being used to support the load. In this mode, the amount of current supplied by each energy storage device is designated as opposed to setting percentages or weight factors. Again, rapid cycling in this mode enables servicing of the load by drawing different portions of load current from different energy storage devices at the same time, but in this case within constraints for the amount of current that is supplied from each cell.
  • FIG. 3 further depicts an equivalent circuit model 306 for the energy storage device system 128. In particular, the equivalent circuit model 306 represents switching hardware 206 that can be used to provide current I to a load 308 using an arrangement of multiple battery energy storage devices 202. In the depicted example, four different battery cells 310(1)-310(4) are connectable to the load 308 via a switch 312. The switch 312 may be implemented as a solid state switch or other suitable hardware switching device. The example battery cells 310(1)-310(4) represent different heterogeneous batteries configured to provide respective amounts of current I1, I2, I3, and I4. The load current I may be supplied using one or a combination of the battery cells 310(1)-310(4).
  • To do so, the switch 312 may be controlled via the control logic 208 to service the load in accordance with a determined power ratio as described previously. The switch 312 is also used to implement the various different switching modes described above and below. For instance the switch 312 may be positioned to select one of the battery cells 310(1)-310(4) and service the load via the selected cell. The switch 312 may also be cycled rapidly to different positions associated with different cells to effectively draw a portion of the overall current I at the same time from each battery. In this approach, the overall current I is supplied by summing the currents I1, I2, I3, and I4 supplied from each cell. (e.g., I=I1+I2, +I3−I4). Portions of current obtained from each cell may be specified in various ways such as by associating percentages, weight factors, thresholds, or designated amounts with the cells.
  • FIG. 4 depicts generally at 400 example details of a system having heterogeneous energy storage devices in accordance with one or more implementations. In particular, the example of FIG. 4 depicts a system having energy storage devices 202 that may be integrated with a computing device 102. Power is supplied via the energy storage devices using the techniques discussed herein, such as via an energy storage device controller 204, which includes switching hardware 206 and control logic 208. In the depicted example, the energy storage device controller 204 is implemented via a power management integrated circuit (PMIC) 402 that is adapted to support heterogeneous energy storage device switching and latency-based energy storage device selection. For instance, in one or more implementations, the PMIC or other energy storage device controller is adapted to include registers 404 to facilitate policy enforcement of a switching policy. The registers 404 may be configured to hold various parameters that the control logic 208 makes use of to control operation of switching hardware 206 and supply power from the energy storage devices accordingly. For example, registers 404 may include registers indicative of the determined power ratio, the switching policy, a selected switching mode, a timing register, and battery cell specific registers indicative of battery states, characteristics, and designated current switching constraints (amounts, weights, percentages, thresholds, etc.). Registers may be assigned default values selected for general usage in typical scenarios. Registers may then be selectively adapted under the influence of the operating system and/or user input to implement policy settings for different use cases.
  • The registers 404 implemented by the energy storage device controller are exposed to enable operating system 108 and/or application 110 level control over switching. In other words, the registers 404 provide user accessible control over heterogeneous energy storage device switching. By way of example and not limitation parameter values for the registers 404 may be set and updated dynamically via an application programming interface (API) 406 that is exposed via the operating system 108 as represented in FIG. 4. API messages and or other control signals may be exchanged between the energy storage device controller 204 and operating system over a suitable communication bus 408, one example of which is an I2C bus. Information regarding energy storage device states, workload, and characteristics of energy storage devices 202 may also be communicated to the operating system 108 and/or schedule-power manager 126 via the control signals and/or API to facilitate assessments of the operational context and policy decisions based on the operational context.
  • Thus, as represented in FIG. 4, the operating system 108, by way of a power manager 126 or otherwise, may make policy decisions such as mode selection and energy storage device constraints setting for energy storage device switching. Policy decisions are made based upon performance parameters indicative of an operational context including at least information regarding battery states and characteristics obtained from the battery controller 204. As represented, policy decisions may be made under the influence of a latency estimator 127 that determines and supplies information regarding latency sensitivity of tasks, applications, workloads, and interaction scenarios. The API 406 provides a mechanism by which control signals are communicated to the energy storage device controller 204 to set the registers 404 in accordance with the policy decisions. Thus, the operating system 108 and/or power manager 126 may direct operation of energy storage device controller 204 to implement policy enforcement of a selected policy by setting the registers 404 and causing operation of switching hardware 206 to effectuate the operational modes and energy storage device constraints specified by the policy. Power is then supplied to the system via one or more of the energy storage devices in accordance with the policy decisions.
  • Example Procedures
  • Further aspects of latency-based energy storage device selection techniques are discussed in relation to example procedure of FIGS. 5 and 6. The procedures described in this document may be implemented utilizing the environment, system, devices, and components described herein and in connection with any suitable hardware, software, firmware, or combination thereof. The procedures may be represented as a set of blocks that specify operations performed by one or more entities and are not necessarily limited to the orders shown for performing the operations by the respective blocks.
  • FIG. 5 is a flow diagram that describes details of an example procedure 500 for latency-based energy storage device selection in accordance with one or more implementations. The procedure 500 describes details of drawing power from multiple heterogeneous energy storage devices based upon latency considerations. The procedure 500 can be implemented by way of a suitably configured computing device, such as by way of an operating system 108, power manager 126, latency estimator 127, and/or other functionality described in relation to the examples of FIGS. 1-4.
  • Latency behavior of computing tasks performed via a computing device having multiple heterogeneous energy storage devices over a period of time is predicted (block 502). The latency behavior of tasks associated with the workload can be predicted in various ways as discussed above. The latency behavior can be determined, for example, based on an assessment of applications, tasks, and interaction scenarios that are currently being performed and/or are expected to be performed during a time period. This may involve analyzing applications that are launched and corresponding tasks associated with the applications. In one or more implementations, a data structure that correlates different items (e.g., applications, tasks, workloads, scenarios, etc.) with latency sensitivity values may be refereed to look-up applicable values. Additionally, predictions can be made based upon a similarity assessment of applications/tasks that are not enumerated in the data structure to items that are enumerated and mapped to latency sensitivity values via the data structure. In this approach, similar items may be assigned the same or similar latency sensitivity values.
  • A combination of energy storage devices to use for performance of the computing tasks is selected in dependence upon the predicted latency (block 504). For example, batteries or energy devices that are better suited to the particular level of latency sensitivity determined for the tasks may be selected or favored based on the analysis. As noted, higher power density devices may be favored in latency sensitive scenarios and higher energy density devices may be favored in situation that are not deemed latency sensitive. Power draws between available energy storage devices are adjusted according to the latency sensitive levels determined for the time period.
  • In particular, adjustments are caused to switching hardware to supply power for performance of the computing tasks from the selected combination of energy storage devices during the period of time (block 506). For example, a power manager 126 may operate to direct operation of an energy storage device controller 204 to implement policy decisions as previously discussed. In at least some implementations, this involves communications between the power manager 126 and energy storage device controller 204 effective to control switching hardware to draw levels of power for different energy storage devices as specified by the power manager. For example, different energy storage devices may be activated and deactivated based on determined policy settings. The policy settings are based at least partially upon latency considerations as described herein. In addition or alternatively, policy settings may specify power ratios that are mapped to the predicted latency behavior as described previously. In yet another example, the policy settings may be configured to cause implementation of different pre-established operating modes such as a high power mode, balanced mode, or low power mode. In this approach, power draws for different energy storage devices are specified by the selected mode. Accordingly, adjustments to power draws based on latency considerations may be made in various example ways enumerated as well as using other suitable techniques to change power draws for a set of heterogeneous energy storage devices in dependence upon assessments of latency behavior for computing tasks.
  • FIG. 6 is a flow diagram that describes details of another example procedure 600 for latency-based energy storage device selection in accordance with one or more implementations. The procedure 600 describes details of adjusting power draw between multiple heterogeneous energy storage device including high power density devices and high energy density device. The procedure 600 can be implemented by way of a suitably configured computing device, such as by way of an operating system 108, power manager 126, and/or other functionality described in relation to the examples of FIGS. 1-4.
  • A determination is made that latency sensitivity of a workload for a computing device exceeds a threshold. The determination is made in relation to a computing device including an energy storage device system with at least one high power density device and at least one high energy density device (block 602). For instance, latency sensitivity of a workload can be determined in various ways as discussed herein including using preset values or predicting latency sensitivity on demand. In one example, the determination is performed by comparing items associated with the workload to items contained in a data structure that correlates different tasks, applications, and scenarios to levels of latency sensitivity to assess latency sensitivity of the workload. Additionally, different threshold levels of latency sensitivity can be established and related to power management settings, such as power ratios or modes of operation as noted in this description. By way of example and not limitation, threshold levels for latency sensitivity may be correlated to different power ratios as represented and discussed in relation to Table 1 above. Accordingly, different determined levels of latency sensitivity may trigger different corresponding responses to adjust power draws between heterogeneous energy storage devices of an energy storage device system.
  • In particular, responsive to determining that latency sensitivity exceeds the threshold, a power ratio for the energy storage device system is adjusted to increase a percentage of power to service the workload supplied from the high power density device (block 604). Here, the level of latency sensitivity that is determined indicates that the workload may benefit from increased power supply and/or processing performance. Accordingly, the power ratio is adjusted accordingly to favor the high power density device. In other words, the balance of total power supplied by the energy storage device system may be adjusted to increase power from one or more high power density devices under appropriate circumstance. In some scenarios, a majority or bulk of the overall power is supplied via high power density devices when a corresponding threshold is exceeded. Moreover, in some instances just high power density devices may be employed, in which case other low power density devices (e.g., high energy density devices) may be suspended or shut-off.
  • Increased power supply favoring the one or more high power density devices may continue for a specified period of time as long as power from the devices remains available (e.g., the devices/battery cells have available charge) and the latency sensitive workload is ongoing. A return to a more balanced or different division of power draw may occur in response to conclusion of the latency sensitive workload and a corresponding change in the level of latency sensitivity.
  • In particular, conclusion of latency sensitive tasks associated with the workload is recognized (block 606). Here, the system recognizes that the particular tasks and/or interaction with applications that causes the elevated level of latency sensitivity are completed. Because of this, a corresponding drop in the level of latency sensitivity occurs and the system is able to detect this drop.
  • Responsive to recognizing conclusion of the latency sensitive tasks, the power ratio is readjusted to divide power supply from the energy storage device system according to factors designated for non-latency sensitive workloads. (block 608) In this case, power ratios are generally adjusted to rely more heavily on high energy density devices and preserve charge of the high power density devices for subsequent, higher demand tasks. For example, assuming that the drop in latency sensitivity falls below a lowest applicable threshold, power ratios may be adjusted to increase reliance upon high energy density devices and/or to minimize usage of high power density devices. Naturally, intermediate levels of latency sensitivity may prompt corresponding adjustments to power ratios to balance the division of power between high power density devices and high energy density devices accordingly. A range of such intermediate balances and power ratios between fully using high power devices/modes and fully using lower power devices/modes are contemplated. Generally, when latency sensitivity is determined to be at levels designated as high, action is taken to favor high power density devices to reduce latency. On the other hand, when latency sensitivity is determined to be below levels designated as high, action is taken to favor high energy density devices to conserve power for future computing tasks and workloads that may be latency sensitive.
  • Having considered the foregoing example details and procedures, consider now a discussion of an example system and components that may be employed for aspects of latency-based energy storage device selection in one or more implementations.
  • Example System
  • FIG. 7 illustrates an example system 700 that includes an example computing device 702 that is representative of one or more computing systems and/or devices that may implement the various techniques described herein. The computing device 702 may be, for example, a server of a service provider, a device associated with a client (e.g., a client device), an on-chip system, and/or any other suitable computing device or computing system.
  • The example computing device 702 as illustrated includes a processing system 704, one or more computer-readable media 706, and one or more I/O interfaces 708 that are communicatively coupled, one to another. Although not shown, the computing device 702 may further include a system bus or other data and command transfer system that couples the various components, one to another. A system bus can include any one or combination of different bus structures, such as a memory bus or memory controller, a peripheral bus, a universal serial bus, and/or a processor or local bus that utilizes any of a variety of bus architectures. A variety of other examples are also contemplated, such as control and data lines.
  • The processing system 704 is representative of functionality to perform one or more operations using hardware. Accordingly, the processing system 704 is illustrated as including hardware elements 710 that may be configured as processors, functional blocks, and so forth. This may include implementation in hardware as an application specific integrated circuit or other logic device formed using one or more semiconductors. The hardware elements 710 are not limited by the materials from which they are formed or the processing mechanisms employed therein. For example, processors may be comprised of semiconductor(s) and/or transistors (e.g., electronic integrated circuits (ICs)). In such a context, processor-executable instructions may be electronically-executable instructions.
  • The computer-readable media 706 is illustrated as including memory/storage 712. The memory/storage 712 represents memory/storage capacity associated with one or more computer-readable media. The memory/storage 712 may include volatile media (such as random access memory (RAM)) and/or nonvolatile media (such as read only memory (ROM), Flash memory, optical disks, magnetic disks, and so forth). The memory/storage 712 may include fixed media (e.g., RAM, ROM, a fixed hard drive, and so on) as well as removable media (e.g., Flash memory, a removable hard drive, an optical disc, and so forth). The computer-readable media 706 may be configured in a variety of other ways as further described below.
  • Input/output interface(s) 708 are representative of functionality to allow a user to enter commands and information to computing device 702, and also allow information to be presented to the user and/or other components or devices using various input/output devices. Examples of input devices include a keyboard, a cursor control device (e.g., a mouse), a microphone for voice operations, a scanner, touch functionality (e.g., capacitive or other sensors that are configured to detect physical touch), a camera (e.g., which may employ visible or non-visible wavelengths such as infrared frequencies to detect movement that does not involve touch as gestures), and so forth. Examples of output devices include a display device (e.g., a monitor or projector), speakers, a printer, a network card, tactile-response device, and so forth. Thus, the computing device 702 may be configured in a variety of ways as further described below to support user interaction.
  • Various techniques may be described herein in the general context of software, hardware elements, or program modules. Generally, such modules include routines, programs, objects, elements, components, data structures, and so forth that perform particular tasks or implement particular abstract data types. The terms “module,” “functionality,” and “component” as used herein generally represent software, firmware, hardware, or a combination thereof. The features of the techniques described herein are platform-independent, meaning that the techniques may be implemented on a variety of commercial computing platforms having a variety of processors.
  • An implementation of the described modules and techniques may be stored on or transmitted across some form of computer-readable media. The computer-readable media may include a variety of media that may be accessed by the computing device 702. By way of example, and not limitation, computer-readable media may include “computer-readable storage media” and “communication media.”
  • “Computer-readable storage media” refers to media and/or devices that enable storage of information in contrast to mere signal transmission, carrier waves, or signals per se. Computer-readable storage media does not include signal bearing media, transitory signals, or signals per se. The computer-readable storage media includes hardware such as volatile and non-volatile, removable and non-removable media and/or storage devices implemented in a method or technology suitable for storage of information such as computer readable instructions, data structures, program modules, logic elements/circuits, or other data. Examples of computer-readable storage media may include, but are not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, hard disks, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or other storage device, tangible media, or article of manufacture suitable to store the desired information and which may be accessed by a computer.
  • “Communication media” may refer to signal-bearing media that is configured to transmit instructions to the hardware of the computing device 702, such as via a network. Communication media typically may embody computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as carrier waves, data signals, or other transport mechanism. Communication media also include any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media.
  • As previously described, hardware elements 710 and computer-readable media 706 are representative of instructions, modules, programmable device logic and/or fixed device logic implemented in a hardware form that may be employed in some embodiments to implement at least some aspects of the techniques described herein. Hardware elements may include components of an integrated circuit or on-chip system, an application-specific integrated circuit (ASIC), a field-programmable gate array (FPGA), a complex programmable logic device (CPLD), and other implementations in silicon or other hardware devices. In this context, a hardware element may operate as a processing device that performs program tasks defined by instructions, modules, and/or logic embodied by the hardware element as well as a hardware device utilized to store instructions for execution, e.g., the computer-readable storage media described previously.
  • Combinations of the foregoing may also be employed to implement various techniques and modules described herein. Accordingly, software, hardware, or program modules including the operating system 108, applications 110, power manager 126, and other program modules may be implemented as one or more instructions and/or logic embodied on some form of computer-readable storage media and/or by one or more hardware elements 710. The computing device 702 may be configured to implement particular instructions and/or functions corresponding to the software and/or hardware modules. Accordingly, implementation of modules as a module that is executable by the computing device 702 as software may be achieved at least partially in hardware, e.g., through use of computer-readable storage media and/or hardware elements 710 of the processing system. The instructions and/or functions may be executable/operable by one or more articles of manufacture (for example, one or more computing devices 702 and/or processing systems 704) to implement techniques, modules, and examples described herein.
  • As further illustrated in FIG. 7, the example system 700 enables ubiquitous environments for a seamless user experience when running applications on a personal computer (PC), a television device, and/or a mobile device. Services and applications run substantially similar in all three environments for a common user experience when transitioning from one device to the next while utilizing an application, playing a video game, watching a video, and so on.
  • In the example system 700, multiple devices are interconnected through a central computing device. The central computing device may be local to the multiple devices or may be located remotely from the multiple devices. In one embodiment, the central computing device may be a cloud of one or more server computers that are connected to the multiple devices through a network, the Internet, or other data communication link.
  • In one embodiment, this interconnection architecture enables functionality to be delivered across multiple devices to provide a common and seamless experience to a user of the multiple devices. Each of the multiple devices may have different physical requirements and capabilities, and the central computing device uses a platform to enable the delivery of an experience to the device that is both tailored to the device and yet common to all devices. In one embodiment, a class of target devices is created and experiences are tailored to the generic class of devices. A class of devices may be defined by physical features, types of usage, or other common characteristics of the devices.
  • In various implementations, the computing device 702 may assume a variety of different configurations, such as for computer 714, mobile 716, and television 718 uses. Each of these configurations includes devices that may have generally different constructs and capabilities, and thus the computing device 702 may be configured according to one or more of the different device classes. For instance, the computing device 702 may be implemented as the computer 714 class of a device that includes a personal computer, desktop computer, a multi-screen computer, laptop computer, netbook, and so on.
  • The computing device 702 may also be implemented as the mobile 716 class of device that includes mobile devices, such as a mobile phone, portable music player, portable gaming device, a tablet computer, a multi-screen computer, and so on. The computing device 702 may also be implemented as the television 718 class of device that includes devices having or connected to generally larger screens in casual viewing environments. These devices include televisions, set-top boxes, gaming consoles, and so on.
  • The techniques described herein may be supported by these various configurations of the computing device 702 and are not limited to the specific examples of the techniques described herein. This is illustrated through inclusion of the power manager 126 and the energy storage device system 128 on the computing device 702. The functionality represented by power manager 126 and other modules/applications may also be implemented all or in part through use of a distributed system, such as over a “cloud” 720 via a platform 722 as described below.
  • The cloud 720 includes and/or is representative of a platform 722 for resources 724. The platform 722 abstracts underlying functionality of hardware (e.g., servers) and software resources of the cloud 720. The resources 724 may include applications and/or data that can be utilized while computer processing is executed on servers that are remote from the computing device 702. Resources 724 can also include services provided over the Internet and/or through a subscriber network, such as a cellular or Wi-Fi network.
  • The platform 722 may abstract resources and functions to connect the computing device 702 with other computing devices. The platform 722 may also serve to abstract scaling of resources to provide a corresponding level of scale to encountered demand for the resources 724 that are implemented via the platform 722. Accordingly, in an interconnected device embodiment, implementation of functionality described herein may be distributed throughout the system 700. For example, the functionality may be implemented in part on the computing device 702 as well as via the platform 722 that abstracts the functionality of the cloud 720.
  • EXAMPLE IMPLEMENTATIONS
  • Example implementations of techniques described herein include, but are not limited to, one or any combinations of one or more of the following examples:
  • Example 1
  • A method implemented by a computing device having multiple heterogeneous energy storage devices, the method comprising: predicting latency behavior of computing tasks performed via the computing device for a period of time; selecting a combination of energy storage devices to use for performance of the computing tasks in dependence upon the predicted latency behavior; and causing adjustments to switching hardware to supply power for performance of the computing tasks from the selected combination of energy storage devices during the period of time.
  • Example 2
  • The method as described in any one or more of the examples in this section, wherein predicting the latency behavior includes assessing latency sensitivity of individual computing tasks associated with a workload for the period of time and establishing overall latency sensitivity for the period of time based on the latency sensitivity for the individual computing tasks.
  • Example 3
  • The method as described in any one or more of the examples in this section, wherein predicting the latency behavior includes determining latency sensitivity associated with applications executing on the computing device for the period of time.
  • Example 4
  • The method as described in any one or more of the examples in this section, wherein predicting the latency behavior comprises referencing a data structure configured to correlate different computing tasks and applications to corresponding levels of latency sensitivity.
  • Example 5
  • The method as described in any one or more of the examples in this section, wherein selecting the combination of energy storage devices comprises: comparing predicted latency behavior to one or more defined threshold levels of latency sensitivity; determining a threshold level that corresponds to the predicted latency behavior; and setting a division of an overall power load between the multiple heterogeneous energy storage devices as designated for the threshold level that corresponds to the predicted latency behavior
  • Example 6
  • The method as described in any one or more of the examples in this section, wherein causing adjustments to switching hardware comprises setting a power ratio for an energy storage system including the multiple heterogeneous energy storage devices to control power draw from the multiple heterogeneous energy storage devices as designated for the predicted latency behavior.
  • Example 7
  • The method as described in any one or more of the examples in this section, wherein the multiple heterogeneous energy storage devices are configured as multiple heterogeneous battery cells.
  • Example 8
  • The method as described in any one or more of the examples in this section, wherein: the multiple heterogeneous energy storage devices include at least one high power density device and at least one high energy density device; and selecting the combination comprises balancing a division of power draw between the high power density device and the high energy density device based on the predicted latency behavior.
  • Example 9
  • The method as described in any one or more of the examples in this section, wherein causing adjustments to switching hardware comprises communicating control signals to a controller for an energy storage system including the multiple heterogeneous energy storage devices and the switching hardware to direct operation of switching hardware to draw power from the selected combination of energy storage devices.
  • Example 10
  • The method as described in any one or more of the examples in this section, wherein the control signals are configured to designate a switching mode for the multiple heterogeneous energy storage devices based on the predicted latency behavior.
  • Example 11
  • A computing device comprising: an energy storage device system including multiple heterogeneous energy storage devices; and a power manager configured to direct operations of the energy storage device system to control power draw from the multiple heterogeneous energy storage devices based at least in part upon an assessment of latency sensitivity of a workload performed via the computing device for a period of time, including: causing a division of power draw between the multiple heterogeneous energy storage devices to favor high power density devices included with the multiple heterogeneous energy storage devices to reduce latency when latency sensitivity is at levels designated as high; and causing the division of power draw between the multiple heterogeneous energy storage devices to favor high energy density devices included with the multiple heterogeneous energy storage devices to conserve power for future workloads when latency sensitivity is below the levels designated as high.
  • Example 12
  • The computing device as described in any one or more of the examples in this section, wherein causing the division of power comprises: determining a power ratio based upon the assessment of latency sensitivity; and communicating the determined power ratio for use by the energy storage device system, thereby directing operation of switching hardware of the energy storage device system to apply the power ratio to implement the corresponding division of power draw.
  • Example 13
  • The computing device as described in any one or more of the examples in this section, wherein the power manager includes a latency estimator configured to perform the assessment of latency sensitivity for the workload including analyzing one or more of energy storage device characteristics, latency sensitivity of different tasks, application-specific latency considerations, estimated device usage, or estimated energy usage to predict latency sensitivity for the workload.
  • Example 14
  • The computing device as described in any one or more of the examples in this section, wherein the latency estimator is further configured to select a combination of energy storage devices to use for performance of the workload in dependence upon the predicted latency sensitivity, the division of power draw corresponding to the combination of energy storage devices that is selected.
  • Example 15
  • The computing device as described in any one or more of the examples in this section, wherein the power manager includes a power ratio estimator configured to derive a power ratio that specifies the division of power draw based upon the assessment of latency sensitivity.
  • Example 16
  • A computing device comprising: an energy storage device system with multiple heterogeneous energy storage devices including at least on high power density device and at least one high energy density device; one or more processors; and one or more computer-readable storage media having stored thereon instructions that, responsive to execution by the one or more processors, cause the one or more processors to perform operations including: determining that latency sensitivity of a workload for the computing device exceeds a threshold associated with high latency sensitivity; and responsive to determining that latency sensitivity exceeds the threshold, adjusting a power ratio for the energy storage device system to increase a percentage of power to service the workload supplied from the high power density device.
  • Example 17
  • The computing device as described in any one or more of the examples in this section, wherein the instructions further cause the one or more processors to perform operations including: recognizing conclusion of latency sensitive tasks associated with the work load; and responsive to recognizing conclusion of the latency sensitive tasks, readjusting the power ratio to divide power supply from the energy storage device system according to factors designated for non-latency sensitive workloads.
  • Example 18
  • The computing device as described in any one or more of the examples in this section, wherein the factors designated for non-latency sensitive workloads include one or more of predicted energy consumption, expected usage of the computing device, availability of charging opportunities, user behavior and schedules, geographic location, or characteristics of the energy storage device system.
  • Example 19
  • The computing device as described in any one or more of the examples in this section, wherein the instructions further cause the one or more processors to perform operations including: determining latency sensitivity of the workload by comparing items associated with the workload to items contained in a data structure that correlates different tasks, applications, and scenarios to levels of latency sensitivity.
  • Example 20
  • The computing device as described in any one or more of the examples in this section, the multiple heterogeneous energy storage devices have different characteristics including one or more of different sizes, capacities, technologies, chemistries, shapes, state of charge (SOC), age, temperatures, or cycle counts.
  • CONCLUSION
  • Although the example implementations have been described in language specific to structural features and/or methodological acts, it is to be understood that the implementations defined in the appended claims are not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as example forms of implementing the claimed features.

Claims (1)

What is claimed is:
1. A method implemented by a computing device having multiple heterogeneous energy storage devices, the method comprising:
predicting latency behavior of computing tasks performed via the computing device for a period of time;
selecting a combination of energy storage devices to use for performance of the computing tasks in dependence upon the predicted latency behavior; and
causing adjustments to switching hardware to supply power for performance of the computing tasks from the selected combination of energy storage devices during the period of time.
US15/944,500 2015-11-13 2018-04-03 Latency-Based Energy Storage Device Selection Abandoned US20190107875A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US15/944,500 US20190107875A1 (en) 2015-11-13 2018-04-03 Latency-Based Energy Storage Device Selection

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US14/941,416 US9939862B2 (en) 2015-11-13 2015-11-13 Latency-based energy storage device selection
US15/944,500 US20190107875A1 (en) 2015-11-13 2018-04-03 Latency-Based Energy Storage Device Selection

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US14/941,416 Continuation US9939862B2 (en) 2015-11-13 2015-11-13 Latency-based energy storage device selection

Publications (1)

Publication Number Publication Date
US20190107875A1 true US20190107875A1 (en) 2019-04-11

Family

ID=57485859

Family Applications (2)

Application Number Title Priority Date Filing Date
US14/941,416 Active 2035-12-02 US9939862B2 (en) 2015-11-13 2015-11-13 Latency-based energy storage device selection
US15/944,500 Abandoned US20190107875A1 (en) 2015-11-13 2018-04-03 Latency-Based Energy Storage Device Selection

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US14/941,416 Active 2035-12-02 US9939862B2 (en) 2015-11-13 2015-11-13 Latency-based energy storage device selection

Country Status (2)

Country Link
US (2) US9939862B2 (en)
WO (1) WO2017083170A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10944132B2 (en) 2015-02-18 2021-03-09 Microsoft Technology Licensing, Llc Dynamically changing internal state of a battery

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9696782B2 (en) 2015-02-09 2017-07-04 Microsoft Technology Licensing, Llc Battery parameter-based power management for suppressing power spikes
US9748765B2 (en) 2015-02-26 2017-08-29 Microsoft Technology Licensing, Llc Load allocation for multi-battery devices
US10061366B2 (en) 2015-11-17 2018-08-28 Microsoft Technology Licensing, Llc Schedule-based energy storage device selection
US9793570B2 (en) 2015-12-04 2017-10-17 Microsoft Technology Licensing, Llc Shared electrode battery
US10917496B2 (en) * 2017-09-05 2021-02-09 Amazon Technologies, Inc. Networked storage architecture
US10992156B2 (en) * 2017-10-17 2021-04-27 The Board Of Trustees Of The Leland Stanford Junior University Autonomous screening and optimization of battery formation and cycling procedures
US11533272B1 (en) * 2018-02-06 2022-12-20 Amesite Inc. Computer based education methods and apparatus
US10963362B2 (en) * 2019-04-11 2021-03-30 Dell Products L.P. Method and system for identifying latency-sensitive computing workloads of information handling systems
CN115934002B (en) * 2023-03-08 2023-08-04 阿里巴巴(中国)有限公司 Solid state disk access method, solid state disk, storage system and cloud server

Family Cites Families (275)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4145669A (en) 1977-02-10 1979-03-20 Westinghouse Electric Corp. Cathode electrode configuration for gas laser system
DE3721529A1 (en) 1987-06-30 1989-01-12 Christiansen Jens TRIGGERING AND ISOLATION OF PSEUDO SPARK SWITCHES
JPH0410366A (en) 1990-04-25 1992-01-14 Otsuka Chem Co Ltd Secondary battery having heating mechanism
US5523671A (en) 1991-02-14 1996-06-04 Dell Usa, L.P. Charging system for battery powered devices
US5315228A (en) 1992-01-24 1994-05-24 Compaq Computer Corp. Battery charge monitor and fuel gauge
US5440221A (en) 1992-07-08 1995-08-08 Benchmarg Microelectronics, Inc. Method and apparatus for monitoring batttery capacity with charge control
JPH0684544A (en) 1992-09-01 1994-03-25 Nippondenso Co Ltd Lithium secondary battery
FR2702885B1 (en) 1993-03-15 1995-04-21 Alcatel Converters System for monitoring the aging of a battery and method implemented in such a system.
JP3549540B2 (en) 1994-03-30 2004-08-04 アルザ・コーポレーション Reducing skin irritation during electrotransport administration
USRE38918E1 (en) 1994-04-22 2005-12-13 University Of Southern California System and method for power-efficient charging and discharging of a capacitive load from a single source
US5705929A (en) 1995-05-23 1998-01-06 Fibercorp. Inc. Battery capacity monitoring system
US5691742A (en) 1995-05-24 1997-11-25 Dell U.S.A., L.P. Software battery gauge for portable computers
US5614332A (en) 1995-05-26 1997-03-25 Pavelle; Richard Method and apparatus for increasing charging and discharging efficiency in batteries
US5684404A (en) 1995-11-17 1997-11-04 Sharp Microelectronics Technology, Inc. System and method of measuring a battery lifetime
US5914585A (en) 1996-02-20 1999-06-22 Norand Corporation Power sharing in computing systems with a plurality of electronic devices
JPH10136574A (en) 1996-10-31 1998-05-22 Hitachi Ltd Battery control device
US5764032A (en) 1997-03-06 1998-06-09 Maxim Integrated Products, Inc. Multiple battery switchover circuits
US5935724A (en) 1997-04-04 1999-08-10 Wilson Greatbatch Ltd. Electrochemical cell having multiplate electrodes with differing discharge rate regions
US5818200A (en) 1997-05-06 1998-10-06 Dell U.S.A., L.P. Dual smart battery detection system and method for portable computers
US6252511B1 (en) 1997-06-20 2001-06-26 Compaq Computer Corporation Real-time battery gauge display
US7059769B1 (en) 1997-06-27 2006-06-13 Patrick Henry Potega Apparatus for enabling multiple modes of operation among a plurality of devices
US5894212A (en) 1997-09-19 1999-04-13 Tarrytown Consulting, Inc. Discharge monitoring and isolating system for batteries
SE519632C2 (en) 1997-12-23 2003-03-25 Ericsson Telefon Ab L M Portable electronic device with thin film batteries and their use in the same
KR100255358B1 (en) 1997-12-27 2000-05-01 배문한 Bipolar battery
US6742003B2 (en) 2001-04-30 2004-05-25 Microsoft Corporation Apparatus and accompanying methods for visualizing clusters of data and hierarchical cluster classifications
US6299998B1 (en) 1999-03-15 2001-10-09 Reveo, Inc. Movable anode fuel cell battery
US6463495B1 (en) 1999-03-29 2002-10-08 Compaq Information Technologies Group, L.P. Command and control infrastructure for a computer system using the computer's power rail
US6268711B1 (en) 1999-05-05 2001-07-31 Texas Instruments Incorporated Battery manager
JP3323832B2 (en) 1999-06-08 2002-09-09 インターナショナル・ビジネス・マシーンズ・コーポレーション Method of controlling charge and discharge of multiple batteries
US6154012A (en) 1999-10-13 2000-11-28 Xicor, Inc. Gas gauge implementation
JP2001211558A (en) 2000-01-27 2001-08-03 Sanyo Electric Co Ltd Charging method for plurality of batteries
JP3398703B2 (en) 2000-02-14 2003-04-21 米沢日本電気株式会社 Discharge circuit and duty ratio setting method
GB2360670B (en) 2000-03-22 2004-02-04 At & T Lab Cambridge Ltd Power management system
JP3438135B2 (en) 2000-05-19 2003-08-18 富士通株式会社 Information device, power saving mode switching method, and recording medium storing power saving mode switching program
JP4759795B2 (en) 2000-09-28 2011-08-31 株式会社Gsユアサ Rechargeable battery remaining capacity detection method
US6353304B1 (en) 2001-01-19 2002-03-05 Sandia Corporation Optimal management of batteries in electric systems
US6771044B1 (en) 2001-02-08 2004-08-03 Frank A. Vinciguerra Electrical power management for recharging multiple battery-powered computers
US6833792B1 (en) 2001-03-30 2004-12-21 Bellsouth Intellectual Property Corporation Battery capacity indicator in a portable computing device
WO2002087006A1 (en) 2001-04-24 2002-10-31 Reveo, Inc. Hybrid electrochemical cell system
US6417646B1 (en) 2001-05-22 2002-07-09 Honeywell International Inc. Circuit for monitoring cells of a multi-cell battery during charge
CN100570577C (en) 2001-08-29 2009-12-16 联发科技股份有限公司 High-speed procedure is followed the tracks of
JP4428551B2 (en) 2001-09-27 2010-03-10 Necトーキン株式会社 Multiple direct connection protection battery pack
JP2003194897A (en) 2001-12-26 2003-07-09 Sanyo Electric Co Ltd Battery residual capacity operating method and pack battery
US6977479B2 (en) 2002-01-08 2005-12-20 Hsu Po-Jung John Portable cell phone battery charger using solar energy as the primary source of power
KR100446510B1 (en) 2002-02-04 2004-09-04 삼성전자주식회사 Method for managing power in handheld terminal
US8036718B2 (en) 2002-06-17 2011-10-11 Nokia Corporation Power management profile on a mobile device
US7065659B2 (en) 2002-06-28 2006-06-20 Microsoft Corporation Power management architecture for defining component power states under a global power state and maintaining a power state floor for a specified component if a power state for the specified component under a new global power state is below the power state floor
US6992580B2 (en) 2002-07-25 2006-01-31 Motorola, Inc. Portable communication device and corresponding method of operation
US6710578B1 (en) 2002-08-27 2004-03-23 Motorola, Inc. Power resource management in a portable communication device
US6650089B1 (en) 2002-10-16 2003-11-18 Texas Instruments Incorporated Control circuit for multiple battery systems with capacity gauge on end equipment
US7259538B2 (en) 2002-11-14 2007-08-21 Hewlett-Packard Development Company, L.P. Adaptive battery conditioning employing battery chemistry determination
JP3669702B2 (en) 2003-02-25 2005-07-13 松下電器産業株式会社 Application program prediction method and mobile terminal
US7734317B2 (en) * 2003-03-18 2010-06-08 Qualcomm Incorporated Battery management
US7015596B2 (en) 2003-07-03 2006-03-21 Opher Pail Electronic device display system and method
US6847191B1 (en) 2003-08-13 2005-01-25 Kinpo Electronics, Inc. Power control device and the operating method thereof
US7020500B2 (en) 2003-12-16 2006-03-28 Michael Gabriel Saghbini Mobile communication system powered by multiple batteries
JP4304600B2 (en) 2004-01-19 2009-07-29 株式会社デンソー Flying capacitor type battery voltage detector for vehicle
US7339353B1 (en) 2004-03-10 2008-03-04 Quallion Llc Power system for managing power from multiple power sources
US7475267B1 (en) 2004-03-31 2009-01-06 Google, Inc. Systems and methods for delay in startup of multiple components
US7339348B2 (en) 2004-04-30 2008-03-04 Dell Products L.P. Battery pack including multiple battery cell technologies
JP4460946B2 (en) 2004-05-19 2010-05-12 株式会社東海理化電機製作所 Operation control device
US7688033B2 (en) 2004-09-29 2010-03-30 Panasonic Ev Energy Co., Ltd. Method for detecting state of secondary battery and device for detecting state of secondary battery
JP2006129588A (en) 2004-10-28 2006-05-18 Sanyo Electric Co Ltd Power control method of secondary battery, and power unit
US7570018B2 (en) 2005-02-07 2009-08-04 Colgate-Palmolive Co. Rechargeable powered device
US7383451B2 (en) 2005-02-18 2008-06-03 Lenovo (Singapore) Pte. Ltd. Controlling power usage of computing device components in holistic manner
KR100784086B1 (en) 2005-05-27 2007-12-10 주식회사 엘지화학 Method and apparatus for estimating maximum power of battery by using internal resistance of the battery
US7541693B2 (en) 2005-06-13 2009-06-02 Intel Corporation Power distribution network for computer systems and other low-power applications
US7529948B2 (en) 2005-08-25 2009-05-05 Apple Inc. Methods and apparatuses for dynamic power estimation
US7430679B2 (en) 2005-08-31 2008-09-30 Apple Inc. Charging of mobile devices
US7531989B2 (en) 2005-11-02 2009-05-12 02Micro International Ltd. Battery fuel gauge circuit
US7688029B2 (en) 2005-11-08 2010-03-30 Eveready Battery Company, Inc. Portable battery powered appliance and method of operation
JP5089883B2 (en) 2005-12-16 2012-12-05 日立ビークルエナジー株式会社 Battery management device
US20070153371A1 (en) 2005-12-30 2007-07-05 Samsung Electronics Co., Ltd. Display device, method of manufacturing the same, and composition for use in manufacturing the same
US7839121B2 (en) 2006-03-20 2010-11-23 Lg Electronics Inc. Apparatus and method for managing power of battery packs in a portable device
KR101253635B1 (en) 2006-03-22 2013-04-10 엘지전자 주식회사 Mobile Terminal and Battery Schedualing of that
US7583951B2 (en) 2006-04-14 2009-09-01 Sharp Laboratories Of America, Inc. Virtual batteries for wireless communication device
US7814348B2 (en) 2006-04-26 2010-10-12 Adaptive Materials, Inc. Power management apparatus
US7598702B2 (en) 2006-04-27 2009-10-06 Hewlett-Packard Development Company, L.P. Power management system and method for controlling use of power-consuming applications
US8494479B2 (en) 2006-04-27 2013-07-23 Honeywell International Inc. System and method for optimizing power supplies in a wireless transceiver
US7948208B2 (en) 2006-06-01 2011-05-24 Mojo Mobility, Inc. Power source, charging system, and inductive receiver for mobile devices
TWI426678B (en) 2006-06-28 2014-02-11 Boston Power Inc Electronics with multiple charge rate, battery packs, methods of charging a lithium ion charge storage power supply in an electronic device and portable computers
US20080024007A1 (en) 2006-07-10 2008-01-31 Honeywell International Inc. Multiple load hybrid power supply
US7415623B2 (en) 2006-07-31 2008-08-19 Motorola, Inc. System for managing the power source life between multiple individually powered devices in a wired system and method of using same
US7716500B2 (en) * 2006-08-31 2010-05-11 Ati Technologies Ulc Power source dependent program execution
US7912288B2 (en) 2006-09-21 2011-03-22 Microsoft Corporation Object detection and recognition system
DE102006046184B4 (en) 2006-09-29 2009-01-02 Infineon Technologies Ag A method, apparatus and computer program product for determining an anticipated exceedance of a maximum allowable power consumption of a mobile electronic device and mobile electronic device
US8001407B2 (en) 2006-10-31 2011-08-16 Hewlett-Packard Development Company, L.P. Server configured for managing power and performance
KR100839385B1 (en) 2006-11-01 2008-06-19 삼성에스디아이 주식회사 Battery management system and driving method thereof
US8472699B2 (en) 2006-11-22 2013-06-25 Board Of Trustees Of The Leland Stanford Junior University Arrangement and method for three-dimensional depth image construction
US8890480B2 (en) 2006-11-30 2014-11-18 The Boeing Company Health management of rechargeable batteries
US8001400B2 (en) 2006-12-01 2011-08-16 Apple Inc. Power consumption management for functional preservation in a battery-powered electronic device
US7787405B2 (en) 2007-01-08 2010-08-31 International Business Machines Corporation Method for utilization of active power profiles used in prediction of power reserves for remote devices
EP1947729B1 (en) 2007-01-17 2010-09-22 Samsung SDI Co., Ltd. Hybrid battery
GB2446168A (en) 2007-01-30 2008-08-06 Third Sense Ltd Reducing the power consumed from a battery
US7430675B2 (en) 2007-02-16 2008-09-30 Apple Inc. Anticipatory power management for battery-powered electronic device
US20080218125A1 (en) 2007-03-09 2008-09-11 Ravi Prakash Bansal Battery Charging System
JP2008232758A (en) 2007-03-19 2008-10-02 Nippon Soken Inc Detection device for internal state of secondary cell and neural network type estimation device for quantity of state
KR101389448B1 (en) 2007-03-27 2014-04-28 삼성전자주식회사 Mobile electronic device and power management method thereof
US20080263375A1 (en) 2007-04-23 2008-10-23 Sundstrom Robert J Method And System For Managing Activities In A Battery Powered Device
WO2008133951A2 (en) 2007-04-24 2008-11-06 Massachusetts Institute Of Technology Method and apparatus for image processing
US8063606B2 (en) 2007-05-11 2011-11-22 Research In Motion Limited Battery charger for a handheld computing device and an external battery
US8145918B2 (en) 2007-06-28 2012-03-27 International Business Machines Corporation Monitoring system processes energy consumption
US20090007128A1 (en) 2007-06-28 2009-01-01 International Business Machines Corporation method and system for orchestrating system resources with energy consumption monitoring
US20090016765A1 (en) 2007-07-12 2009-01-15 Kycera Mita Corporation Image Forming Device and Image Forming Method
US8046180B2 (en) 2007-07-13 2011-10-25 Honeywell International Inc. Model-based determination of power source replacement in wireless and other devices
EP2017938A1 (en) 2007-07-18 2009-01-21 Magna Steyr Fahrzeugtechnik AG & Co. KG Accumulator
US20090085553A1 (en) 2007-09-28 2009-04-02 Pavan Kumar Reconfigurable battery pack
US8097355B2 (en) 2007-11-16 2012-01-17 Microsoft Corporation Protecting against incorrect battery polarity
KR20090064813A (en) 2007-12-17 2009-06-22 삼성전자주식회사 Method and device for dynamic changing of backlight settingtime in mobile divices
ITRM20080185A1 (en) 2008-04-09 2009-10-10 Michele Cunico MOTOR VEHICLE
US8624560B2 (en) 2008-04-11 2014-01-07 Apple Inc. Controlling battery charging based on current, voltage and temperature
JP5029488B2 (en) 2008-05-14 2012-09-19 カシオ計算機株式会社 Electronic device, power supply control method and program
US8032317B2 (en) 2008-05-15 2011-10-04 The Nielsen Company (Us), Llc System and methods for metering and analyzing energy consumption of events within a portable device
US8423306B2 (en) 2008-05-22 2013-04-16 Microsoft Corporation Battery detection and user experience
US8242738B2 (en) 2008-05-28 2012-08-14 Texas Instruments Incorporated Systems and methods for determining battery parameters following active operation of the battery
WO2010024892A1 (en) 2008-08-26 2010-03-04 Reserve Power Cell, Llc State of charge battery measurements using data accumulation
US20100070334A1 (en) 2008-09-08 2010-03-18 Dante Monteverde Method and system for location-based mobile device predictive services
JP5293020B2 (en) 2008-09-10 2013-09-18 住友化学株式会社 Electrode mixture for non-aqueous electrolyte secondary battery, electrode and non-aqueous electrolyte secondary battery
US9184603B2 (en) 2008-09-29 2015-11-10 Wilson Lee Multi-chemistry battery charging system and method of identifying and improved charging technique for primary and secondary dry-cell batteries
KR101538498B1 (en) 2008-10-07 2015-07-22 삼성전자주식회사 Method and appratus for battery gaging in portable terminal
US20100106994A1 (en) 2008-10-27 2010-04-29 David Carroll Challener Method, apparatus, and system for adapting power consumption
US7944662B2 (en) 2008-10-28 2011-05-17 Steve Carkner Multi-battery system for high voltage applications with proportional power sharing
US8386816B2 (en) 2008-10-30 2013-02-26 Nokia Corporation Methods, apparatuses, and computer program products for reducing power consumption in computing devices
US20100123436A1 (en) 2008-11-14 2010-05-20 Symbol Technologies, Inc. Optimized lithium-ion battery charging
CN201402987Y (en) 2008-12-31 2010-02-10 广州西格美信电子科技有限公司 Battery pack with battery management system
US8250384B2 (en) 2009-01-05 2012-08-21 International Business Machines Corporation Optimizer mechanism to increase battery length for mobile devices
BRPI1008178A8 (en) 2009-02-09 2017-09-19 Xtreme Power Inc BATTERY DISCHARGE
US20100213897A1 (en) 2009-02-23 2010-08-26 Lawrence Tze-Leung Tse Battery-Cell Converter Management Systems
US8369904B2 (en) 2009-02-24 2013-02-05 Gary Bennis Cell phone battery system with back-up reserve
US8405332B1 (en) 2009-02-24 2013-03-26 Marvell International Ltd. Method to eliminate current surge during spindle spin up
KR20110139244A (en) 2009-03-02 2011-12-28 엘리먼트 에너지 Systems and methods for scalable configurations of intelligent energy storage packs
US10283974B2 (en) 2009-03-02 2019-05-07 Volterra Semiconductor LLC Systems and methods for intelligent, adaptive management of energy storage packs
US8258748B2 (en) 2009-03-11 2012-09-04 Enfora, Inc. Methods and apparatus for modeling, monitoring, simulating and controlling power consumption in battery-operated devices
US8330420B2 (en) 2009-04-10 2012-12-11 The Regents Of The University Of Michigan Dynamically reconfigurable framework for a large-scale battery system
WO2010118310A2 (en) 2009-04-10 2010-10-14 The Regents Of The University Of Michigan Dynamically reconfigurable framework for a large-scale battery system
DE102009002468A1 (en) 2009-04-17 2010-10-21 Robert Bosch Gmbh Determining the internal resistance of a battery cell of a traction battery when using inductive cell balancing
DE102009018787A1 (en) 2009-04-24 2010-10-28 Akasol Engineering Gmbh battery module
US8313864B2 (en) 2009-05-08 2012-11-20 Robert Bosch Gmbh Li-ion battery with blended electrode
US8190939B2 (en) 2009-06-26 2012-05-29 Microsoft Corporation Reducing power consumption of computing devices by forecasting computing performance needs
US8898485B2 (en) 2009-07-15 2014-11-25 Microsoft Corporation Power transfer between devices
US8754614B2 (en) 2009-07-17 2014-06-17 Tesla Motors, Inc. Fast charging of battery using adjustable voltage control
GB2472051B (en) 2009-07-22 2012-10-10 Wolfson Microelectronics Plc Power management apparatus and methods
US8922329B2 (en) 2009-07-23 2014-12-30 Qualcomm Incorporated Battery charging to extend battery life and improve efficiency
JP5635608B2 (en) 2009-07-29 2014-12-03 ザ・リージェンツ・オブ・ザ・ユニバーシティ・オブ・ミシガンThe Regents Of The University Of Michigan Battery charging and discharging scheduling system
JP2011036052A (en) 2009-08-03 2011-02-17 Sanyo Electric Co Ltd Battery charger
TWI422849B (en) 2009-08-13 2014-01-11 Neotec Semiconductor Ltd Battery capacity estimation by dcir
US8255716B2 (en) 2009-08-27 2012-08-28 Qualcomm Incorporated Power optimization for data services
WO2011025937A2 (en) 2009-08-28 2011-03-03 The Charles Stark Draper Laboratory, Inc. High-efficiency battery equalization for charging and discharging
US8744638B2 (en) 2009-09-11 2014-06-03 General Electric Company Method and system for demand response in a distribution network
US8415926B2 (en) 2009-10-19 2013-04-09 Apple Inc. In-situ battery health detector and end-of-life indicator
CN101714629A (en) 2009-11-10 2010-05-26 苏州大学 Tri-platform blended cathode material for lithium ion batteries and preparation method thereof
KR101064370B1 (en) 2009-11-17 2011-09-14 삼성모바일디스플레이주식회사 Organic light emitting display and driving method thereof
KR101613715B1 (en) 2009-12-12 2016-04-20 삼성전자 주식회사 Computer system and control method of the same
WO2011087860A2 (en) 2009-12-22 2011-07-21 G2 Llc Battery charging and management systems and related methods
TW201122753A (en) * 2009-12-29 2011-07-01 Ind Tech Res Inst Voltage scaling systems
US8962188B2 (en) 2010-01-07 2015-02-24 Nanotek Instruments, Inc. Anode compositions for lithium secondary batteries
JP2013516746A (en) 2010-01-11 2013-05-13 アンプリウス、インコーポレイテッド Variable capacity battery assembly
US8504855B2 (en) 2010-01-11 2013-08-06 Qualcomm Incorporated Domain specific language, compiler and JIT for dynamic power management
US20110187309A1 (en) 2010-02-01 2011-08-04 Acoustic Arc International Ltd. Apparatus for automatically switching and charging multiple batteries
TWI404963B (en) 2010-02-10 2013-08-11 Chung Shan Inst Of Science Method for detecting battery module status
US20120326671A1 (en) 2010-03-15 2012-12-27 Brusa Elektronik Ag Balancing the states of charge of charge accumulators
CN101834320B (en) 2010-04-07 2012-02-15 清华大学 Method and device for scheduling batteries
DK2559097T3 (en) 2010-04-13 2018-06-25 Fluidic Inc ELECTROCHEMICAL METAL AIR CELL WITH HIGH ENERGY EFFICIENCY MODE
US9130376B2 (en) 2010-04-23 2015-09-08 Psion Inc. System and method for externally controlling the charging of a battery powered device
US8386826B2 (en) 2010-04-23 2013-02-26 Psion Inc. System and method for managing power of a portable device
US9912175B2 (en) 2010-04-23 2018-03-06 9609385 Canada Inc. Battery harvester
US9413181B2 (en) 2010-04-23 2016-08-09 The Flewelling Ford Family Trust Wearable power supply comprising a master cell and a slave cell
US8836274B2 (en) 2010-04-26 2014-09-16 Psion Inc. System and method for displaying battery information before executing and operating system
US9726732B2 (en) 2010-06-22 2017-08-08 GM Global Technology Operations LLC Adaptive battery parameter extraction and SOC estimation for lithium-ion battery
US8487473B2 (en) 2010-06-24 2013-07-16 Microsoft Corporation Hierarchical power smoothing
US8732487B2 (en) 2010-06-30 2014-05-20 Microsoft Corporation Predictive computing device power management
JP5558941B2 (en) 2010-06-30 2014-07-23 三洋電機株式会社 How to detect battery internal resistance
US8612077B2 (en) 2010-07-07 2013-12-17 Massachusetts Institute Of Technology Hybrid electric vehicle and method of path dependent receding horizon control
US8423215B2 (en) 2010-08-10 2013-04-16 Tesla Motors, Inc. Charge rate modulation of metal-air cells as a function of ambient oxygen concentration
KR20120025274A (en) 2010-09-07 2012-03-15 삼성전자주식회사 Method and apparatus for power controlling by cut-off voltage in a portable terminal
US20120098705A1 (en) 2010-10-22 2012-04-26 Palm, Inc. Use of heuristic data for sending message from mobile computing device
US20120102407A1 (en) 2010-10-25 2012-04-26 Microsoft Corporation Displaying battery life resulting from setting changes
US8635630B2 (en) 2010-10-25 2014-01-21 Microsoft Corporation Application lifetime management
US20120109519A1 (en) 2010-10-27 2012-05-03 Honda Motor Co., Ltd. System and method for routing bev to charging station
US8569995B2 (en) 2010-11-15 2013-10-29 Volkswagen Ag Control circuit and method for controlling a plurality of battery cells based on a determined number of coupled battery cells
US9182803B2 (en) 2010-12-02 2015-11-10 Advanced Micro Devices, Inc. Load step mitigation method and apparatus
US20120144215A1 (en) 2010-12-03 2012-06-07 Advanced Micro Devices, Inc. Maximum current limiting method and apparatus
US20120150247A1 (en) 2010-12-08 2012-06-14 Meier Giovanni C Battery pack topology
EP2466718A1 (en) 2010-12-16 2012-06-20 Dialog Semiconductor GmbH Multiple battery charger with automatic charge current adjustment
US8665214B2 (en) 2010-12-29 2014-03-04 Qualcomm Incorporated Extending battery life of a portable electronic device
US20120210150A1 (en) 2011-02-10 2012-08-16 Alcatel-Lucent Usa Inc. Method And Apparatus Of Smart Power Management For Mobile Communication Terminals
FR2972304A1 (en) 2011-03-02 2012-09-07 Commissariat Energie Atomique BATTERY WITH INDIVIDUAL MANAGEMENT OF CELLS
US8949629B2 (en) 2011-04-01 2015-02-03 International Business Machines Corporation Predicting battery power usage
GB201106356D0 (en) 2011-04-14 2011-06-01 Univ Strathclyde Automated construction of usage policies
JP5208244B2 (en) 2011-05-06 2013-06-12 株式会社豊田自動織機 Negative electrode active material for lithium ion secondary battery and method for producing the same, lithium ion secondary battery and method for producing the same
JP5835941B2 (en) 2011-05-17 2015-12-24 日立オートモティブシステムズ株式会社 Nonaqueous electrolyte secondary battery
US8624719B2 (en) 2011-06-03 2014-01-07 Bosch Automotive Service Solutions Llc Smart phone control and notification for an electric vehicle charging station
US8751845B2 (en) 2011-06-07 2014-06-10 Microsoft Corporation Estimating and preserving battery life based on usage patterns
US9152202B2 (en) 2011-06-16 2015-10-06 Microsoft Technology Licensing, Llc Mobile device operations with battery optimization
US9136705B2 (en) 2011-06-17 2015-09-15 GM Global Technology Operations LLC Scalable method of proportional active state of charge balancing for managing variations in the state of health of batteries
CN102230953B (en) 2011-06-20 2013-10-30 江南大学 Method for predicting left capacity and health status of storage battery
US9698451B2 (en) 2011-07-06 2017-07-04 Apple Inc. Using reference electrodes to manage batteries for portable electronic devices
US8958854B1 (en) 2011-07-22 2015-02-17 Cellco Partnership Dynamic battery saver for a mobile device
JP5623994B2 (en) 2011-07-29 2014-11-12 日立オートモティブシステムズ株式会社 Power converter
CN103782443B (en) 2011-08-01 2017-10-03 马克西姆综合产品公司 Simple and highly efficient balancing circuitry and method for hybrid battery
CN103582963B (en) 2011-08-05 2015-12-23 松下知识产权经营株式会社 Electronic equipment
US20130043827A1 (en) 2011-08-10 2013-02-21 Nathan Daniel Weinstein Portable power charger
US20130162430A1 (en) 2011-08-18 2013-06-27 Wefi, Inc. Method and System for Charging Mobile Devices
US8538686B2 (en) 2011-09-09 2013-09-17 Microsoft Corporation Transport-dependent prediction of destinations
US8478450B2 (en) 2011-10-04 2013-07-02 Advanergy, Inc. Power control system and method
US8766597B2 (en) 2011-10-21 2014-07-01 Linear Technology Corporation Optimized bi-directional balancing method and system
WO2013060802A1 (en) 2011-10-25 2013-05-02 St-Ericsson Sa Battery-operated electronic device and method
WO2013066865A1 (en) 2011-10-31 2013-05-10 Cobasys, Llc Intelligent charging and discharging system for parallel configuration of series cells with semiconductor switching
US8829847B2 (en) 2011-11-01 2014-09-09 Blackberry Limited Hybrid battery system for portable electronic devices
EP2590050B1 (en) 2011-11-01 2017-07-26 BlackBerry Limited Hybrid battery system for portable electronic devices
CN202424488U (en) 2011-11-18 2012-09-05 北京汇能精电科技有限公司 Shared-cathode-type anti-reversing-function topology circuit applied to photo-electricity storage battery
US8860347B2 (en) 2011-11-29 2014-10-14 Dispensing Dynamics International Apparatus for reducing current drain and current spike impact on battery-powered electronic dispensers
JP6224005B2 (en) 2012-01-19 2017-11-01 ナイキ イノベイト シーブイ Power management in activity monitoring equipment
US9262182B2 (en) 2012-01-25 2016-02-16 Apple Inc. Dynamic parameter profiles for electronic devices
US8793520B2 (en) 2012-01-25 2014-07-29 Apple Inc. Power management of electronic devices based on charging location
KR101498761B1 (en) 2012-02-02 2015-03-04 주식회사 엘지화학 Apparatus and method of estimating state of health for battery, and battery management system using the same
KR101178152B1 (en) 2012-02-23 2012-08-29 주식회사 엘지화학 Battery pack of novel structure
US8594648B2 (en) 2012-02-23 2013-11-26 International Business Machines Corporation Calendar-based power reserve
US9425631B2 (en) 2012-02-27 2016-08-23 Infineon Technologies Austria Ag System and method for battery management
WO2013145000A1 (en) 2012-03-28 2013-10-03 株式会社 日立製作所 Heterogeneous battery connection device and battery system using same
US10690725B2 (en) 2012-03-29 2020-06-23 Atieva, Inc. Battery state-of-charge estimation
KR102000295B1 (en) 2012-04-11 2019-10-01 유니버시티 오브 써던 캘리포니아 Runtime selection of most energy-efficient approach for services requested by mobile applications
WO2013165371A1 (en) 2012-04-30 2013-11-07 Hewlett-Packard Development Company, L.P. Energy storage charging from an adjustable power source
BR112014027173A2 (en) 2012-05-04 2017-06-27 Nano Now Pty Ltd electrode material, and electrode
JP6119402B2 (en) 2012-05-29 2017-04-26 株式会社Gsユアサ Internal resistance estimation device and internal resistance estimation method
US9285851B2 (en) 2012-06-22 2016-03-15 Microsoft Technology Licensing, Llc Optimizing battery use for known future load
EP2682840A1 (en) 2012-07-06 2014-01-08 BlackBerry Limited Controlling current draw
JP5678928B2 (en) 2012-07-31 2015-03-04 トヨタ自動車株式会社 All-solid battery and method for manufacturing the same
US10110130B2 (en) 2012-08-12 2018-10-23 Loai Galal Bahgat Salem Recursive DC-DC converter
US9318910B2 (en) 2012-09-06 2016-04-19 Samsung Sdi Co., Ltd. Cell balancing circuit and cell balancing method using the same
US20140082384A1 (en) 2012-09-20 2014-03-20 Apple Inc. Inferring user intent from battery usage level and charging trends
US8768567B2 (en) 2012-10-29 2014-07-01 Broadcom Corporation Intelligent power and control policy for automotive applications
US9261563B2 (en) 2012-11-07 2016-02-16 Zero Motorcycles, Inc. System and method for improved battery charge state determination
US9537994B2 (en) 2012-12-03 2017-01-03 Douglas Baldasare System and method for providing and locating public or private mobile device charging stations
JP6045901B2 (en) 2012-12-18 2016-12-14 オートモーティブエナジーサプライ株式会社 Mixed electrode for non-aqueous electrolyte battery and manufacturing method thereof
US9189056B2 (en) 2012-12-26 2015-11-17 Intel Corporation Mixed cell type battery module and uses thereof
US9012090B2 (en) 2012-12-27 2015-04-21 Palo Alto Research Center Incorporated Advanced, high power and energy battery electrode manufactured by co-extrusion printing
US20140203780A1 (en) 2013-01-24 2014-07-24 Texas Instruments Incorporated System and method for active charge and discharge current balancing in multiple parallel-connected battery packs
CA2845684A1 (en) 2013-03-13 2014-09-13 Manitoba Hydro International Ltd. Heterogeneous energy storage system and associated methods
CN205724938U (en) 2013-03-14 2016-11-23 米沃奇电动工具公司 There is the electric tool of multiple set of cells
US8972175B2 (en) 2013-03-14 2015-03-03 Qualcomm Incorporated Navigation using crowdsourcing data
EP2973935B1 (en) 2013-03-15 2018-10-31 GLX Power Systems Inc. Method and apparatus for creating a dynamically reconfigurable energy storage device
KR101459464B1 (en) 2013-03-19 2014-11-10 현대자동차 주식회사 Method and system for controlling power of fuel cell vehicle
CN103226184B (en) 2013-03-20 2015-09-02 东莞宇龙通信科技有限公司 The method of battery information and many battery terminal is obtained in many battery terminal
US9286568B2 (en) 2013-05-03 2016-03-15 Asurion, Llc Battery drain analysis and prediction for wireless devices
US8749193B1 (en) 2013-05-10 2014-06-10 Inpower Llc Battery protection circuit for multiple battery power supply and charging system
KR101595562B1 (en) 2013-05-30 2016-02-18 주식회사 엘지화학 Lithium secondary battery
US9583279B2 (en) 2013-07-01 2017-02-28 Samsung Sdi Co., Ltd. Secondary battery
US9671944B2 (en) 2013-07-12 2017-06-06 Microsoft Technology Licensing, Llc Inclusion/exclusion user interface controls for range filters
JP6119516B2 (en) 2013-09-02 2017-04-26 ソニー株式会社 Battery pack and electric vehicle
JP2015064676A (en) 2013-09-24 2015-04-09 株式会社東芝 Information processing device, semiconductor device, information processing method, and program
CN103683255A (en) 2013-11-28 2014-03-26 成都市宏山科技有限公司 Starting-up anti-surge circuit
US10128528B2 (en) 2014-01-02 2018-11-13 Johnson Controls Technology Company Combinatorial chemistries for matching multiple batteries
KR20150081731A (en) 2014-01-06 2015-07-15 삼성에스디아이 주식회사 Battery pack, energy storage system including the battery pack, and method of operating the battery pack
US20150207344A1 (en) 2014-01-17 2015-07-23 General Electric Company Configurable hybrid energy storage system and method
CN106104904B (en) 2014-02-12 2019-04-02 南特能源公司 Operation includes the method for the electrochemical cell of electro-deposition fuel
US9760138B2 (en) 2014-04-25 2017-09-12 Microsoft Technology Licensing, Llc Load scheduling in multi-battery devices
US9475398B2 (en) 2014-05-08 2016-10-25 Cummins, Inc. Optimization-based predictive method for battery charging
US10026998B2 (en) 2014-05-15 2018-07-17 Ford Global Technologies, Llc Electric vehicle operation to manage battery capacity
US20150339415A1 (en) 2014-05-21 2015-11-26 Gary L. KLEIN System and method for creating a simulation model via crowdsourcing
US9210662B1 (en) 2014-05-29 2015-12-08 Apple Inc. Adaptive battery life extension
DE102014221547A1 (en) 2014-10-23 2016-05-12 Ford Global Technologies, Llc Method for monitoring the state of charge of a battery
US20160231387A1 (en) 2015-02-09 2016-08-11 Microsoft Microsoft Technology Licensing, LLC Estimating Battery Cell Parameters
US9696782B2 (en) 2015-02-09 2017-07-04 Microsoft Technology Licensing, Llc Battery parameter-based power management for suppressing power spikes
US20160241048A1 (en) 2015-02-18 2016-08-18 Microsoft Technology Licensing, Llc Battery Assembly Combining Multiple Different Batteries
US10158148B2 (en) 2015-02-18 2018-12-18 Microsoft Technology Licensing, Llc Dynamically changing internal state of a battery
US20160248266A1 (en) 2015-02-19 2016-08-25 Microsoft Technology Licensing, Llc Heterogeneous Battery Cell Charging
US20160248125A1 (en) 2015-02-19 2016-08-25 Microsoft Technology Licensing, Llc Heterogeneous Battery Cell Switching
US9748765B2 (en) 2015-02-26 2017-08-29 Microsoft Technology Licensing, Llc Load allocation for multi-battery devices
US20160275400A1 (en) 2015-03-19 2016-09-22 Microsoft Technology Licensing, Llc Device Charging Discovery Service
US10818988B2 (en) 2015-03-19 2020-10-27 Form Energy, Inc. Electrochemical cell comprising an electrodeposited fuel
CA2991415A1 (en) 2015-06-04 2016-12-08 Fluidic, Inc. Hybrid electrochemical cell systems and methods of operation
US20170108906A1 (en) 2015-10-16 2017-04-20 Microsoft Technology Licensing, Llc Single Fuel Gauge for Multiple Energy Storage Devices
US10061366B2 (en) 2015-11-17 2018-08-28 Microsoft Technology Licensing, Llc Schedule-based energy storage device selection
US9793570B2 (en) 2015-12-04 2017-10-17 Microsoft Technology Licensing, Llc Shared electrode battery

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10944132B2 (en) 2015-02-18 2021-03-09 Microsoft Technology Licensing, Llc Dynamically changing internal state of a battery

Also Published As

Publication number Publication date
US9939862B2 (en) 2018-04-10
WO2017083170A1 (en) 2017-05-18
US20170139465A1 (en) 2017-05-18

Similar Documents

Publication Publication Date Title
US9939862B2 (en) Latency-based energy storage device selection
EP3259825B1 (en) Heterogeneous battery cell switching
EP3198429B1 (en) Heterogeneous thread scheduling
CN107534189B (en) Battery management in a device having multiple batteries
US10198059B2 (en) Adaptive doze to hibernate
US10061366B2 (en) Schedule-based energy storage device selection
US20160248266A1 (en) Heterogeneous Battery Cell Charging
US20180136708A1 (en) Dynamic Energy Storage Device Charging
US20180136709A1 (en) Dynamic External Power Resource Selection
EP3542243B1 (en) Dynamic energy storage device discharging
US11656666B2 (en) Dynamic power source selection, charging, and discharging
US10795420B2 (en) Offline battery management in a device

Legal Events

Date Code Title Description
AS Assignment

Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BADAM, ANIRUDH;CHANDRA, RANVEER;PRIYANTHA, NISSANKA ARACHCHIGE BODHI;AND OTHERS;SIGNING DATES FROM 20151009 TO 20151113;REEL/FRAME:045636/0267

STPP Information on status: patent application and granting procedure in general

Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION

STPP Information on status: patent application and granting procedure in general

Free format text: NON FINAL ACTION MAILED

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION