The invention relates to energy efficiency with rate adaptation and is particularly concerned with rate-adaptation schemes that combine the best properties of sleep-state exploitation and rate-scaling techniques.
Data networking services and applications enable substantial energy savings in broad sectors of economic activity, for example by replacing the transportation of people and goods with the electronic transfer of data packets. In order to maximize the energy-saving yields of the replacement function offered by network services and applications, packet network themselves must target energy efficiency comprehensively, in every component and in every function. Energy efficiency thus becomes an attribute of foremost importance in the design and qualification of network equipment.
Network nodes forward data packets from one network interface to another, often modifying part of their contents. To minimize energy consumption, energy use in network equipment should be proportional to traffic handling activity. More specifically, energy use in a system should scale with the network traffic load and should become negligible when the system does not process packets.
Rate scaling and sleep-state exploitation are popular methods for reducing energy consumption in network nodes when traffic load is well below link capacity. (For reference, in this disclosure the terms rate scaling and sleep-state exploitation as referred to as examples of rate adaptation.)
With rate scaling, the clock frequency of the data-path device changes over time to track the traffic load, using the generally linear relationship that exists between frequency and power to decrease power consumption levels under low traffic loads. However, since the traffic processing rate also scales with the operating frequency, delay accumulation may be caused by frequency reductions. To control delay accumulation, the operation of rate-scaling systems is typically constrained by bounds on the additional delay that lower processing rates can impose on traffic. Steeper reductions of power consumption levels can be obtained by integration of dynamic voltage and frequency scaling (DVFS) technologies in the rate-scaling system. In a DVFS device, the voltage level of the power supply can decrease as the clock frequency scales down, at least down to the minimum voltage level needed to maintain the electronic circuitry of the device in predictable operation.
With sleep-state exploitation, the network device alternates between a full-capacity state where it operates at maximum clock frequency as long as traffic is available for processing and a sleep state where power consumption is much lower.
While a significant body of work can be found in the literature that defines and studies rate-scaling and sleep-state exploitation schemes and architectures, several issues remain unresolved.
First, a clear framework for the coordination of contiguous rate-adaptation devices is not yet available. For sleep-state exploitation techniques with the architectures that have been proposed so far, the lack of coordination may lead to substantial drops in energy-saving performance, while the introduction of coordination requires the broad consensus of a standard body (see for example the ongoing work within the IEEE 802.3az Energy Efficient Ethernet Task Force) or the full cooperation of large portions of the entire network. Even within a single circuit pack, new components, and therefore new sources of energy consumption, must be added to coordinate the clock frequency of multiple rate-scaling devices.
Second, while the energy-saving performance results presented for rate-adaptation techniques are generally encouraging, they heavily depend on the specific set of operating states that are available in a given device and on the resulting power-rate (PR) function. When different schemes are compared, the final choice for the best solution can only be determined after entering the actual parameters of a practical device. General guidelines for straightforward design practices remain unavailable.
Therefore, it would be desirable to have a scheme for rate adaptation that combine the best properties of sleep-state exploitation and rate scaling while overcoming the limitations of the rate-adaptation techniques that are available in the prior art. [AF Question: should the “limitations” be spelled out explicitly here (e.g., need for coordination, lack of a clear winner, lack of a clear trade-off between energy savings and delay degradation)?]
An object of the present invention is to provide an improved system and method for achieving energy efficiencies in packet networks via rate adaptation.
According to an aspect of the invention there is provided a method of establishing a rate-adaptation domain in a packet network having a plurality of connected network nodes not providing rate adaptation, the method having the steps of first, partitioning the plurality of connected network nodes into subdomains, each subdomain having connecting interfaces with at least one other subdomain. Then, identifying those rate independent connecting interfaces among the connecting interfaces wherein the integrity of the data transfers through the connecting interfaces is preserved independent of the operating states of those subdomains connected. Next, identifying at least one subdomain for which all connecting interfaces are rate independent connecting interfaces; and operating this subdomain as a rate independent subdomain.
In some embodiments of the invention the operating step includes receiving packets at an input interface from a domain immediately upstream to the rate-adaptation domain; and establishing Quality-of-Service requirements associated with the received packets. Further, processing the received packets in a processing unit; dispatching packets at an output interface to a domain immediately downstream from the rate-adaptation domain; establishing a set of state variables; controlling the operating state of the processing unit with the state variables so as to control the rate at which packets are dispatched over the output interface; selecting such state variables so as to satisfy a feasible departure curve; and further selecting such state variables so as to reduce energy consumption in the rate-adaptation domain.
Advantageously, in certain embodiments the packet processing step consists of at least one of the group of parsing, modifying, and storing in a buffer queue. Also, in some embodiments the further selecting step selects state variables so as to place the processing unit in a sleep state or selects state variables so as to adjust the clock rate of the processing unit. As well, in some embodiments, the feasible departure curve is an optimal departure curve.
According to another aspect of the invention, there is provided a system having a rate-adaptation domain in a packet network having a plurality of connected network nodes. The system includes a plurality of subdomains, each subdomain being a partitioned subset of the plurality of connected network nodes, each subdomain having connecting interfaces with at least one other subdomain. As well, the system includes a set of rate independent connecting interfaces among the connecting interfaces wherein the integrity of the data transfers through the connecting interfaces is preserved independent of the operating states of those subdomains connected; at least one subdomain for which all connecting interfaces are rate independent connecting interfaces; and wherein the at least one subdomain operates as a rate-adaptation subdomain.
In some embodiments of the invention the at least one subdomain further includes an input interface for receiving packets from a domain immediately upstream to the rate-adaptation domain; a set of Quality-of-Service requirements associated with the received packets; a processing unit for processing the received packets; an output interface for dispatching packets to a domain immediately downstream from the rate-adaptation domain; a set of state variables for controlling the operating state of the processing unit wherein the state variables control the rate at which packets are dispatched over the output interface; a subset of such state variables selected so as to satisfy a feasible departure curve; and a further subset of the subset of state variables selected so as to reduce energy consumption in the rate-adaptation domain.
Advantageously, in certain embodiments the system further includes a buffer queue wherein the processing unit may store packets which have been at least one of the set of parsed and modified by the processing unit. As well, the state variables may be selected to control setting the processing unit in a sleep state or adjusting the clock rate of the processing unit. In certain embodiments, the feasible departure curve is an optimal departure curve.
Note: in the following the description and drawings merely illustrate the principles of the invention. It will thus be appreciated that those skilled in the art will be able to devise various arrangements that, although not explicitly described or shown herein, embody the principles of the invention and are included within its spirit and scope. Furthermore, all examples recited herein are principally intended expressly to be only for pedagogical purposes to aid the reader in understanding the principles of the invention and the concepts contributed by the inventor(s) to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions. Moreover, all statements herein reciting principles, aspects, and embodiments of the invention, as well as specific examples thereof, are intended to encompass equivalents thereof.
The present invention will be further understood from the following detailed description of embodiments of the invention, with reference to the drawings in which:
a illustrates a set of network nodes connected by bidirectional links in accordance with the known art;
b illustrates an alternative version of
c illustrates a directed graph version of
a and 3b illustrate a set of arrival and departure curves;
a and 4b illustrate a set of optimal service curves for the arrival curves of
Following are definitions of terms and concepts that are used throughout the description. Also described is the reference model that is used for evaluating the energy-saving performance of rate adaptation schemes.
A rate-adaptive networking device is a device that receives and forwards data packets over one or more interfaces and is capable of adjusting its operating state to the traffic load it is offered. The rate-adaptive device is arranged with a finite set S={sk,k=1 . . . K} of operating states, where each state is identified by fixed values of clock frequency (fk) and power-supply voltage (Vk): sk=(fk,Vk). Since a unique traffic processing capacity r can be associated with every frequency value f, we can represent the operating states also by reference to the respective processing capacities: sk≡(rk,Vk). For each state sk, an active substate ska, an idle substate skj, and a transition substate skt are further defined, depending on whether the device is processing traffic (ska), not processing traffic (skj), or transitioning to state sk from a different state sj (skt). In a first-order approximation of the energy model for rate-adaptive devices, fixed levels of power consumption (Pka, Pki, Pkt) are associated with each substate. The three power consumption levels are referred to as the active power, the idle power, and the transition power, respectively.
For a given device, it is assumed that the transition time δ, which is the time needed to complete a state transition, is fixed and independent of the two states involved in the transition: δ(sj,sk)=δ∀(j,k). As a conservative assumption, it is assumed that no traffic processing can take place during a state transition.
Eq. (1) expresses the energy consumed over a time interval of duration T based on the time spent in each substate:
The idle power can comfortably be assumed to be always lower than the active power: Pkj=β·Pka,0<β<1. Considering that the device remains idle during a state transition, it is reasonable to argue that the transition power Pkt should be defined as the average of the idle power for the states before and after the state transition, and therefore as a function of both states: Pkt=(Pji+Pki)/2=Pkt(j,k). Observing that, under fluctuating load levels, for every transition into a state there is always a transition out of the same state, the inbound and outbound idle power contributions for state sk can be aggregated into a fixed transition power Pkt=Pki for the inbound state transition, and accordingly remove the idle-power contribution Pki/2 from the transition power for the outbound transition. Eq. (1) may now be rewritten as follows:
Eq. (2) is the metric of reference for comparing the energy-saving performance of different rate-adaptation schemes.
In a sleep-state exploitation device only two operating states are available: the full-capacity state sC≡(C,VC) and the sleep state sS=(0,VS). The energy equation becomes as follows:
E(T)=PCa·TCa+PCi·(TCi+TCt)+PSi·(TSi+TSt) (3)
To take advantage of the reduced power consumption in sleep state, the device must transition out of the full-capacity state every time there is no packet to be processed, so that TCi=0:
E(T)=PCa·TCa+PCi·TCt+PSi·(TSi+TSt) (4)
Sleep-state exploitation matches the average offered traffic load λ by limiting the time spent in the full-capacity state:
In a rate-scaling device, eq. (2) remains the energy equation of reference, only with the restriction that no sleep state is included in the set of operating states available. The device matches the offered load by proper distribution of the time spent in each operating state:
The type of concavity of the power-rate function of a device should drive the selection of the rate-adaptation scheme: if the function is concave over the full set of available processing capacities, i.e., ((P(r1)+P(r2))/2≦P((r1+r2)/2)∀r1<r2, the adoption of sleep-state exploitation is the obvious choice, if effective at all in reducing energy consumption. If instead the curve is convex, i.e., (P(r1)+P(r2))/2≧P((r1+r2)/2)∀r1>r2, a properly designed rate-scaling scheme can yield higher energy savings.
Rate-Adaptation Representation of Packet Networks
It has been historically argued that tight coordination between adjacent network nodes is necessary for certain rate-adaptation techniques to yield any energy-saving gains. The need for coordination hinders the deployment of those techniques because no new technology can be reasonably expected to be exhaustively deployed overnight in any multi-player environment. The following development shows via a simple data path abstraction that the need for coordination can be entirely removed and that rate-adaptive devices can be deployed incrementally, both within individual network nodes and in the network at large.
Referring to
Devices A and B are arranged with respective sets of rate-adaptation operating states, possibly identical. The nature of interface C determines whether the states of devices A and B must be controlled jointly or can be controlled separately:
As a more formal definition, a rate-adaptation domain may consist of one input interface where packets are received from the domain immediately upstream, a processing unit where packets may be parsed, modified, or assigned to buffer queues, and one output interface through which packets are dispatched to the domain immediately downstream. The rate-adaptation domain maintains state variables that drive the operating state of the processing unit and therefore the rate at which packets are forwarded over the output interface. For stability purposes, it is assumed that the maximum transmission capacity of the output interface and the maximum processing capacity of the processing unit are identical and never lower than the maximum capacity of the input interface.
Referring to
More specifically:
In the design of a network system with rate adaptation capabilities, the directed-graph representation of the system helps identify opportunities for the insertion of rate-adaptive devices. As well, the directed-graph representation allows a recognition of trade-offs between the benefits of designs with a small number of rate adaptation domains (lower delay penalties) and designs with a higher number of domains (lower complexity). The directed-graph representation indeed makes it evident that tight coordination between network nodes is not a necessary condition for the introduction of rate-adaptation capabilities in a packet network. Rate-adaptive devices that single-handedly form a rate adaptation domain can be added to the network incrementally, without requiring coordinated efforts from equipment vendors and service providers. It becomes apparent, for example, that a system designer can include a rate-adaptive network processor in a line card that has no rate-adaptive transceivers.
The following disclosure focuses on methods for controlling the operating state of a rate-adaptation domain that fully avoid any coordination between domains.
Implementation Guidelines for Rate-Adaptation Schemes
The following discussion identifies general guidelines for the effective implementation of rate-adaptation schemes.
Consider a rate-adaptation domain in isolation. Through its state-setting policy, a rate-adaptation scheme sets the sequence of operating states in response to a sequence of packet arrivals with the objective of minimizing energy consumption in the domain while not violating the quality-of-service (QoS) requirements of the incoming traffic. Different types of traffic may present different types of QoS requirements, expressed through respective QoS constraints.
Listed here are a number of useful definitions and implications:
To meet the QoS requirements of the incoming traffic, the sequence of operating states set by the rate adaptation scheme must produce a departure curve that always lies between the minimum departure curve (Q0S constraint) and the arrival curve (causality constraint):
A(t)≧D(t)≧Dmin(t),(t)≧0.
Such a departure curve is called feasible. Referring to
In the example of
It is known that for systems with convex power-rate function the departure curve that minimizes energy consumption, called the optimal departure curve Dopt(t), is the shortest feasible curve between the points (0,A(0)) and (T,Dmin(t)). For quick visualization of the result, the following has been suggested:
“Consider a string that is restricted to lie between A(t) and Dmin(t). Tie its one end at the origin and pass the other end through Dmin(t). Now if the string is made taut, its trajectory is the same as the optimal curve.”
a and 4b show the optimal service curves for the two examples of
The “shortest-string result” for convex power-rate functions indicates that energy minimization is achieved when the processing capacity of the rate-adaptation domain is set equal to the average rate needed to meet the QoS constraint exactly by the time available to complete the task.
The following differences can be appreciated between a practical rate-adaptation domain and the more abstract reference system for the results shown in
1. In the abstract reference system, the operating state can be chosen out of an infinite set, with a continuous range of processing capacities available; in the practical rate-adaptation domain the set of operating states is finite, with discrete values of processing capacity available. As a consequence, the optimal departure curve for the practical domain typically yields lower energy savings than the optimal curve for the ideal system.
2. In the abstract system all state transitions are instantaneous; in the practical domain, state transitions complete within a fixed amount of time, during which no traffic processing can take place.
3. In the abstract system, which processes a continuous stream of bits, state transitions can occur at any time. In the practical domain, which processes bits in atomic packets, state transitions can only occur at packet processing boundaries.
4. In the abstract system the arrival curve A(t) is known, so that the minimum departure curve Dmin(t) can be tailored around it before the traffic starts arriving; in the practical domain the arrival curve is unknown.
It is desired to implement a practical rate-adaptation scheme that never violates a given delay constraint d for all packets that traverse a single rate-adaptation domain. In approaching the implementation, the discussion is developed along the following three dimensions:
Operating Intervals
The extended duration of state transitions in the practical rate-adaptation domain motivates the subdivision of the time axis into intervals of variable duration but never shorter than a fixed amount h, called the minimum hold time. In fact, the time cost δ of a state transition implies that frequent state transitions must be deterred to prevent them from occupying most of the operating time of the rate-adaptation domain. If the domain is allowed to spend substantial portions of its operating time switching states, then it must execute all traffic processing work within shorter time intervals, at higher power levels. Even without counting the energy consumed during workless transitions, with a convex power-rate function the simple deviation of the operating state from the optimal average-rate point causes significant energy losses. Forcing the operating state of the domain to remain unchanged for a minimum hold time h>>δ keeps the total transition time below an acceptable fraction of the total operating time.
Our target rate-adaptation scheme divides the operation of the rate-adaptation domain into a sequence of operating intervals (tn,tn+1] of variable duration hn, hn>h . The operating state (and processing capacity) in any operating interval is always different than the state (and capacity) in the interval that immediately follows. These relations may be seen by reference to
With reference to a generic operating interval (tn,tn+1], the rate-adaptation scheme decides to set a different operating state at time tn. At time tn+δ the state transition is complete and the rate-adaptation domain can start processing traffic again. Starting at time tn+h, the rate-adaptation domain checks at every packet processing completion if the state-setting policy requires the operating state to be changed. The end of the operating interval is reached at time tn+1=tn+hn≧tn+h, when the rate-adaptation domain completes the processing of a packet and the state-setting policy indicates the necessity of a state change.
Optimization of the Power-Rate Function
The power-rate function of a rate-adaptation domain defines the relationship between processing capacity and power consumption in the active substate. In a practical device the power-rate function is typically defined over a finite set of discrete capacity values. However, for convenience of presentation and after considering that the composition of the set of discrete capacity values of the practical domain constitutes itself a design choice, this section refers to power-rate functions that are defined over continuous ranges of capacity values.
The current lack of commercial rate-adaptive network devices that can quickly adjust their operating state to traffic load conditions makes for a lack of real-life numbers for key parameters such as the state transition time and the power-rate function. However, sleep-state exploitation devices and rate-scaling devices that incorporate DVFS capabilities to offer an extended set of operating states, only controlled over a larger timescale, do exist (especially general-purpose processors [INTELPXA, INTELPENTIUM]) and can be used to obtain a reasonable indication of what future devices can accomplish.
Focusing now on DVFS-capable rate-scaling devices, a commonly accepted conclusion about their power-rate function is its partition into two different operating regions. These two different operating regions may be seen in
It is relevant now to consider the equivalent power-rate function of a sleep-state exploitation device whose operation alternates between the full-capacity state sC≡(C, PC) and the sleep state sS(0, PS). In the ideal case of a device with instantaneous state transitions (δ=0) the equivalent power-rate function is a continuous function where the operating state of the device over an interval of duration T is derived from the time TC spent in the full-capacity state as follows: Peq(T)=[PC·TC+PS·(T−TC)/T. Refer to
If a rate-scaling device and a sleep-state exploitation device with identical full-capacity state sC(C,Pc) are compared, and the condition holds that that the minimum-capacity power P0 in the former is higher than the sleep-state power PS in the latter, referring to
where Prs(r) is the power-rate function of the original rate-scaling domain.
Specification of the State-Setting Policy
The state-setting policy is the algorithmic core of the rate-adaptation scheme. It sets the time and the destination of each state transition, based on system parameters (power-rate function, transition time δ, and minimum hold time h), QoS constraints (maximum added delay d), and state variables (queue length Q and traffic arrival measures).
First addressed is the determination of the time when a state transition should occur. In a previous section it was established that, in order to absorb the cost of a state transition, the domain should remain in the resulting state for at least a time h after starting that transition. During the operating interval, the processing capacity of the domain remains unchanged.
In setting the value of h, the tradeoff is between extending h to minimize the negative effect of state transitions (an increase of average processing rate by up to h/(h−δ) is needed to compensate the loss of processing capacity caused by a transition time δ), and contracting h to improve the accuracy of the departure curve D(t) in tracking the arrival curve A(t) (the larger h, the longer the time the two curves have to diverge). Since the delay constraint d expresses the maximum accepted distance between arrival and departure curve, it may be used to drive the specification of h.
The following definition is an important property that drives the classification of state-setting policies.
Weak Backlog Clearing Property—At the beginning t0 of the operating interval the state-setting policy chooses the processing capacity from the set of available capacities that are sufficient to clear the current queue backlog Q(t0)>0 by the closest possible end of the operating interval (t1=t0+h): r(t0)ε{rk:skεSrk≧Q(t0)/h−δ)}. If no such capacity is available, the policy chooses the full capacity of the rate adaptation domain: r(t0)=C.
A state-setting policy that holds the weak backlog clearing property is referred to as a weak backlog clearing policy. It should be noted that the weak backlog clearing property has no bearing over the case with null backlog (i.e., when Q(t0)=0).
The following theorem gives the relationship between d and h in a fluid rate-adaptation domain, where bits arrive in a continuous stream without packet boundaries.
Theorem 1—In a fluid rate-adaptation domain with weak backlog clearing policy the delay constraint d is bounded as follows:
d<d
max=2h+δ (8)
Proof: Without loss of generality, let t0 be the start time of an operating interval where the state-setting policy chooses a processing capacity r(t0) such that r(t0)>Q(t0)/(h−δ). At time t1=t0+h, when the rate-adaptation domain has the next chance to set the processing capacity, the queue backlog is Q(t1)=Q(t0)+A(t0,t1)−r(t0)·(h−δ)≦C·h, where A(t0,t1)≦C·h is the number of bits received between t0 and t1. At time t1, the domain sets a processing capacity r(t1) such that either r(t1)≧Q(t1)/(h−δ) if Q(t1)≦C·(h−δ), or r(t1)=C if Q(t1)>C·(h−δ).
The former case is trivial because it reproduces the conditions at time t0, only with a rate that is possibly different.
In the latter case, the queue backlog at the next useful time (t2) for setting the processing capacity is Q(t2)=Q(t1)+A(t1,t2)−C·(h−δ)≦2C·h−C·(h−δ)=C·(h+δ). At time t2, if Q(t2)≦C·(h−δ) the domain returns to the condition of time t0. Otherwise the processing capacity remains C, so that no state transition is triggered.
At this point there is no way for the queue length to grow any further beyond Qmax=C·(h+δ). If Q(t2)=C·h+ΔB, ΔB>0 and no more traffic arrives after t2, it takes up to two full operating intervals to clear the backlog Q(t2): the first operating interval takes the backlog down to Q(t3)=ΔB and the second interval guarantees that the backlog is cleared by t4=t3+h. The earliest time the last bit cleared by t4 may have arrived so that ΔB>0 is tε=t2−δ+ε1ε→0, so that d=t4−tε<2h+δ.
The scenario at time t2 in the proof of Theorem 1 leads to the following formulation of a backlog clearing property that provides a tighter delay bound for given values of h and δ:
Strong Backlog Clearing Property—The processing capacity set at the beginning t0 of the operating interval is chosen from the set of available capacities that are sufficient to clear the current queue backlog Q(t0)>0 by the closest possible end of the operating interval (t1=t0+h) and are higher than the current capacity r(t0−): r(t0)ε{rk:skεSrk≧Q(t0)/(h−δ)rk≧r(t0−)}.
If no such capacity is available, the policy chooses the full capacity of the rate adaptation domain (r(t0)=C).
A state-setting policy that holds the strong backlog clearing property is referred to as a strong backlog clearing policy.
The following theorem defines the delay bound for a fluid rate-adaptation domain with strong backlog clearing policy.
Theorem 2—In a fluid rate-adaptation domain with strong backlog clearing policy the delay constraint d is bounded as follows:
d≦d
max
=h+δ. (9)
Proof Consider the same sequence of events as in the proof of Theorem 1, up to time when a backlog Q(t2)=C·h+ΔB,ΔB>0 has accumulated in the queue. As opposed to the case with weak backlog clearing policy, the processing capacity of the rate-adaptation domain cannot be reduced again until the queue backlog is completely cleared. As a consequence r(t2)=C and no additional backlog is allowed to accumulate in the queue. The maximum queue backlog remains Qmax=C·(h+δ) and dmax=h+δ is the maximum time it takes to forward the last bit in the queue after it arrives.
The following theorem defines the maximum queue length in a packetized rate-adaptation domain with strong backlog clearing policy.
Theorem 3—In a packetized rate-adaptation domain with strong backlog clearing policy, the queue size Q(t) is bounded as follows:
where Lmax is the maximum size of a packet in the rate adaptation domain and rmin is the minimum non-null rate in the set of available rates (rmin=mins
Proof: Without loss of generality, let t0 be the start time of an operating interval where the state-setting policy chooses a processing capacity r(t0) such that r(t0)≧Q(t0)/(h−δ). At time t1, when the packetized rate-adaptation domain has the next chance to set the processing capacity at the end of a packet transmission (t0+h≦t1<t0+h+Lmax/r(t0)), the queue backlog is Q(t1)=Q(t0)+A(t0,t1)−r(t0)·(t1−t0−δ), with A(t0,t1)≦C·(t1−t0). Therefore:
Q(t1)≦(C−r(t0))·(t1−t0)+Q(t0)+r(t0)·(h−h+δ)
∴Q(t1)≦(C−r(t0))·(h+Lmax/r(t0))+r(t0)·h
∴Q(t1)≦C·h+Lmax·(C/rmin−1)
Since Q(t1)>C·(h−δ), at time t1 the state-setting policy chooses r(t1)=C and during the subsequent state transition the rate-adaptation domain accumulates up to C·δ more bits. At time t1+δ, when Q(t1)≦C·h+Lmax·(C/rmin−1), operation at the full capacity starts preventing the queue length from growing any further.
As shown in the proof of Theorem 2, in a rate-adaptation domain with strong backlog clearing policy the maximum delay is the time needed to clear the maximum backlog at full capacity. The following result immediately derives from Theorem 3:
Lemma 1: In a packetized rate-adaptation domain with strong backlog clearing policy the delay constraint d is bounded as follows:
The identification of the selection criterion for the operating state of the rate-adaptation domain completes the specification of the state-setting policy. To retain the result of Lemma 1 on the relationship between the maximum added delay dmax(P) and the minimum hold time h the selection criterion must satisfy the strong backlog clearing property.
The simplest strong backlog clearing policy that also minimizes energy consumption is one that chooses capacity
when Q(t0)>0 and capacity
at any time te such that Q(te)=0 (i.e., chooses the processing capacity immediately lower than the current one as soon as the queue gets empty, whether or not the duration of the current operating interval has passed the h mark). It should be noted that in both state-setting events the policy may find no capacity that satisfies the corresponding condition. In that case the policy retains the current capacity without triggering a state transition. It should also be noted that in a rate-adaptation scheme that combines rate scaling with sleep-state exploitation the set S of available operating states is formed by the union of the sleep state with the subset of states in the underlying rate-scaling scheme such that the associated processing capacities are not lower then the optimal threshold capacity rT,opt:
S={sS}∪{skεS′:rk≧rT,opt} where S′ is the set of operating states in the underlying rate-scaling scheme and rs=0 is the capacity associated with the sleep state. While the policy only allows single-step capacity decrements when the queue becomes empty to avoid wide state oscillations along the convex power-rate curve, the same policy imposes no restrictions on state transitions that cause capacity increments: at time t0, when Q(t0)>0 and a new operating interval can start because at least h time has elapsed since the beginning of the current operating interval, the policy chooses the new processing capacity out of the full subset of available capacities that are not lower than the current one. The name for this state-setting policy is the simple strong backlog clearing (SSBC) policy.
To improve statistically the delay performance of the rate-adaptation domain, a predictor Â(t) for the traffic arrival rate can be included in the state-setting policy. The simplest predictor uses the arrival rate of an operating interval as the arrival rate estimate for the next interval: Â(tn)=[A(tn+1)−A(tn)]/(tn+1−tn), where tn and tn+1 are the start and end times of the nth operating interval. While the combination of the current queue length with an estimate of the arrivals for the next operating interval does improve the average delay performance of the rate adaptation domain, it cannot reduce the worst-case added delay of eq. (11). This is because a predictor, however accurate, has no actual control over future arrivals. Heretoafter are described the effects of including the simplest predictor in the state-setting decision at time t0 such that Q(t0)>0
and in the state-setting decision at time te such that Q(te)=0
The name for this state-setting policy is the predictive strong backlog clearing (PSBC) policy.
A slightly different approach to the combination of current state (the queue length Q(t)) and future arrivals (the predictor Â(t)) is derived from a rate-scaling method of the prior art [Nedevschi]. Instead of being projected over the entire operating interval to follow, the predictor for future arrivals is only applied to the time needed to complete the next transition, so that the new processing capacity is set based on the expected backlog at the time when the domain can start processing packets again. At time t0, such that Q(t0)>0 this partially predictive strong backlog clearing (PPSBC) policy sets the processing capacity r(t0) for the next operating interval as follows:
At time te such that Q(te)=0 the PPSBC policy sets the processing capacity r(te) for the next operating interval as follows:
The discussion to this point has covered state-setting policies that hold the strong backlog clearing property. However, the experimental results presented in the following section also account for the performance of weak backlog clearing policies and of a non-backlog clearing policy.
Experimental Results
The energy-saving and delay performance of rate-adaptation schemes that incorporate the state-setting policies heretofore defined (SSBC, PSBC, and PPSBC) were studied by simulation of a 10 Gbps single-queue rate-adaptation domain fed by 10 independent Pareto sources, each capable of supplying up to 1 Gbps traffic. The sources generate 1000 Byte packets and have average burst time and average idle time of 50 ms. The packet-level simulation experiments were run using newly designed Queue subclasses for the ns2 simulation platform. In every experiment data were collected for 100 seconds of system time after expiration of a 5 second warm-up period.
The power-rate curve of the domain was derived by interpolation and normalization of the six operating states of the Intel® Pentium® M Processor as documented in the March 2004 Whitepaper, “Enhanced Intel® SpeedStep® Technology for the Intel® Pentium® M Processor” (which may be found at ftp://download.intel.com/design/network/papers/30117401.pdf):
where r0=1.625 Gbps, P0=0.232 W, and A=0.001308 W Gbps−3. The operating states of Table 1 were assumed to be available to the state-setting policy.
It is assumed that the sleep power PS is a fraction of the base active power P0 (PS=γ·P0, 0<γ<1) and that the idle power is a fraction of the active power: Pki=β·Pka∀k, 0<β<1). Per eq. (7), the optimal threshold capacity is a function of the sleep power PS and therefore of the ratio γ between sleep power and base active power. With the power-rate curve of eq. (12), a relatively low value of the ratio of (γ=0.125) yields r(tT,opt)=5.21 Gbps, whereas a relatively high value (γ=0.5) yields r(tT,opt)=4.51 Gbps. As a compromise between the two values, the minimum non-null capacity available in the rate-adaptation domain was set to 5 Gbps:
S={sS}∪{skεS′:rk≧5 Gbps}={sS,s5,s6,s7,s8,s9,s10}
The transition time δ is set at 1 ms knowing that it is well within the capabilities of existing technologies but still a cause of delays that may affect the user perception of end-to-end applications. In the evaluation of rate-scaling schemes that do not include sleep-state exploitation, the minimum non-null capacity available is set at 2 Gbps (Table 1 shows that there is no energy benefit in including s1 in the set of available operating states).
Referring to
To choose between the SSBC and PPSBC policies, their relative delay performances are illustrated in
Next is depicted the best minimum capacity to be made available in a rate-adaptation scheme that combines rate scaling with sleep-state exploitation. Referring to
Finally, referring to
The curves of
Summarizing, rate-adaptation schemes for improving the energy efficiency of packet networks have been addressed resulting in two contributions. First, it has been shown that by proper abstraction of network data paths it is possible to create the conditions for the incremental introduction of rate-adaptive devices in practical networks. Second, there has been defined a class of state-setting policies for rate adaptation schemes that enforce tight deterministic bounds on the extra delay that the schemes may cause to network traffic at every node where they are deployed. Within that class, there have been disclosed state-setting policies that effectively combine the best properties of sleep-state exploitation and rate-scaling schemes, demonstrating that the implementation of rate adaptation in practical network equipment can be improved over the rate adaptation methods existent in the prior art.
The present invention can be embodied in the form of methods and apparatuses for practicing those methods. The present invention can also be embodied in the form of program code embodied in tangible media, such as magnetic recording media, optical recording media, solid state memory, floppy diskettes, CD-ROMs, hard drives, or any other machine-readable storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the invention. The present invention can also be embodied in the form of program code, for example, whether stored in a storage medium or loaded into and/or executed by a machine, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the invention. When implemented on a general-purpose processor, the program code segments combine with the processor to provide a unique device that operates analogously to specific logic circuits.
It will be further understood that various changes in the details, materials, and arrangements of the parts which have been described and illustrated in order to explain the nature of this invention may be made by those skilled in the art without departing from the scope of the invention as expressed in the following claims.
It should be understood that the steps of the exemplary methods set forth herein are not necessarily required to be performed in the order described, and the order of the steps of such methods should be understood to be merely exemplary. Likewise, additional steps may be included in such methods, and certain steps may be omitted or combined, in methods consistent with various embodiments of the present invention.
Although the elements in the following method claims, if any, are recited in a particular sequence with corresponding labeling, unless the claim recitations otherwise imply a particular sequence for implementing some or all of those elements, those elements are not necessarily intended to be limited to being implemented in that particular sequence.
Reference herein to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment can be included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment, nor are separate or alternative embodiments necessarily mutually exclusive of other embodiments. The same applies to the term “implementation.” Numerous modifications, variations and adaptations may be made to the embodiment of the invention described above without departing from the scope of the invention, which is defined in the claims.