The present invention relates generally to Telecommunication systems and more particularly to wired networking systems utilizing telephone wiring, coaxial cables, or power lines as physical media.
The following presents a simplified summary in order to provide a basic understanding of one or more aspects of the invention. This summary is not an extensive overview of the invention, and is neither intended to identify key or critical elements of the invention, nor to delineate the scope thereof. Rather, the primary purpose of the summary is to present some concepts of the invention in a simplified form as a prelude to the more detailed description that is presented later.
One embodiment relates to a network arrangement, comprising at least one master node and plurality of slave nodes coupled to the master node. The master node and slave nodes communicate over a medium (e.g., telephone wiring, coaxial cables, or power lines) with time-variant channel characteristics. The master node includes a processing block to receive inputs from the plurality of slave nodes. The inputs are used by the processing block to generate an optimized Time-Division Multiple Access (TDMA) schedule which is broadcast to the plurality of slave nodes. Other methods and systems are also disclosed.
The following description and annexed drawings set forth in detail certain illustrative aspects and implementations of the invention. These are indicative of only a few of the various ways in which the principles of the invention may be employed.
a illustrates some embodiments of a communication network comprising three nodes.
b illustrates some embodiments of six unidirectional links formed in a communication network comprising three nodes.
One or more implementations of the present invention are now described with reference to the attached drawings, wherein like reference numerals are used to refer to like elements throughout, and wherein the various structures are not necessarily drawn to scale. In the following description, for purposes of explanation, numerous specific details are set forth in order to facilitate understanding. It may be evident, however, to one of ordinary skill in the art, that one or more aspects described herein may be practiced with a lesser degree of these specific details. In other instances, known structures and devices are shown in block diagram form to facilitate understanding.
a illustrates some embodiments of a communication network 100a comprising three nodes: a network access node 102a, a first network communication node 104a, and a second network communication node 106a, which are coupled through a shared physical medium 108a. For bidirectional communication between three nodes the shared physical medium 108a must support at least six unidirectional links, as illustrated in
Many multi-user communication systems operate over physical media with time-variant channel characteristics. One example of this is powerline communications systems that operate over AC wiring, which are subject to noise generated by devices coupled to the AC wiring. This noise can sometimes be predicted if it is generated by a process that is synchronized with an AC cycle of the wiring. In such systems, know as synchronous channel or SyncCh, the noise parameters will vary with a frequency that is an integer multiple of a basic 50 Hz or 60 Hz AC cycle, or MAC cycle.
Multi-user communication systems must insure that only one device is using a physical medium at a given time to avoid data collisions. One way to achieve this is to define a Time-Division Multiple Access (TDMA) schedule that all of the nodes in a network must follow. Choosing an optimal schedule can be a non-trivial problem for networks comprising a large number of nodes, and may be further complicated by requiring that a certain node or set of nodes meet a minimum network capacity, or Quality of Service (QoS).
Accordingly, the present disclosure relates to a method and network arrangement in a communication system that can achieve an optimal (or near optimal) capacity allocation for multiple links with time-varying capacities. A TDMA schedule is formulated in terms of matrices and vectors that describe various input parameters of the network arrangement. A number of algorithms are then provided which can define the TDMA schedule in various ways. Optimal algorithms are provided which use linear programming techniques to find a TDMA schedule that is optimal for one or more parameters of the network arrangement. Heuristic algorithms are also provided. These algorithms may be solved and implemented in hardware though the use of a central node that broadcasts a TDMA schedule that all of the other nodes in a network must follow.
A TDMA schedule may be formulated for a network comprising L unidirectional links, with a MAC cycle T that is divided into K BAT regions. The duration of each BAT region j is tj, where jε[1, . . . K]. The capacity available for link i during time t1 is βij, where iε[1, . . . L]. The fraction of region tj allocated to link i, or time-slot, is given by αij such that αij≧0. If a required capacity for link i is assumed as δi, then a total capacity of all time-slots allocated to link i is γi, which may be computed in as follows:
A restriction that no more than 100% of the fraction of region tj allocated to link i (with i in 1, . . . L) results in the additional restriction that Σiε[1, . . . L] αij≦1. This problem may be formulated in vector form as the following:
Find a schedule matrix:
such that an allocation condition is met:
and subject to constraints α≧0 and ILT·α≦IKT. Here α o β represents the element-by-element product of α and β, and IL represents an L-dimensional all-ones column vector.
In principle there may be an infinite number of unique allocations a that satisfy the allocation condition. The allocation condition may be optimized for one or more parameters of the network. To maximize the aggregate network capacity (the total network throughput), one may maximize Σi=1L γi with no further constraints. To maximize the aggregate network capacity with the constraint that all links achieve equal capacity, maximize Σi=1L γi with the requirement that (γ1=γ2= . . . =γL). To maximize the amount of unallocated time slots while guaranteeing that γ≧δ, minimize Σi=1L Σj=1K αijtj with the following constraints:
t≧δ (provides L inequalities), α≧0 (provides L×K inequalities), and Σiε[1, . . . L] αij≦1 (provides K inequalities). The aforementioned maximizations comprise Optimal Algorithms that may be solved using Linear Programming.
Linear Programming is a set techniques that are well-known to one of skill in the art that may be employed to solve a standard minimization problem:
y=[y
1
,y
2
, . . . ,y
m]T
that minimizes:
y
T
b=y
1
b
1
+y
2
b
2
+ . . . +y
m
b
m
subject to the constraints yTA≧c, and y≧0. If an optimal scheduling problem can be represented as a standard minimization problem, then Linear Programming methods may be used.
To express an optimal scheduling problem as a standard minimization problem for arbitrary values of L and K, define an auxiliary variable:
Then, matrices A, b, and c are given by:
The relationship between a and y is given by:
such that the an allocation condition
may be represented as a standard minimization problem, to minimize yTb subject to yTA≧c and y≧0.
The simplex method or the interior point method are examples of Optimal Algorithms that utilize Linear Programming techniques to solve the optimal scheduling problem when represented as a standard minimization problem. Heuristic Algorithms may also provide a solution to the scheduling problem, though these are not guaranteed to be optimal.
At step 302 initialize recursive variables: αij:=0 (fraction of region j allocated to link i=algorithm output), γi:=0 (Total capacity of all time slots allocated to link i=Σj αijβijtj), εj:=0 (the fraction of the capacity allocated to region j=Σjαij), p:=1 (the lowest link with γi<δi), and q:=1 (the time region with εj<1).
At step 304 a first exit condition is checked. If p>L, then the algorithm has found a feasible schedule.
At step 306, if the first exit condition is met (YES at 304), then return “CORRECT” and exit the algorithm.
At step 308 a first error condition is checked. If q>K, then the algorithm has not found a feasible schedule.
At step 310, if the first error condition is met (YES at 308), then return “ERROR” and exit the algorithm.
At step 312 calculate a temporal variable
At step 314 determine if fractional capacity has been exceeded. α*+εp<1?
At step 316, if the fractional capacity has not been exceeded (YES at 314), then set recursive variables: αpq:=α*,
εq:=εq+αpq, and p:=p+1; and return to step 304.
At step 318, if the fractional capacity has been exceeded (NO at 314), then set recursive variables: αpq:=1−εq,
εq:=εq+αpq=1, and q:=q+1; and return to step 304.
The nave left-to-right allocation method 300 completes (with “CORRECT” or “ERROR” results) in no more than L+K+1 steps, wherein each step calculates a new value of a*, plus one extra step for either step 316 or step 318. If the nave left-to-right allocation method 300 returns “ERROR,” then it has not been able to satisfy all of the constraints. In particular, it has not been able to insure that all γi≧δi.
At step 402 initialize recursive variables: αij:=0 (algorithm output and intermediate allocation steps), γi:=0 (the capacity allocated to link i, equal to εj αijβijtj), εj:=0 (the fraction of the capacity allocated to region j, equal to εj αij), L:=(1, 2, . . . L) (the set of all links for which γi<δi), K:=(1, 2, . . . K) (the set of regions for which εj<1), and q:=1 (the lowest time region with εj<1).
At step 404 a first exit condition is checked. If L=φ, then the algorithm has found a feasible schedule.
At step 406, if the first exit condition is met (YES at 404), then return “CORRECT” and exit the algorithm.
At step 408, if the first exit condition is not met (NO at 404), begin looping through a E L.
At step 410 create local copies of all recursive variables: Ka:=K, εa:=ε, γa:=γ, αa:=α, {circumflex over (q)}:=q, and ga:=0 for each aεL.
At step 412 a first error condition is checked. If Ka=φ, then the algorithm has not found a feasible schedule.
At step 414, if the first error condition is met (YES at 410), then return “ERROR” and exit the algorithm.
At step 416, if the first error condition is not met (NO at 410), calculate a local temporal variable
At step 418 determine if local fractional capacity has been exceeded. ε{circumflex over (q)}a+α*a<1?
At step 420, if the local fractional capacity has not been exceeded (YES at 418), then set recursive variables: αa{circumflex over (q)}a:=α*a, ε{circumflex over (q)}a:=ε{circumflex over (q)}a+αa{circumflex over (q)}a, ga:=ga+αa{circumflex over (q)}a t{circumflex over (q)}, γa:=δa, and qa:={circumflex over (q)}.
At step 422, if the fractional capacity has been exceeded (NO at 416), then set recursive variables: αa{circumflex over (q)}a:=1−ε{circumflex over (q)},
ε{circumflex over (q)}:=1, q:=q+1, ga:=ga+αa{circumflex over (q)}a t{circumflex over (q)}, Ka:=Ka−{{circumflex over (q)}}, {circumflex over (q)}:={circumflex over (q)}+1; and return to step 410.
At step 424, determine whether to continue looping through aεL (i.e., do any aεL remain that have not been looped through?).
At step 426 choose i such that gi≦ga, ∀aεL.
At step 428 copy the i-th copy local copy into the main set of variables: K:=Ki, ε:=εi, γ:=γi, α:=αi, and q:=qa.
At step 430 remove i from L: L:=L−{i}; and return to step 404.
The optimized left-to-right allocation method 400 completes (with “CORRECT” or “ERROR” results). Calculating an upper-bound on the number of iterations for the optimized left-to-right allocation method 400 is non-trivial, but can loosely be estimated as (L·K)·(K+1)K/2 steps.
At step 502 initialize recursive variables: αij:=0 (algorithm output and intermediate allocation steps), γi:=0 (the capacity allocated to link i, equal to Σj αijβijtj), εj:=0 (the fraction of the capacity allocated to region j, equal to Σj αij), L:=(1, 2, . . . L), and K:=(1, 2, . . . K).
At step 504 a first exit condition is checked. If L=φ, then the algorithm has found a feasible schedule.
At step 506, if the first exit condition is met (YES at 504), then return “CORRECT” and exit the algorithm.
At step 508 a first error condition is checked. If K=φ, then the algorithm has not found a feasible schedule.
At step 510, if the first error condition is met (YES at 508), then return “ERROR” and exit the algorithm.
At step 512 choose aεL and bεK such that βab≧βij ∀iεL and ∀iεK (the maximum value of βij).
At step 514 calculate a temporal variable
At step 516 determine if fractional capacity has been exceeded. α*+εb<1?
At step 518, if the fractional capacity has not been exceeded (YES at 516), then set recursive variables: αab:=α*,
εb:=εb+αab, and L:=L−{a}; and return to step 504.
At step 520, if the fractional capacity has been exceeded (NO at 516), then set recursive variables: αab:=1−εb,
εb:=εb+αab=1, and K:=K−{b}; and return to step 504.
The βij maximization method 500 may not always find a feasible solution, even if one exists. One way to enhance the method 500 is to direct the algorithm to look beyond allocating a time slot to see if a solution is still feasible after the allocation.
At step 602 initialize recursive variables: αij:=0 (algorithm output and intermediate allocation steps), γi:=0 (the capacity allocated to link i, equal to εj αijβijtj), εj:=0 (the fraction of the capacity allocated to region j, equal to Σj αij), L:=(1, 2, . . . L), and K:=(1, 2, . . . K).
At step 604 a first exit condition is checked. If L=φ, then the algorithm has found a feasible schedule.
At step 606, if the first exit condition is met (YES at 604), then return “CORRECT” and exit the algorithm.
At step 608, if the first exit condition is not met (NO at 604), begin looping through a E L.
At step 610 a first error condition is checked. If K=φ, then the algorithm has not found a feasible schedule.
At step 612, if the first error condition is met (YES at 608), then return “ERROR” and exit the algorithm.
At step 614 create local copies of all recursive variables: La:=L Ka:=K, εa:=ε, γa:=γ, and αa:=α for each aεL.
At step 616 choose b E K such that βab≧βaj ∀jεK (the maximum value of βaj).
At step 618 calculate a temporal variable
At step 620 determine if fractional capacity has been exceeded. α*+εba<1?
At step 622, if the fractional capacity has not been exceeded (YES at 618), then set recursive variables: αaba:=α*,
εba:=εba+αaba, and La:=La−{b}.
At step 624, if the fractional capacity has been exceeded (NO at 516), then set recursive variables: αaba:=1−εba,
εba:=εba+αaba=1, and Ka:=Ka−{b}.
At step 626, compute the average capacity of each link m εLa:
At step 628, compute the average time-slot required to achieve capacity constraint in each link mεLa:
At step 630, compute the estimated aggregate time-slot length for all
At step 632, compute total time allocation: za:=αabatb+ha.
At step 634, choose c such that zc≦za ∀aεL.
At step 636, copy the local variables to main variables: L:=Lc, K:=Kc, ε:=εc, γ:=γc, and α:=αc; and return to step 604.
The embodiments of methods 300-600 assume that the when a time-slot of duration αijtj is allocated to link i, the complete time-slot is used to transmit data. In reality, all multiple-access communications systems require nodes to transmit some overhead signal (e.g., preambles, headers, acknowledgements, etc.), or leave the channel idle for some time (e.g., inter-frame gaps, etc.). For the embodiments of methods 300-600, the overhead can be modeled with a modification of some parameters. For transmission of p bits of data in a channel with a capacity β, a time required is defined as:
where tt is the total time, tp is the transmission time (dependent upon p), and is the overhead time (not dependent upon p).
Therefore, an equation for calculating αij for link i in region j will be given by:
where each region has a minimum size (tj≧η). Additionally, a minimum allocation size for any αij can never be less than
This modification for an accurate area overhead estimation may be applied to the embodiments of methods 300-600
These families of Optimal Algorithms and Heuristic Algorithms provide different trade-offs in terms of computational complexity and solution performance. An implementation can choose between these two classes of algorithms depending upon environmental constraints. For example: if computational resources are limited, or a solution has to be found in a limited amount of time, an implementation may choose a fast algorithm to find a feasible albeit non-optimal solution.
The MAP generation block 720 is configured to build a MAP message 726 and broadcast it to the plurality of slave nodes 704. The MAP message 726 comprises information about the length of a MAC cycle (T) and a schedule of time-slots allocated to one or more nodes from the set comprising the master node 702 and slave nodes 704.
Each pair of channel estimation blocks formed from a set comprising the first channel estimation block 714 and respective second channel estimation blocks 722 are configured to communicate a first protocol 728 that results in a bit-loading table for communication between each pair of nodes formed from a set comprising the master node 702 and the plurality of slave nodes 704. Bit loading tables may be different for different parts of the MAP cycle. Whenever a pair of nodes updates the a bit-loading table, they inform the master node 702 by sending an updated first protocol 728 that includes which regions of the MAC cycle are impacted by the update.
Additionally, the first channel estimation 714 block is configured to communicate a second protocol 730 to the scheduler block 718, comprising a vector t comprising K elements corresponding to the length of K time regions within the MAC cycle, and a matrix β comprising L×K elements corresponding to a bit rate for L links between the set of N nodes within K time regions.
A respective second bandwidth reservation block 724 is configured to communicate a third protocol 732 to the first bandwidth reservation block 716, wherein the third protocol 732 comprises a request for a predetermined amount of bandwidth for a connection formed between a pair of nodes from a set of N nodes comprising the at least one master node and the plurality of slave nodes. The third protocol 732 also includes an option for the first bandwidth reservation block 716 to accept or reject the request.
Additionally, the first bandwidth reservation block 716 is configured to periodically communicate a vector δ 734 to the scheduler block 718, wherein the vector δ 734 comprises L elements corresponding to a requested bandwidth for each of the L links between each pair of nodes from the set of N nodes.
The scheduler block 718 takes the inputs t, β, and δ and uses an algorithm from families of Optimal Algorithms and Heuristic Algorithms previously described to calculate an optimal schedule α 736 comprising an L×K matrix in which each element αij represents an amount of channel time allocated to link i during time region j. The optimal schedule α 736 is sent to the MAP generation block 720.
The MAP generation block 720 receives the optimal schedule α 736 from the scheduler block 718 and builds the MAP message 726 that implements a time-slot allocation as described by the optimal schedule α 736 matrix. The MAP message 726 is then broadcast to the plurality of slave nodes 704, which will then follow the time-slot allocation.
The families of Optimal Algorithms and Heuristic Algorithms previously described may also be used in scenarios where multiple G.hn networks share the same physical medium. In general, a cooperation may be achieved either through centralized methods which rely on a single device (e.g., a “Global Master” that is responsible for scheduling time-slots for each domain), or distributed methods which different networks negotiate with each other.
After receiving tn, βn, and δn from each domain, the global master 806 computes values for tg, βg, and δg (g is an index for the global master 806). δg is a vector of Lg elements, where
tg is a vector with Kg elements, and βg is a Lg×Kg matrix, where Kg is the minimum number of time regions that insure that βijg is a constant. If BAT regions in different domains are exactly aligned with each other, then a best case value of Kg is given by:
K
g
=K
n
but if the BAT regions in different domains are mis-aligned, then a worst case value of Kg is given by:
In practice, Kg will be somewhere between the best and worst case values, because some BAT regions are aligned while others are not.
After computing values for tg, βg, and δg the global master 806 computes an allocation matrix αg using any of the algorithms from the families of Optimal Algorithms and Heuristic Algorithms previously described, and uses it to build domain-specific matrices αn (where n=1 . . . N), wherein a respective matrix αn is sent to the nth master node (e.g., one of 804a-804c) of the nth domain over one of a plurality of second communication channels, comprising 810a-810c. The nth master node uses an to construct a MAP message to be broadcast to the nth domain.
Thus, the above described embodiments are a method and network arrangement in a communication system that can achieve an optimal (or near optimal) capacity allocation for multiple links with time-varying capacities. Although the invention has been illustrated and described with respect to one or more implementations, alterations and/or modifications may be made to the illustrated examples without departing from the spirit and scope of the appended claims. For example, although certain embodiments of the invention have been described with respect to wired communication systems conforming to the G.hn standard, the invention is applicable to any wired communication system operating at full bandwidth capacity, or a wireless communication channel if channel conditions (signal-to-noise ratio) change in a periodic manner.
In addition, although various illustrated embodiments are illustrated as a hardware structure, the functionality and corresponding features of the present device can also be performed by appropriate software routines or a combination of hardware and software.
In particular regard to the various functions performed by the above described components or structures (assemblies, devices, circuits, systems, etc.), the terms (including a reference to a “means”) used to describe such components are intended to correspond, unless otherwise indicated, to any component or structure which performs the specified function of the described component (e.g., that is functionally equivalent), even though not structurally equivalent to the disclosed structure which performs the function in the herein illustrated exemplary implementations of the invention. In addition, while a particular feature of the invention may have been disclosed with respect to only one of several implementations, such feature may be combined with one or more other features of the other implementations as may be desired and advantageous for any given or particular application. Furthermore, to the extent that the terms “including”, “includes”, “having”, “has”, “with”, or variants thereof are used in either the detailed description and the claims, such terms are intended to be inclusive in a manner similar to the term “comprising”.
The present application claims priority to U.S. provisional application having Ser. No. U.S. 61/490,058, entitled “METHOD FOR OPTIMAL ALLOCATION OF RESOURCES IN A MULTI-USER NETWORK” and filed on May 26, 2011. This provisional application is incorporated by reference into this application in its entirety.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US12/39489 | 5/25/2012 | WO | 00 | 9/17/2014 |
Number | Date | Country | |
---|---|---|---|
61490058 | May 2011 | US |