This invention generally relates to communication. More particularly, this invention relates to wireless communications.
Wireless communication systems are well known and in widespread use. Personal wireless communication devices such as cellular phones, personal digital assistants and notebook computers provide convenient communication abilities under a wide variety of circumstances. For example, many mobile stations are capable of data communications that allow an individual to access the Internet.
One difficulty associated with using mobile stations for internet communications is that the bandwidth and associated rates available for wireless communications typically lag behind those available from wired communication lines. For example, although the aggregated throughput of typical 3rd generation cellular networks can reach 4 Mbps, when it is shared by mobile users in a cell, the achievable throughput for each user is much smaller than that typically achievable on a wired network. In most circumstances, the wireless link will present a bottleneck as it is not able to process transmissions at the same rate as the wired link.
As the Internet continues to progress toward becoming a heterogeneous network (i.e., wired and wireless communication links), it becomes increasingly important to address the differences in capacity between wireless and wired communication links. Known congestion control techniques do not provide an adequate solution.
For example, known transport control protocol (TCP) congestion control is based on end-to-end additive increase multiplicative decrease adjustment. That approach does not expect any network-assisted feedback. TCP sources must estimate the available bandwidth from packet loss or retransmission timeout. While this scheme has served its purpose well for wired only Internet, it has problems when used in a heterogeneous network. For example, if the network consists of a high bandwidth wired segment and bottlenecked cellular segments, mismatch between the layer 4 congestion control protocol and the layer 2 scheduling mechanism causes serious queue accumulation at the base station that acts as the interface between the wired and wireless portions of the network. It is important to maintain queue stability in this situation. The media access (MAC) layer scheduler cannot take full advantage of multi-user diversity, which results in system performance degradation.
An exemplary method of controlling communications includes determining a total congestion window size for a router device. An allocation of at least a portion of the determined total congestion window size to allocated at least one mobile station that communicates with the router device over a wireless link is determined based on the determined total congestion window size. The determined allocation is then reported to a source of a communication intended for the at least one mobile station.
An exemplary router device includes a first communication portion configured to communicate with at least one device over a hardwired connection. A second communication portion is configured to communicate with at least one mobile station over a wireless link. A congestion controller is configured to control congestion at the router device. The congestion controller determines a total congestion window size for the router device and determines an allocation of at least a portion of the determined total congestion window size to at least one mobile station. The congestion controller reports the determined allocation over the hardwired connection to a source of a communication intended for the at least one mobile station.
The various features and advantages of the disclosed example will become apparent to those skilled in the art from the following detailed description. The drawings that accompany the detailed description can be briefly described as follows.
In one example, the router device comprises a base station transceiver capable of conducting wireless communications as used in known cellular networks. The illustrated router device 22 comprises a single base station edge router. The router device 22 in such an example effectively condenses the radio access network into a single network edge element that connects the wired and wireless segments of the example network. The illustrated router device 22 provides layer 3 routing capabilities. Such a flat wireless access network architecture differs from a hierarchical architecture in a known manner. Such an architecture is used in the illustrated example because it is useful for reducing end-to-end latencies and simplifies the complex network structure.
The router device 22 includes a congestion controller 50 that manages the rate of transmissions from the server devices 32-28 to accommodate different bandwidths of the hardwired connection 30 and the wireless links 40. The congestion controller 50 provides information to the server devices 32-38 to control a rate of transmission from the server devices 32-38 to the router device 22.
One example approach used by the illustrated congestion controller 50 is summarized in the flowchart 60 of
The server devices 32-38, which are the sources of transmissions for the various mobile stations 42-48, adjust their transmission rates responsive to the corresponding reported allocation. In this example, each server device receives a report indicating the window size allocation available to the intended recipient of its transmissions and controls its transmission rate accordingly. This approach minimizes congestion at the router device 22.
In one example, the total congestion window size is based on a measured buffer occupancy at the router device 22. Using a measured queue length or buffer occupancy level is useful for avoiding a more complicated input-output rate measurement, for example.
In one example, the total congestion window size is determined using the following equation
W(n)=W(n−1)+α·(B−Q(n−1))+β·(Q(n−1)−Q(n))
wherein W(n) is the total congestion window size, B is a targeted buffer occupancy level at the router device 22, Q(n) is the measured buffer occupancy level at a time n, Q(n−1) is the measured buffer occupancy level at a previous time n−1, and α and β are tuning parameters.
In one example, the targeted buffer occupancy level is equal to the average bandwidth-delay product of the wireless link and a Drop tail policy is used.
By recognizing a situation where the router device 22 is receiving transmissions on the wired connection 30 at a faster rate than the router device is sending transmissions on the wireless links 40 (i.e., there is congestion at the router device 22), the buffer occupancy can be controlled to maintain stability. In the above equation, whenever the measured occupancy Q is higher than it was previously (i.e., Q(n)>Q(n−1)), the last term becomes negative, which serves to reduce the total congestion window size.
Choosing the tuning parameters allows for ensuring system stability. For example, choosing the tuning parameters to ensure that the poles of the transfer function locate in the left side of the complex s-plane where the transfer function is
where P0=(1−α·(B+Haw·T))/α
P
1=1+P0, P2=P0(β−1)
P
3
=P
0(α−β), P4=(α−2β+2)T2
P
3=4(1−α+β)T, P4=4α
and Have is the average aggregate TCP throughput of the router device 22. One example stable system includes the tuning parameters satisfying the following
β≧1, 2(β−1)≦α≦β+1
An update rate for updating the total congestion window size in one example is determined based on an average round trip time for TCP packets on the wireless links between the router device 22 and the mobile stations 42-48. For example, the update interval is equal to the difference in time between the times n and n−1 above.
Once the total congestion window size is determined, the congestion controller 50 determines how to allocate that resource among the mobile stations 42-48. One example allocates at least a portion of the available window resource to at least one of the mobile stations based on a quality of the wireless link 40 between the router device 22 and the corresponding mobile station. Each mobile station is allocated an allocation wi(n) (i=1,2, . . . N) wherein n is the update interval and N is the number of mobile stations actively communicating with the router device 22. In one example, in the MAC layer scheduler uses a proportional fair approach to provide a tradeoff between aggregated throughput efficiency and system fairness. One example includes congestion window allocation in the TCP layer following the proportional fair criterion to coordinate with the MAC layer scheduler. The goal in one example is to have data injected from the higher (TCP) layer into the network at a rate that matches the transmission rate of the MAC layer assigned to the corresponding flow. One way of achieving this goal is to maximize the utility function U(w) of the proportional fair allocation.
For example, the utility function is described by the equation
Maximizing U(w) in one example includes allocating the total congestion window according to
w
f(n)=[μ−τ·
wherein [X]† □max(0,x), τ is an averaging factor, Ri(n) is the moving average of TCP packet throughput of user i measured at the update interval n, Ti(n−1) is the average TCP packet wireless round trip delay of slot n−1 and μ is the water filling level of a water filling allocation approach.
The maximization target during slot n is
Using moving average throughput calculation yields
wherein tc is the time constant of the averaging window and ri(n)=wi(n)/Ti(n) is the TCP packet throughput for slot n. Approximating Ti(n) with Ti(n−1), the maximization problem above can be written as
Using the Lagrangian, we have
According to the Karush-Kuhn-Tucker condition, the necessary condition for optimality is
λf≧0,λfwi(n)=0
1/(τ·
τ=tc−1
Solving for the water filling level μ yields
The individual window allocations are therefore described by
w
i(n)=1/μ−96 ·
In this example, the allocations for the mobile stations are a function of the average packet throughput Ri(n) on the wireless link during the interval n and the average packet round trip delay Ti(n−1) on the wireless link during the previous update interval and the water filling level μ.
In this example, a water filling allocation technique is used to make the individual mobile station allocations. In this example, τRi(n)·Ti(n−1) corresponds to the ground level, the total congestion window W(n) corresponds to the amount of water that is available and the optimal user congestion window size corresponds to the depth of water above the ground.
Once the allocations are determined, the controller 50 reports these to the corresponding server devices. The allocation report from the controller 50 is intended to match the transmission rate of the server devices 32-38 to the achievable rate the router device MAC scheduler provides the corresponding mobile stations 42-48 according to the determined allocations. In one example, the report comprises and indication in an advertised window field in the header of a TCP acknowledgment segment sent to the server devices 32-38.
The disclosed example facilitates maintaining stability at an edge router device that interfaces between wireless communication links and wired communication lines in a heterogeneous network arrangement. The example control strategy controls transmission rates based on the radio channel capacity of the wireless links to the mobile stations. One feature of the disclosed example is that is does not require changing the TCP protocol so that it can be implemented at appropriate router devices without affecting the operation of the already established Internet network.
The preceding description is exemplary rather than limiting in nature. Variations and modifications to the disclosed examples may become apparent to those skilled in the art that do not necessarily depart from the essence of this invention. The scope of legal protection given to this invention can only be determined by studying the following claims.