The present invention is related generally to wireless networks, and in particular, to throughput optimization in wireless mesh networks.
A wireless mesh network is a mesh network implemented over a wireless network system such as wireless local area network (LAN). As such, wireless mesh networks have been considered as a practical wireless solution for providing community broadband internet access service and other wireless services. In some cases, nodes (e.g., transmitters) in wireless mesh networks may be equipped with multiple radios (e.g., multiple sources) and may be capable of transmitting over multiple orthogonal channels simultaneously.
For a traditional network, each intermediate node forwards received information to the next node (e.g., the next hop). This method of forwarding information is inefficient and occupies excessive capacity. While transmission may occur over multiple channels in such networks, the resources of wireless mesh networks are finite and it is difficult to efficiently utilize the wireless resources.
Therefore, there remains a need to improve throughput in wireless mesh networks.
The present invention is generally directed to designing a wireless mesh network. The wireless mesh network may have a plurality of transmission sources and a plurality of nodes connected by a plurality of links. The design of the network may include optimizing the throughput by determining an optimization problem describing the wireless mesh network. Associated constraints for the optimization problem may be determined as well as a network code for the wireless mesh network. The network code may be designed by solving the optimization problem using a column-based primal-dual optimization method.
These and other advantages of the invention will be apparent to those of ordinary skill in the art by reference to the following detailed description and the accompanying drawings.
The present invention is generally directed to a cross-layer method for designing and optimizing multi-radio/multi-channel wireless mesh networks with network coding to support multiple unicast applications. In designing a wireless mesh network, the network constraints are represented as an optimization problem. A column-generation-based primal-dual method is used to solve this optimization problem, taking into account the broadcasting features of wireless networks.
Optimization of the wireless mesh network may include designing a network code for transmission of information among the nodes of the network. Thus, optimization may allow full realization of the theoretical gains of network coding. For network-layer formation, a code construction scheme based on linear programming is used. In this way, the network coding plus media access control (MAC) gain may be significantly increased. Delay constraints are imposed on the network code construction so the possible impact of the extra decoding delay to the upper-layer Transmission Control Protocol/Internet Protocol (TCP/IP) performance may be reduced without changing the upper-layer protocols.
In practical application, the methods described herein may be used to design a wireless mesh network with multiple transmission sources (e.g., multiple antennas, base stations, etc.). The additional transmission sources may improve network throughput. Though this may increase complexity in decoding downstream (e.g., at receivers, nodes, drains, etc.), the network coding described herein may account for this complexity (e.g., by discounting solutions which introduce decoding delay) so that there is no significant increase in decoding time. Thus, the overall transmission speed of the wireless mesh network may be increased.
Network 100 may be a wireless mesh network as is known. In an alternative embodiment, network 100 may be a portion of a wireless network (e.g., a source and two drains of a wireless mesh network, etc.). In at least one embodiment of the present invention, network 100 may be designed and/or optimized according to the methods described herein. In some embodiments, network 100 may be a multi-radio, multi-channel wireless mesh network. To facilitate such a network, physical nodes 102-106 may communicate via one or more radios, network interface cards (NICs), and/or other communication devices (not shown) able to access multiple orthogonal channels simultaneously. As such, physical nodes 102-106 may communicate (e.g., transmit information) by multiple independent point-to-point transmissions (e.g., multiple unicast). These transmissions may be made over one or more links, which may be any means of connecting one location (e.g., node) to another for the purpose of transmitting and receiving data as is known.
In the exemplary network 100, physical node 102 is also referred to as Node 1 (e.g., N1) and/or Source 1 (e.g., s1) and is capable of simultaneous multiple unicast transmission to physical node 104, also referred to as Node 2 (e.g., N2) and/or Drain 1 (e.g., d1), via link 108, also referred to as Link 1 (e.g., ε1). Link 1 and other links described herein may be data links such as wireless communication channels or the like. Similarly, physical node 102 is capable of simultaneous multiple unicast transmission to physical node 106, also referred to as Node 3 (e.g., N3) and/or Drain 2 (e.g., d2), via link 110, also referred to as Link 2 (e.g., ε2). Of course, since network 100 may have any number of nodes and any number of corresponding links, nodes may be labeled N={1, 2, . . . , N} and links may be labeled ε={1, 2, . . . , L}. Accordingly, a directed graph G=(N, ε) may be used to model network 100.
Network 100, as a multi-radio network, may have a radio distribution vector
where Ii indicates the available radio number at the ith node. The topology of network 100 may be represented by an N×L indicator matrix D, such that
To illustrate the multiple unicast methods of transmission, connection, and communication, network 100 may be described as featuring pseudo-broadcasting. That is, network 100 may be thought of as having a virtual node 112. Virtual node 112 is not a node in the same way that physical nodes 102-106 are nodes; virtual node 112 does not have a physical structure, but is used herein to help model the network 100. For purposes of illustration and simplicity, virtual node 112 is described hereafter as if it is a physical node capable of sending and/or receiving transmissions in the same manner as physical nodes 102-106.
Virtual node 112 may have links to one or more physical nodes 102-106. In network 100, virtual node 112 may be referred to as Node 4 (e.g., N4) and may receive transmissions from physical node 102 over link 114 (e.g., ε3). Similarly, virtual node 112 may transmit information to physical nodes 104 and 106 over link 116 (e.g., ε4) and link 118 (e.g., ε5), respectively.
Network 200 may be a wireless mesh network as is known. In an alternative embodiment, network 200 may be a portion of a wireless network (e.g., multiple sources and multiple drains of a wireless mesh network, etc.). In at least one embodiment of the present invention, network 100 may be designed and/or optimized according to the methods described herein. In some embodiments, network 200 may be a multi-radio, multi-channel wireless mesh network or another type of broadcast network. To facilitate such a network, physical nodes 202-210 may communicate via one or more radios, network interface cards (NICs), and/or other communication devices (not shown) able to access multiple orthogonal channels simultaneously. As such, physical nodes 202-210 may communicate (e.g., transmit information) by multiple independent point-to-point transmissions (e.g., multiple unicast).
In the exemplary network 200, physical node 202 is also referred to as Node 1 (e.g., N1) and/or Source 1 (e.g., s1) and is capable of simultaneous multiple unicast transmission to intermediate (e.g., relay) physical node 206, also referred to as Node 3 (e.g., N3), via link 212, also referred to as Link 1 (e.g., ε1). Physical node 202 may also be configured to transmit to physical node 208, also referred to as Node 4 (e.g., N4) and/or Drain 2 (e.g., d2), via link 214, also referred to as Link 2 (e.g., ε2). Similarly, physical node 204 is capable of simultaneous multiple unicast transmission to intermediate physical node 206 via link 216, also referred to as Link 3 (e.g., ε3). Physical node 204 may also be configured to transmit to physical node 210, also referred to as Node 5 (e.g., N5) and/or Drain 1 (e.g., d1), via link 218, also referred to as Link 4 (e.g., ε4). Intermediate physical node may be configured to relay transmissions received from physical nodes 202 and 204 and/or transmit the same and/or other information to physical nodes 208 and 210 via links 220 (e.g., ε5) and 222 (e.g., ε6), respectively. As will be discussed further below, intermediate physical node 206 may be further configured to code and/or otherwise alter transmissions received from physical nodes 202 and 204 as appropriate.
Of course, since network 200 may have any number of nodes and any number of corresponding links, nodes may be labeled N={1, 2, . . . , N} and links may be labeled ε={1, 2, . . . , L}. Accordingly, a directed graph G=(N, ε) may be used to model network 200 as described above with respect to network 100.
Similar to network 100, network 200 may be thought of as having virtual nodes 224 (e.g., N6), 226 (e.g., N7), and 228 (e.g., N8). In a similar manner, physical node 202 may “transmit” to virtual node 224, which may, in turn, “transmit” to intermediate physical node 206 and/or physical node 208 over corresponding links. Physical node 204 may “transmit” to virtual node 226, which may, in turn, “transmit” to intermediate physical node 206 and/or physical node 210. These transmissions may also be over one or more corresponding links (e.g., data links). In the same way, intermediate physical node 206 may “transmit” information to physical nodes 208 and 210 by way of virtual node 228 and another set of corresponding links. One of skill in the art will recognize the particular means of communication between the physical nodes and the various network arrangements (e.g., butterfly, X, etc.) which may be employed. Accordingly, these issues will not be discussed in further detail herein.
Using the concept of virtual nodes as described in relation to
In step 304, an optimization problem for the throughput of the network is determined. The optimization problem may be a linear optimization problem describing the network being optimized. For example, as discussed above, multiple unicast transmissions may be made over network 100. Assuming there are S independent data sessions in the network, si is the source node (e.g., physical node 102) and di is the destination node (e.g., physical node 104 or 106) in the ith unicast session. Let R={RI}l=1T be the unicast data rates for T sessions. Denote fI as the aggregated flow rate over the Ith link (1≦l≦L′). Given RB FUR is the set containing all possible network flow rates that can support R. Let F(R) be the set containing all achievable rates c={cl}l=1L′ that the physical layer can support on links lεε′. C(I) is a function of the radio distribution vector (I) discussed above with respect to
maxU(R, f)s.t.fεF(R); ri≧0, ∀i; cεC(I); fl≦cl, ∀l where U(R, f) is a utility function. In some embodiments, the utility function is assumed to be concave.
In step 306, the constraints of the optimization problem determined in step 304 are determined. In the embodiment of the present invention shown in step 304, four constraints are used. These constraints are described in substeps 306a-d.
In substep 306a, the first constraint is determined. The first constraint fεF(R) enforces the dependence between the achievable rates R and the data flows f. In substep 306b, the second constraint is determined. The second constraint ri≧0, ∀i is that data rate (e.g., the data transmission rate, etc.). In substep 306c, the third constraint is determined. The third constraint cεC(I) indicates the relationship between the achievable link capacity c and radio allocation along with the resource allocation, scheduling, and data routing schemes. In substep 306d, the fourth constraint is determined. The fourth constraint fl≦cl, ∀l bounds the sum of the flow rate on each link by the link capacity. For the sake of notational simplicity, the index I in C(I) is omitted hereinafter.
When maximizing the total throughput is the design target (e.g., the resultant of the optimization formulation in method step 304), the network optimization problem max U(R, f)s.t.fεF(R); ri≧0, ∀i; cεC(I); fl≦cl, ∀l can be defined as the sum of the data rates in all sessions
Alternatively, in case fairness needs to be taken into account, the minimum end-to-end communication rates may be maximized by letting
which may be transformed to an equivalent linear formulation. That is, all users (e.g., sources, drains, nodes, etc.) should realize throughput gain (e.g., a higher rate) in the newly designed network. Accordingly, the rate at each node is taken into account instead of the sum rate of the system.
In step 308, the optimization problem is solved. In at least one embodiment of the invention, the optimization problem is solved using a primal-dual approach with column generation. Such an approach will be described in further detail below with respect to
In step 404, a set V′ containing several feasible link rates ck is generated. In at least one embodiment, there are K feasible link capacity vectors such that V′={ckεC}k=1K.
The set F(R) and C in
maxU(R, f)s.t.fεF(R); ri≧0, ∀i; cεC(I); fl≦cl, ∀l are determined by the specific network and physical-layer model (e.g., as in networks 100 and 200 of
Therefore, F(R) is also convex if data routing is assumed to be based on the multicommodity flow model or routing with linear network coding, as described below.
These two constraints are coupled only through the constraints fl≦cl, ∀l. Thus the optimization problem of method step 304 is a convex optimization problem. Since C is a convex hull, it is fully determined by its vertices. However, since joint resource allocation and scheduling are considered, C may be too complex to be described for a wireless network.
In step 406, the column-generation method is employed to solve the optimization problem. Instead of trying to exactly describe the convex hull C, another convex hull C′⊂C is employed to approximate C. The corresponding convex hull
is fully characterized by the set V′ of step 404. The original linear programming problem is then transformed to the following problem:
This is referred to as the restricted primal problem.
In step 408, the lower bound Ulower and the dual factors {λl}l=1L′ are determined. Since C′εC, the solution to the restricted primal problem provides a lower bound Ulower(I) for the optimization problem of method 300.
Similarly, in step 410, the upper bound Uuppper and a new vertex is determined. The upper bound of the optimization problem of method 300 may be determined by considering the dual of the original problem given by:
where the dual factors {λl}l=1L′ are the corresponding Lagrangian multipliers associated with the constraints about {ci} in the optimization problem of method 300.
In step 412, a check is performed to determine if the upper and lower bounds coincide. If they coincide, an optimal solution has been reached and the method ends at step 416. If the upper and lower bounds do not coincide, the method passes to step 414.
In steps 406 and 408, a lower bound and an upper bound of the original optimization are determined and the gap between the two bounds indicates the accuracy of the current solution. In case that the two bounds coincide, the optimal solution to the optimization problem of method 300 is obtained and the method ends at step 416.
If they are different, a new vertex is generated in step 414. The new vertex is generated by solving the problem
into the subset V′. The method 400 then returns control to step 406 and new upper and lower bounds are determined. The iteration will continue until the gap between the two bounds is smaller than a predetermined threshold n.
The optimal solution may be referred to as {r*, f}. If the optimization problem is a linear programming, the strong duality holds. That is, the optimal primal solution coincides with its dual solution, and
Accordingly, the upper bound may be efficiently solved using only
The network optimization described with respect to
Linear programming methods in wireless mesh networks may be used in network code construction according to embodiments of the present invention, especially in conjunction with the optimization in step 304 of method 300. For simplicity of presentation, the following discussion focuses on network coding over GF(2) (e.g., the Galois field (finite field) of two elements), where simple binary exclusive disjunction (e.g., XOR) operation is employed for network encoding and/or decoding.
For a given node nεN′, I(n) indicates the set of edges whose end node is n and O(n) indicates the set of edges whose start node is n. xli is the flow rate of the ith session over the Ith link and the aggregate load on the Ith link is given by
if no network coding is considered. The T unicast triples (si, di, Ri) for i=1, 2, . . . , T are feasible with routing if the following conditions hold:
where c={cl}l=1L′ are the achievable rates that the physical layer (e.g., in the OSI model) can support on links lεε′. However, when network coding is permitted, the actual aggregate load over a particular link I is no longer the sum of {xli}i=1T and
xli=fl≧0 should be modified to reflect the effect of network coding. What is more, in order to ensure that a network coding scheme is decodable, extra variables and conditions should be introduced based on the following poison-antidote concept.
Referring back to
Linear programming formulation for use in optimizaton of the throughput of the network may be based on a similar poison-antidote approach where the possible network coding+MAC gain depends upon the network topology and can be unbounded. That is, in order to ensure that a given set of rates (e.g., the candidate rates) can be supported by the network, a set of linear constraints are supplied.
A wireless network G′=(V′, ε′) is used with pseudo-broadcasting as described above in networks 100 and 200. A source set is defined as
where siεN. A network coding event is defined as
with nuεN′ being the node where binary XOR encoding is performed (e.g., at intermediate node 206 in network 200) and Su⊂S being the set of sources that are involved in this network coding event. For instance, in the exemplary network 200 of
Sufficient conditions (e.g., linear constraints) for the existence of a network coding solution involving routing, duplicating, pseudo-broadcasting, and bit-level XOR are considered. That is, when these constraints are satisfied, the solution corresponds to a valid network coding solution. In order to do so, a number of variables are introduced. Given a particular coding event u=(nu, Su), let iεSu. Also, pl(i,u), {ql(j→i, u)}jεS
and the conditions discussed hereinafter are satisfied, then the rate triples (si, di, Ri) for i=1, 2, . . . , T are feasible with U, and the corresponding p(.), q(.) and r(.) represent a particular network coding solution.
For all ukεU and i, jεSu
p
l(i,uk)=pl(j,uk) if lεΓO(nu
For all nεN′, ukεU, and i, jεSu
Let Tuk be the number of elements in Suk. At every link lεε′:
At every link I and iεS:
If the conditions specified in these constraints are satisfied, then the rate triples (si, di, Ri) for i=1, 2, . . . , T are feasible with network coding scheme U, and the only operations involved are duplication, routing, pseudo-broadcasting and bit-level XOR.
In networks in which network coding as described herein is performed, coding might introduce extra decoding delay which will affect the upper layer TCP/IP performance. For example, if binary coding over b1 and b2 is performed, the receiver (e.g., physical nodes 206, 208, 210, etc.) needs to have both the coded bit b1⊕b2 and b2 in order to recover b1. Should it take more time for b2 to reach the receiver than the coded bit b1⊕b2, the receiver needs to wait and cannot send back an acknowledgement (e.g., an ACK). This may increase the possibility of making the sender (e.g., nodes 202 and/or 204) reduce its transmission speed and hence might significantly decrease the network throughput. To prevent this delay constraints may be imposed on the network code construction formulation, so extra decoding delay may be eliminated and there is no need to modify the upper-layer TCP/IP protocol.
Network 200 may have a known delay over link I, TI. For coding event uk, the poisoning event j→i. The information from j will go through two virtual pipes, the first along the links with nonzero antidote-request participating in the coding event uk at node nuk and then along the links with nonzero poison and ending at some decoding node (e.g., a drain, an intermediate node, etc.). A second stream denotes the antidote flow and also ends at the same decoding node. The total delay for the antidote-request/poison stream is
and the total delay of the antidote j→I is
Accordingly, for all uk and iεSu
∀jεSuk, j≠i and the antidotes will arrive earlier than the poisoned information at the decoding node. Thus, if a network coding solution satisfies this constraint as well as those described above, there will be no additional decoding delay.
To characterize the convex region C in the optimization formulation of method step 304 for the network G′=(N′, ε′), communication models of multi-radio/multi-channel networks are used. Physical-layer and MAC-layer issues such as wireless resource allocation, power control, interference management, transmission scheduling and medium access schemes as are known may be used.
To account for interference and power control, Hl,k denotes the effective power loss between the transmitter (e.g., physical nodes 202, 204, etc.) of the Ith link and the receiver (e.g., physical nodes 206, 208, 210, etc.) of the kth link, where lεε′ and kεε. Assuming the value of Hl,k is determined by the βth power path-loss law: Hl,k=Gl,kdl,k−β, where dl,k is the distance between the start node of the Ith link and the end node of the kth link, β is the path-loss exponent, and Gl,k is a constant representing the radio propagation properties of the wireless environment and other physical-layer effects.
In the physical layer (e.g., in a transmission model), each radio in the network (e.g., networks 100, 200, etc.) may only transmit or receive at any moment in time. Accordingly, the medium access (e.g. MA) of a multi-radio/multi-channel network may be constrained (e.g., as a further constraint to the optimization problem of method 300) according to the following constraints:
Since each radio in the network (e.g., networks 100, 200, etc.) may only transmit or receive at any moment in time, a primary conflict constraint
is used. Additionally, the total number of channels accessed by a node is bounded by the number of radios in that node. That is, each node as described above may have multiple radios (e.g., transmitters, antennas, etc.) and a radio conflict constraint
where In is the available radio number at node n, is used.
Furthermore, a transmission over a link may be corrupted by other nodes in case that the signal-to-interference-plus-noise ratio (SINR) for the link is smaller than its target SINR, a situation which is called the transmission conflict. For lεε, in order to avoid a transmission conflict over the mth channel,
where jεε′ and ZI is a constant large enough to guarantee
In case that the Ith link is activated at the mth channel, vl,m=1
and
states that the SINR of the Ith link should be greater than the target SINR γl,mt. In case the link is not activated, vl,m=0 and
always holds.
In the links (e.g., data links, etc.) associated with a virtual node n′ (e.g., virtual node 224, 226, etc.), let l′εI(n′) and k′εO(n′). Also let I be the link (e.g., link 212, 214, 26, 218, etc.) which has the same start node as I′ and end node as k′. In this way,
∀k′εO(n′) where jεε′ and ZI,I′ is a constant large enough to guarantee
When vl′,mvk′,m=1, a virtual broadcasting path is established along link I, and
∀k′εO(n′) ensures that the SINR of this path is larger than the target SINR. The capacity of the activated virtual links associated with the virtual node n′ is determined by γl,mt. To avoid transmission conflict, the total power of a node should be less than Pn,max. That is,
The capacity of the Ith link is given by
and the convex set C (described above) is a convex hull of {c|c satisfies the constraints
Thus, the optimization problem described above in method 300 may be reformulated as
such that c satisfies the constraints
One or more wireless mesh networks, each having multiple transmission sources (e.g., multiple radios, transmitters, antennas, etc.) may be designed and/or implemented according to the methods described herein. That is, an optimization problem describing such a network may be formulated and solved. In other words, a network may be designed and the throughput of such a network may be optimized. In at least one embodiment, the optimization problem may be solved according to a primal-dual method with column generation. The designed network may be constructed and transmission may be sent using the network code designed for such a network.
According to some embodiments of the present invention, instructions of a program (e.g., controller software) may be read into memory 506, such as from a ROM device to a RAM device or from a LAN adapter to a RAM device. Execution of sequences of the instructions in the program may cause the controller 500 to perform one or more of the method steps described herein, such as those described above with respect to methods 300 and 400. In alternative embodiments, hard-wired circuitry or integrated circuits may be used in place of, or in combination with, software instructions for implementation of the processes of the present invention. Thus, embodiments of the present invention are not limited to any specific combination of hardware, firmware, and/or software. The memory 506 may store the software for the controller 500, which may be adapted to execute the software program and thereby operate in accordance with the present invention and particularly in accordance with the methods described in detail above. However, it would be understood by one of ordinary skill in the art that the invention as described herein could be implemented in many different ways using a wide range of programming techniques as well as general purpose hardware sub-systems or dedicated controllers.
Such programs may be stored in a compressed, uncompiled and/or encrypted format. The programs furthermore may include program elements that may be generally useful, such as an operating system, a database management system, and device drivers for allowing the controller to interface with computer peripheral devices, and other equipment/components. Appropriate general purpose program elements are known to those skilled in the art, and need not be described in detail herein.
The foregoing Detailed Description is to be understood as being in every respect illustrative and exemplary, but not restrictive, and the scope of the invention disclosed herein is not to be determined from the Detailed Description, but rather from the claims as interpreted according to the full breadth permitted by the patent laws. It is to be understood that the embodiments shown and described herein are only illustrative of the principles of the present invention and that various modifications may be implemented by those skilled in the art without departing from the scope and spirit of the invention. Those skilled in the art could implement various other feature combinations without departing from the scope and spirit of the invention.
This application claims the benefit of U.S. Provisional Application No. 60/868,418 filed on Dec. 4, 2006, which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
60868418 | Dec 2006 | US |