The present invention relates generally to power management techniques for computing systems, such as server farms or clusters in data centers, for instance.
The cost of data center server power consumption and the cooling systems to dissipate the generated heat are major expenses in modern data centers where thousands of servers are densely packed in relatively small racks. To maintain effective operation and sustain profitability, it becomes necessary to have power management systems to optimize the power usage with respect to customer requirements. In other words, these power management systems must be able to use minimum power possible and yet be able to satisfy all customer requirements. It is well established that a typical server consumes a relatively high amount of power even it is idle, due to chip leakage current and other supporting components such as disk drives and network routers. Turning a system off and directing all traffic to a subset of available servers during non-peak hours is a common approach to saving power during periods of low traffic. Current technologies for server shutdown are mainly based on manual actions by system administrators or on automated actions driven by simple policies. Based on their experiences and workload history, the system operators may shut down systems for an extended period of time. In doing so, these system operators must anticipate the possibility of sudden increases in traffic, and often they drastically overprovision to ensure adequate performance (and hence customer satisfaction) even under worst case situations. The amount of manual effort by system administrators is costly, and so is the over provisioning that is typically done to ensure that performance goals are met—particularly as energy costs continue to mount.
New power management strategies that turn servers on and off in real time as workload fluctuates have been investigated. While turning a server off can save energy costs, and perhaps licensing fees as well, a countervailing factor that must be considered is the cost of turning a server on or off. There are several components to this cost. First, during the time that a server is being powered down or up, it is still consuming energy but is not doing any useful work. Second, every time a server is power-cycled, the thermal changes induce more wear and tear on the server, and thus frequent cycling may shorten the lifetime of the server, leading to an increased failure rate and a concomitant increase in replacement cost. Third, 1 to 5 minutes may elapse when restoring a server from shut-down state to a state in which it is fully available for use, depending on system applications and configurations. This may not be fast enough to react to a sudden increase in traffic, resulting in Service Level Agreements (SLA) violations, which may be subject to monetary penalties. All of these problematic costs reduce the usefulness of the strategy of turning servers on and off dynamically, preventing power management strategies of this nature from being deployed widely.
It is therefore desirable to place these unneeded devices into intermediate states of “readiness” such as “standby” or “hibernate” from which the devices may be activated more quickly. These states consume more power than when the device is powered down, and generally have longer activation times than the idle state. Moreover, as common in data center environments with distributed resources, the overall infrastructure is generally composed of different physical components with different power-performance characteristics, different power management capabilities and different power-state-transition latencies. Therefore, the overall system efficiency can vary dramatically by the order which the hosts are chosen to transition into different power states.
At present, there are no algorithms known in the art for managing these tradeoffs between the desire to conserve energy and the desire to be responsive to surges in workload behavior.
The present invention is a system, method and computer program product that addresses the tradeoff between responsiveness and power savings by coordinating multiple surge response zones in a computing cluster with different power-management states system characteristics.
In one embodiment, the tradeoffs between responsiveness and power savings are formulated as an objective function with constraints, and the desired number of devices in each inactive state emerging as the solution to a constraint optimization problem.
Thus, in one aspect, there is provided a system, method and computer program product for managing power consumption in a system comprising computing devices. The method comprises: receiving, at a processing unit, a request to one of: activate or deactivate one or more computing devices from a respective group of inactive or active computing devices, each inactive or active computing device initially in a pre-determined state of readiness; activating or deactivating the one or more computing devices, the activating or deactivating resulting in a number of computing devices in one or more states of readiness i; optimizing configuration of the computing devices in the one or more states of readiness i by minimizing an expected power consumption Σi Ai Pi where i represents all inactive computing devices, Ai represents a number of the computing devices currently in each state i, and, Pi represents an average power consumption of a computing devices while in the state i; and placing the computing devices in the optimized configuration. A program using the processor unit is configured to perform one or more of the receiving, activating, optimizing and placing.
Further to this aspect, there are defined multiple alternative ways of quantifying the desired responsiveness to surges in demand and, in each case, formulating tradeoffs between responsiveness and power savings as an objective function with constraints, and the desired number of devices in each inactive state emerges as the solution to a constraint optimization problem.
Thus, the method further comprises: formulating, for processing by said processor unit, a constraint optimization problem including an objective function with constraints representing respective tradeoffs between transition time responsiveness and power savings; and, solving said constraint optimization problem to determine a number of devices to be placed in each inactive state of readiness.
In a further aspect, there is provided a system for managing inactive states of computing devices comprising: receiving, at a processing unit, a request to one of: activate or deactivate one or more computing devices from a respective group of inactive or active computing devices, each inactive or active computing device initially in a pre-determined state of readiness; activating or deactivating the one or more computing devices, the activating or deactivating resulting in a number of computing devices in one or more states of readiness i; optimizing configuration of the computing devices in the one or more states of readiness i by minimizing an expected power consumption Σi Ai Pi where i represents all inactive computing devices, Ai represents a number of the computing devices currently in each state i, and, Pi represents an average power consumption of a computing devices while in the state i; and placing the computing devices in the optimized configuration. A program using the processor unit is configured to perform one or more of the receiving, activating, optimizing and placing.
A computer program product is provided for performing operations. The computer program product includes a storage medium readable by a processing circuit and storing instructions run by the processing circuit for running a method. The method is the same as listed above.
Further, in accordance with one embodiment, provision is made for permitting human involvement in the decision regarding which devices are to be placed in which state.
Advantageously, in one aspect, there is provided an effective and efficient dynamic server buffering system for optimizing power consumption in servers while adhering to specified Service Level Agreements (SLAs).
The objects, features and advantages of the present invention will become apparent to one skilled in the art, in view of the following detailed description taken in combination with the attached drawings, in which:
In one aspect, there is provided a system, method and computer program product for providing automated power management techniques for computing systems, generally, and more particularly, the invention relates to an effective and efficient dynamic server buffering system for optimizing power consumption in servers according to specified constraints. In one embodiment, power consumption optimization adheres to specified Service Level Agreements (SLAs).
Further, the system, method and computer program product provides automated power management and addresses the tradeoff between responsiveness and power savings by coordinating multiple surge response zones in a computing cluster with different power-management states system characteristics. In one embodiment, the tradeoffs between responsiveness and power savings are formulated as an objective function with constraints, and the desired number of devices in each inactive state emerging as the solution to a constraint optimization problem.
In one exemplary embodiment, the Inactive Pool Manager device 45 manages the inactive states of all computing devices in the inactive pool. The Global Manager device 50 manages the interaction of the “Active Pool Manager” device 35 and “Inactive Pool Manager” device 45. For example, the global manager device 50 interfaces with the “Active Pool Manager” device 35 that executes logic configured for determining when computing devices should be activated from the inactive pool, or returned to the inactive pool; and, further interfaces with the “Inactive Pool Manager” device 45 that executes logic configured for dividing the inactive resources into different “inactive zones” operating at the different inactive states and for determining the transition of inactive devices among the different states.
In one embodiment, the Inactive Pool Manager device 45 receives request 46 from the Global Manager device 50, e.g., a request from the Global Manager to either provide one or more computing devices from the inactive pool to the active pool, or accept one or more active computing devices into the inactive pool. If the request was to activate computing devices, the Inactive Pool Manager 45 selects which servers to provide, and takes steps to activate them. If the request is to accept computing devices into the inactive pool, the Inactive Pool Manager device de-activates one or more computing devices to an initial inactive state. Therefore, the “Inactive Pool Manager” that plans the activation transition and the transition(s) of inactive device(s) among the different inactive states (between inactive state transitions) is generally referred to herein as a “planner” device.
Once satisfying the Global Manager's request, the Inactive Pool Manager 45 proactively manages the inactive states of each computing device as follows: 1) by determining the desired number (and identities) of computing devices to be placed in each inactive state by solving a constraint optimization problem that describes a user-specified trade-off between expected readiness (estimated time to be able to activate computing devices when they are needed next) and conserving energy; 2) by generating a plan for changing the current set of inactive states to the desired set; and, by 3) executing the plan.
The abovementioned embodiment can be described more specifically in terms of the following set of quantities:
a set of activation states (e.g. active, idle, standby, hibernate, shutdown-bare, . . . );
an activation vector Ai, representing the number of servers currently or prospectively in each activation state i;
a transition latency matrix Tij, representing the expected time required to change the activation state of a server from i to j;
a power vector Pi, representing the average power consumption of a server while in activation state i;
a readiness vector R, where the kth component Rk represents the minimal amount of time it would take for k inactive servers to be restored to an active state given a specific activation vector A and the transition latency matrix T; and
a desired readiness vector R0, where the kth component R0k represents a specified constraint on the maximum time permitted for k inactive servers to be restored to an active state.
With reference to these defined quantities, a method of managing the inactive server pool in accordance with this embodiment is depicted by the flow chart in
Regardless of whether servers have been activated or deactivated, at step 130 a new activation vector A′ is computed by the IPM. In one embodiment, before computing new activation vector A′, one approach is to wait until the activation steps undertaken at step 116 or the de-activation steps undertaken at step 124 have completed, and observe how many servers are in each inactive state to derive A′. A second approach is to anticipate what the activation vector will be when steps 116 or 124 have completed, which is computed from the original activation vector A and a knowledge of which servers are making transitions and their original and destination states.
From step 130, control then passes to step 140, at which an optimal activation vector A″ is computed. In this preferred embodiment, a constraint-optimization problem is formulated and solved to generate A″. One example of such a constraint-optimization problem is to select A″ so as to minimize the expected power consumption Σi Ai Pi (where the index i runs across all inactive servers) subject to the constraint that Rk≦R0k for all k. The solution can be computed by any of a number of existing constraint-optimization techniques known in the art, ranging from methods such as exhaustive search to ones such as are embodied in the known CPLEX® (Trademark of CPLEX Optimization Inc., TEXAS) optimization software package.
Next, as shown in
Finally, control passes to Step 160, at which the transition plan generated at step 150 is executed, bringing the system to activation state A″.
As an explicit example in accordance with the first embodiment, a device 12, e.g., a server, in the cluster may be in one of the following activation states with respect to a given application or set of applications that are intended to run on that server: 0) active mode, in which it is fully on and operational and processing workload; 1) idle mode, in which the server is idle but ready to accept workload nearly instantaneously; 2) standby mode, in which the server architectural state is saved in memory and the processors and part of the system are put into low-power state; 3) hibernate mode, in which the server architectural and memory state are saved into disk, and various components of the server such as the memory and CPU are in low power consumption mode; and, 4) shutdown-prepared mode, in which all components are completely powered down but the operating system, middleware and software needed by the application are loaded on the server. Servers may even be in any of several less-prepared states of readiness with respect to the application(s) of interest. For example, the server may be in a 5) shutdown-bare mode, in which it is necessary to install some combination of the operating system, hypervisor, middleware, and/or software on the server (either by installing them via traditional methods or by loading a virtual machine image) before it is able to run the application of interest, or a 6) shutdown-teardown mode, in which the server needs to have its current software, middleware and operating system removed before it is ready to be re-provisioned with the appropriate operating system, software and middleware.
Given the aforementioned definition of the server activation states, in an illustrative example, supposing that there are 2 active servers and 6 inactive servers (1 in idle mode, 1 in standby mode, 1 in hibernate mode, 1 in shutdown-prepared mode, and 2 in shutdown-bare mode), the activation vector A would be represented as:
A0=2
A1=1
A2=1
A3=1
A4=1
A5=2
A6=0
Or, more compactly, A=(2,1,1,1,1,2,0).
Continuing this example, consider a transition latency matrix 80 as given in
Furthermore, for this example, suppose that the expected average power consumption in the various states is
P6=5 watts
P5=5 watts
P4=5 watts
P3=10 watts
P2=20 watts
P1=50 watts
P0=150 watts
Or, more compactly, P=(150,50,20,10,5,5,5).
Continuing the example further, a user may specify a desired state of readiness via the desired readiness vector R0. For example, an administrator or an automated entity such as a workload manager determines that, given the historical volatility of a given workload, it is advisable for it to take no more than 5 seconds for a single inactive server to be brought to the active state, no more than 30 seconds for two servers to be brought to the active state, and no more than 180 seconds for three servers, no more than 400 seconds for four servers, no more than 600 seconds for five servers, and no restrictions on how long it can take for 6 or more servers to be brought back to the active state in the event of a sudden surge in workload. Then the administrator or workload management software uses an interface to set the desired readiness vector to the values R0=(5, 30, 180, 400, 600), with R0k set to infinity for k>5.
In this embodiment, the constraint optimization problem is to compute the activation vector A such that:
the actual readiness vector R will not exceed R0 in any component, i.e. Rk≦R0k for all k; and
the expected aggregate power consumption for activation vector A, Σi Ai Pi, is minimized (the summation index range need not include the active state i=0, although whether or not it does is immaterial because the active state manager will already have determined A0, so all possible solutions will share the same value for it.).
Note that the kth component of the actual readiness vector R of any given activation vector A can be computed as the expected time for k inactive servers to be placed in the active state, provided that the most efficient route to activation is taken in terms of server transition latencies. Thus Rk is computable from the activation vector A, the transition latency matrix T, and certain knowledge about whether servers can be activated serially or in parallel. For example, suppose the A is given as above: A=(2,1,1,1,1,2,0), T is given as in
In order to determine the optimal activation vector among all for which the number of inactive servers is equal to the current number of inactive servers, an exhaustive search is conducted over all possible activation vectors to find the one that minimizes the total power consumption of the inactive pool while satisfying the readiness vector constraint, or use any of a number of more sophisticated constraint optimization methods such as are embodied in the known CPLEX optimization software package. In this example, it turns out that A=(2,1,1,1,1,2,0) is the optimal activation vector.
In alternate embodiments, the method is substantially similar to the first embodiment, except that the desired readiness is described in a manner other than as a specified constraint on the maximum time permitted for k inactive servers to be restored to an active state. An important class of such alternate embodiments is one for which the first embodiment is preceded with a step in which the alternate way of expressing desired readiness is translated into the aforementioned desired readiness vector R0. For example, in a second embodiment, in lieu of the readiness vector R0, a desired demand fluctuation response vector F0 is provided, such that the kth component F0k represents the maximum time permitted for a plurality of servers to be allocated so as to provide acceptable performance should the workload intensity increase by a fraction gk≦g≦gk+1 above its present level. The workload intensity may be expressed in terms of number of clients, number of requests per second, or any other suitable metric. The fractions gk may be set to any values, but are preferentially set such that the lowest value g0 is set to zero and the highest value is set to infinity so that the full range of possible rises in demand can be covered. An example is provided in the table below, which can equivalently be expressed as F0=(0, 15, 120, 400, 600, 720, ∞) and g=(0, 0.1, 0.2, 0.3, 0.5, 0.8, ∞). As summarized in TABLE 1 below, the interpretation is that a workload increase of up to 10% above the present level must be handled immediately without violating acceptable limits on performance; a workload increase of 10-20% above the present level must be handled acceptably within 15 seconds, a workload increase of 20-30% must be handled acceptably within 120 seconds, and so on, up to the final requirement that a workload increase of 80% or more be handled within 720 seconds.
This second embodiment is identical to the first embodiment, except that in the second embodiment the method of the first embodiment is preceded by a first step of converting from the requirement expressed in terms of readiness F0 to one expressed in terms of the readiness vector R0. All subsequent steps are completely the same as in the first embodiment. Specifically, for each value k, an algorithm computes the minimal number of servers required to achieve an acceptable performance given the assumption that the demand is increased by a fraction gk above its present value. What constitutes acceptable performance depends on the nature of the application and the preferences of the administrator. One form of preference is to establish an upper limit on the CPU utilization permitted on a server, or among a set of servers; e.g., 80% or 90% may be used as values for this threshold. An alternative is to express preferences directly in terms of application metrics such as response time: for example, the administrator might specify that the response time for a given web application should not exceed two seconds for more than 5% of the requests. The algorithm that computes the minimal number of servers required to achieve the specified acceptable performance for a given assumed demand may, for example, comprise a queuing-theoretic algorithm coupled with an optimization algorithm. In one embodiment of the algorithm, a hypothetical workload intensity λk is generated for each value of k by multiplying the current workload by (1+gk), where gk is the fraction of increase in workload intensity (e.g., see Table 1). The type of arrival process (e.g. Markov, Deterministic, or General) is either assumed, or estimated from measured arrival statistics. The service process type is likewise assumed or estimated from statistics. For each hypothetical workload intensity, a series of one or more hypothetical number of servers is assumed. A standard queuing theory formula or a numerical procedure (e.g. based on formulas and procedures from the queuing theory textbooks Queuing Systems, Volume I and Queuing Systems, Volume II by Leonard Kleinrock) is used to compute the estimated performance (i.e. an estimated response-time distribution, throughput, and/or average server utilization, depending on which is the performance metric of interest). An optimization algorithm (e.g. exhaustive search or binary search) examines the estimated performance measures produced by the queuing algorithm, and identifies for each assumed workload intensity λk the minimal number of servers s*k for which the computed performance lies within a range deemed acceptable by the administrator.
For example, suppose there is a supply of identical-capacity servers, and that the current workload can be satisfied with acceptable performance by 10 servers. Further consider that 10% additional workload can be accommodated with acceptable performance by one additional server, 20% additional workload can be accommodated by two additional servers, 30% additional workload can be accommodated by three additional servers, 50% additional workload can be accommodated by five additional servers, and 80% additional workload can be accommodated by eight additional servers. Then several components of the equivalent desired readiness vector R0 are automatically identified from these results: namely, R01=F01, R02=F02, R03=F03, R05=F04, and R08=F05. To obtain the readiness for 4 servers, R04, one may make the pessimistic assumption that it is equal to that for 5 servers since it is not otherwise specified; hence R04=F04. Similarly, the pessimistic assumption leads to R06=F05 and R07=F05. For a plurality of servers greater than 8, the fact that no readiness value exceeds 720 seconds may be used to infer that R0k=F05 for k>5. Thus R0=(0, 15, 120, 400, 600, 600, 720, 720, 720) and R0k=720 for k>8. Now, having derived the desired readiness vector, the remaining steps are exactly as described in the first embodiment.
In further alternate embodiments of the invention, the user can specify alternative measures of preferences in place of the aforementioned readiness vector R0. For example, in a third embodiment, the steps are nearly the same as in the first embodiment represented in
In a preferred embodiment, the probabilities ps for “s” servers to be required for acceptable performance are computed as follows: Suppose c(w), the cumulative workload intensity distribution as a function of workload intensity “w”, is known. Such a function c(w) is depicted for example in
In a fourth embodiment, the computation of the desired activation vector A″ takes into consideration a further constraint, objective or tradeoff based on minimizing wear-and-tear on computing resources that can result from changing their activation state. For example, the nature of the constraint or objective could be such as to discourage or forbid the absolute total number of changes in activation state from exceeding a specified value. Alternatively, the constraint or objective could be constructed to discourage or forbid the number of changes in activation state within any given time period from exceeding a given upper limit. Alternatively, the constraint or objective might be based on the specific activation states and transitions among them, rather than just the total number or frequency of changes.
In a fifth embodiment, shown in the flow chart of a method 300 in
Any of the above embodiments of the invention can be extended to include a Calibration Process that automatically establishes various quantities required for computing the optimal activation vector, such as the transition latency matrix and the power curves. The Calibration Process is triggered at the admission of a new computing resource to either of the pools. The calibration process works as follows: 1) A calibration utilization benchmark—similar in operational principle to SPECpower_ssj™ (trademark of the Standard Performance Evaluation Corporation: http://www.spec.org/power_ssj2008) incorporated by reference herein, that evaluates the power and performance characteristics of volume server class and multi-node class computers—is run at varying device utilizations and corresponding power utilization is monitored; idle device power is recorded; and, for available device power states: a) the device is cycled through each state; and, b) Transition latencies and power overhead, and power consumption at different states are recorded; and, based on the observed data, a “resource descriptor” is generated.
The end results of the calibration process are the generation of “resource descriptors” that include: (i) a transition latency matrix; (ii) a transition power matrix; and (iii) the resource power curve for each computing device.
The calibration process may be triggered at the admission of a new computing device to a pool. The full calibration process can be performed “eagerly” i.e., immediately after the device is added to the pool; or “lazily”, based on performance requirements, available power budgets and energy costs. For example, the added resources might be immediately needed to satisfy current demand, or the time-varying energy costs and system load might make deferring calibration to a low-demand, low-cost time period preferable.
Data structures representing the resource descriptors are input into the pool managers to be used in host ordering for power-efficient transitioning among active and inactive states. Additional provision is made for allowing manual input in the decision regarding which devices are to be placed in which state.
As a result, the system, method and computer program product provides dynamic buffering in which servers are maintained in various states of readiness, and caused to make transitions among these states of readiness without consuming excessive amounts of energy. In one embodiment, transitions among these states of readiness are determined in such a way as to maintain good SLA behavior.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with a system, apparatus, or device running an instruction.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with a system, apparatus, or device running an instruction. Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may run entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present invention are described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which run via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which run on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more operable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be run substantially concurrently, or the blocks may sometimes be run in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
Number | Name | Date | Kind |
---|---|---|---|
5283905 | Saadeh et al. | Feb 1994 | A |
5506987 | Abramson et al. | Apr 1996 | A |
5692204 | Rawson et al. | Nov 1997 | A |
5761507 | Govett | Jun 1998 | A |
5872972 | Boland et al. | Feb 1999 | A |
6161173 | Krishna et al. | Dec 2000 | A |
6324580 | Jindal et al. | Nov 2001 | B1 |
6771661 | Chawla et al. | Aug 2004 | B1 |
6795928 | Bradley et al. | Sep 2004 | B2 |
6816905 | Sheets et al. | Nov 2004 | B1 |
6859882 | Fung | Feb 2005 | B2 |
6996728 | Singh | Feb 2006 | B2 |
7051215 | Zimmer et al. | May 2006 | B2 |
7058826 | Fung | Jun 2006 | B2 |
7124321 | Garnett et al. | Oct 2006 | B2 |
7143300 | Potter et al. | Nov 2006 | B2 |
7174468 | Gary et al. | Feb 2007 | B2 |
7210145 | Srinivasan | Apr 2007 | B2 |
7219249 | Ghose et al. | May 2007 | B1 |
7228441 | Fung | Jun 2007 | B2 |
7272735 | Fung | Sep 2007 | B2 |
7337333 | O'Conner et al. | Feb 2008 | B2 |
7441135 | Chan et al. | Oct 2008 | B1 |
7797563 | Moll et al. | Sep 2010 | B1 |
20020004913 | Fung | Jan 2002 | A1 |
20020004915 | Fung | Jan 2002 | A1 |
20030037268 | Kistler | Feb 2003 | A1 |
20030056126 | O'Connor et al. | Mar 2003 | A1 |
20030120751 | Husain et al. | Jun 2003 | A1 |
20030158940 | Leigh | Aug 2003 | A1 |
20030204759 | Singh | Oct 2003 | A1 |
20040015581 | Forbes | Jan 2004 | A1 |
20040034807 | Rostowfske | Feb 2004 | A1 |
20050050200 | Mizoguchi | Mar 2005 | A1 |
20050149940 | Calinescu et al. | Jul 2005 | A1 |
20050165925 | Dan et al. | Jul 2005 | A1 |
20050182838 | Sheets et al. | Aug 2005 | A1 |
20050188075 | Dias et al. | Aug 2005 | A1 |
20060168104 | Shimizu et al. | Jul 2006 | A1 |
20060265616 | Cesare et al. | Nov 2006 | A1 |
20070043860 | Pabari | Feb 2007 | A1 |
20070049133 | Conroy et al. | Mar 2007 | A1 |
20070130341 | Ma | Jun 2007 | A1 |
20070276934 | Lai | Nov 2007 | A1 |
20080126816 | Prete et al. | May 2008 | A1 |
20090235097 | Hamilton et al. | Sep 2009 | A1 |
20100218005 | Jain et al. | Aug 2010 | A1 |
Number | Date | Country |
---|---|---|
2005367416 | Dec 2005 | JP |
2006195986 | Jul 2006 | JP |
Entry |
---|
Standard Performance Evaluation Corporation, last updated Jul. 15, 2010, Copywright 1995-2010, http://www.spec.org/power—ssj2008. |
Deusterwald, E., et al., “Characterizing and Predicting Program Behavior and its Variability”, Proceedings of the 12th International Conference on Parallel Architectures and Compilation Techniques, Sep. 27-Oct. 1, 2003, p. 220, Abstract only. |
Benini, L., “Policy optimization for dynamic power management,”; Computer-Aided Design of Integrated Circuits and Systems, IEEE Transactions, Publication Date: Jun. 1999, vol. 18, Issue: 6, pp. 813-833, INSPEC Accession No. 6270844. Digital Object Identifier: 10.1109/43.766730. Posted online: Aug. 6, 2002 22:29:34.0 http://ieeexplore.ieee.org/xpl/RecentIssue.jsp?punumber=43 http://ieeexplore.ieee.org/xpl/tocresult.jsp?isnumber=16613&isYear=1999. |
Chase, J., et al., “Balance of Power: Energy Management for Server Clusters,” Proceedings of the 8th Workshop on Hot Topics in Operating (2001). http:// citeseer.ist.psu.edu. http://www.cs.duke.edu/ari/publications/publications.html, Jan. 2001. |
Nishimura, F., “Transaction Modes of Electric Energy Exchange and their Effects on Benefit Optimization and Allocation,”Conference: Energy management and power delivery—International conference, EMPD-Proceedings- , 1995; vol. 1 , p. 25-30, Publisher: Piscataway, NJ. |
Srivastava, M.B., et al., “Predictive system shutdown and other architectural techniques for energy efficient programmable computation,” Very Large Scale Integration (VLSI) Systems, IEEE Transactions, Publication Date: Mar. 1996, pp. 42-55, vol. 4, Issue: 1. |
Tiwari, V., et al., “Guarded evaluation: pushing power management to logic synthesis/design,” International Symposium on Low Power Electronics and Design, Proceedings of the 1995 international symposium on Low power design, 1995, pp. 221-226. |
Zheng, R., et al., “On-demand power management for ad hoc networks,” in: Ad Hoc Networks, Jan. 2005, pp. 51-68, vol. 3, Issue 1. |
Number | Date | Country | |
---|---|---|---|
20120117399 A1 | May 2012 | US |