Terminal-based contention free low overhead access

Information

  • Patent Application
  • 20080025339
  • Publication Number
    20080025339
  • Date Filed
    July 26, 2006
    18 years ago
  • Date Published
    January 31, 2008
    16 years ago
Abstract
A station of a wireless local area network, the station includes a joining unit configured to join one of a plurality of cliques or to create a new clique, wherein each of the plurality of cliques includes at least one station and wherein each station in a clique can hear all other stations within the clique. The station also includes a communication unit configured to communicate with a server that assigns a unique value to each station in the clique when the station joins the network, wherein the value is used to determine a rank associated with each station within the clique. The server is configured to maintain a system map that defines information associated with each of the plurality of cliques and all of the stations in the network. The station also includes a listening unit configured to listen for a predefined signal such that upon receipt of the predefined signal each station in the clique is configured to begin transmission based on an order determined by a ranking of the stations in the clique.
Description

BRIEF DESCRIPTION OF THE DRAWINGS

The accompanying drawings, which are included to provide a further understanding of the invention and are incorporated in and constitute a part of this specification, illustrate embodiments of the invention that together with the description serve to explain the principles of the invention, wherein:



FIG. 1 illustrates an embodiment of a wireless local area network for implementing a system for providing real-time services over a WLAN while taking into account WLAN station throughput, user throughput, power consumption and quality of service requirements;



FIG. 2 illustrates the steps implemented in an embodiment of the present invention for a new station to join an existing clique;



FIG. 3 illustrates the steps implemented in an embodiment of the present invention for a new station to create a new clique;



FIG. 4 illustrates the steps implemented in an embodiment of the present invention for updating an existing clique; and



FIG. 5 illustrates the steps implemented in an embodiment of the present invention for an existing station to transmit data.





DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS

Reference will now be made to preferred embodiments of the present invention, examples of which are illustrated in the accompanying drawings. The present invention is based on statistical multiplexing to exploit silence intervals found in VoIP data. Although statistical multiplexing approaches are well known, they may be subject to drawbacks, such as no guaranteed quality of service provision. Hence, an embodiment of the present invention provides a novel method that provides for the bandwidth efficiency of statistical multiplexing, preservation of quality of service and low signalling overhead.



FIG. 1 illustrates an embodiment of wireless local area network (WLAN) for implementing a system for providing real-time services over a WLAN while taking into account WLAN station throughput, user throughput, power consumption and quality of service requirements. WLAN 100 includes cliques 102a-102c, stations 104a-104x, 106a-106x and 108a-108x, a system map information (SMI) server 110, a wireless LAN access point 112 and router 114 for connecting WLAN to the Internet 116. In an embodiment of the present invention, stations 104-108 are grouped into cliques 102a-102c such that all stations 104-108 within each clique 102a-102c can “hear” all other stations within the clique, that is, there are no hidden terminals within cliques 102. As illustrated in FIG. 1, each station 104-108 includes multiple components 102a and 102b for communicating with server 110 and for receiving information from server 110. Intra-clique contention is solved by assigning an inter-frame spacing value to each station in the clique so that no two stations in a clique have the same inter-frame spacing value. The inter-frame spacing value associated with each station determines the station's ranks in a clique, i.e., the order in which the stations can attempt to transmit data.


Inter-clique contention is solved by assigning non-overlapping time windows to each clique 102. A clique's window duration is dynamically adjusted based on the transmission needs of the stations in that clique. In an embodiment of the present invention, required signalling is kept to a minimum and all signalling takes place among the stations and possibly server 110. Thus, no modification to access point 112 is required.


An embodiment of the invention provides a system map information that defines the information specifying which stations 104-108 belongs to a specific clique 102, along with the stations inter-frame spacing values, and the ordering of cliques 102. In the station map information, the station with the lowest inter-frame spacing value is referred to as “first” station of the clique. Conversely, the station with the highest inter-frame spacing value is referred to as “last” station of the clique.


A cycle in the system map information denotes the sequence of clique windows, wherein the cycle for: clique 102a, clique 102b, . . . , clique N denotes that window for clique 102a is first, the window for clique 102b is next and so on. The inter-frame spacing values are aligned to the start of the clique window. Furthermore, if the data has a periodicity requirement of X msec, where for example if X is equal to 20 msec for VoIP, then there is at least one cycle every X msec. A request-to-Send (RTS) signal from station Y, denoted by RTS(Y), shows that a request-to-send signal is transmitted to station Y. A clear-to-send (CTS) signal to station Y, denoted by CTS(Y), shows that a clear-to-send signal is addressed to station Y.


When a station, for example station 104a, joins the system or when it is going to start data transmission, station 104a obtains the system map information by querying a predefined address. The query is processed by SMI server 110, which returns the system map information. If there are existing cliques 102 in the system map information, station 104a determines if it can join clique 102a by listening to the request-to-send/clear-to-send signalling of all stations in each existing cliques. In an embodiment, if station 104a can hear the RTS(Y) and CTS (Y) of all the stations 104b-104x in clique 102a, station 104a will join clique 102a. If there are multiple “qualified” cliques, that is a clique where station 104a can hear the request-to-send/clear-to-send signalling of all stations in the clique, station 104a chooses of one of the qualified cliques. When station 104a joins, for example, clique 102a, station 104a contacts SMI server 110 to obtain an inter-frame spacing value. SMI server 110 assigns an inter-frame value that does not coincide with any of the existing inter-frame spacing values. SMI server 110 assigns the lowest available/unassigned inter-frame spacing value. It should be noted that depending on how inter-frame spacing values are managed, station 104a may or may not be the new “Last” station of clique 102a. SMI server 110 then distributes an updated system map information, including station 104a and its inter-frame spacing value, to all the stations 104-108.


Continuing with our example of station 104a, if there are no such existing qualified cliques where station 104a can hear the request-to-send/clear-to-send signalling of all stations in the clique, station 104a creates a new clique. To create a new clique, station 104a contacts SMI server 110 to obtain an inter-frame spacing value. Similar to when station 104a joins an existing clique, SMI server 110 assigns an inter-frame value that does not coincide with any of the existing inter-frame spacing values. Specifically, SMI server 110 assigns the lowest possible inter-frame spacing value among the ones that are currently unassigned and SMI server 110 distributes the updated system map information, including station 104a, to all existing stations.


Cliques 102 may need to be updated, if hidden terminal conditions change in the cliques over time, for example, due to mobility. If station 106a hears a CTS(106b), but did not hear RTS(106b) for station 106b in the same clique 102b, station 106a may decide to reinitiate its clique determination procedure by listening for the RTS(106) and CTS(106) of all stations in clique 102b. If station 106a cannot hear the RTS(106) and CTS(106) of all stations in clique 102b, station 106a may decide to leave the system.


When a station leaves the system or when it stops data transmission, it notifies SMI server 110, which updates the system map information and distributes the updated system map information to all stations 104-108. The inter-frame spacing value assigned to the leaving station, for example 106a, is returned to a pool of unassigned inter-frame spacing values. If the leaving station was “first” station in the clique, the next ranked station becomes the new “first” station. If the leaving station was “Last” station in the clique, the preceding ranked station becomes the new “last” station.


A station that has data to transmit will listen for clear-to-send signal of the “first” station of the clique to which the sending station belongs and start its inter-frame spacing timer at receipt of that clear-to-send signal. A station that is first station of its clique and that has data to transmit will listen for clear-to-send signal of the “last” station of the preceding clique. When that clear-to-send signal of the “last” station of the preceding clique is heard, the first transmitting station in the next clique issues a request-to-send signal. In an embodiment of the invention, the first station of the first clique will listen for the clear-to-send signal of the “last” station in the last clique. In one embodiment of the invention, the first station sends the request-to-send signal right away. In another embodiment of the invention, the first station sends the request-to-send signal after a predetermined amount of time to provide time for other traffic.


At its normally scheduled time, as determined by its inter-frame spacing value, a station that is the last station of its clique transmits its data and issues a request-to-send signal. If the station that is the last station of its clique does not have data, it issues only a request-to-send signal.


If a clique is a single member clique, meaning that there is only one station in the clique, then to avoid confusion for the cliques that follow the single member clique on how to interpret the clear-to-send signals addressed to the station in the single member clique, stations of the clique following the single member clique start transmission of a request-to-send signal only after hearing two clear-to-send signals addressed to the station of the single member clique. To address the scenario where the station in the signal member clique has failed, without updating the SMI map, the stations in the clique following the single member clique start a timer after the last clear-to-send signal that is send on the medium. After expiration of the timer, if there is no activity on the medium, the stations in the clique following the single member clique may start transmission of a request-to-send signal.


As noted above, a new station listens for request-to-send signals and “clear-to-send signals” of all stations in each clique to determine which cliques are “qualified” cliques. Thus, request-to-send and clear-to-send signals must be issued from other stations, which are not “first” or “last” stations of a clique, to allow a new station to determine whether nor not to join a clique, and also to enable cliques updates. Various approaches may be implemented for enabling the other stations to listen for request-to-send signals and clear-to-send signals. For example, each station may issue a request-to-send signal every N cycles for cycle i, i+N, i+2N, etc. where i is chosen randomly by the station. In another example, a station may issue a request-to-send signal upon request from server 110. Server 110 runs its algorithm for issuing the request.


In the basic form described above, failure of a “Last” or “First” station will have a system wide impact. To address the single failure point issue, if a failure occurs at the “First” station, such that no clear-to-send signal is heard for the first station, the next ranked station in the clique takes over and issues a request-to-send signal. If failure is confirmed after m cycles, server 110 updates the system map information as if the failed station left the system. If, however, failure occurs at the “Last” station, such that no clear-to-send signal is heard for the last station, the First station of the next clique takes over and issues a request-to-send signal. If failure is confirmed after m cycles, server 110 updates the system map information as if the failed station left the system. Server 110 is assumed to be reliable enough and as such is implemented with the appropriate amount of redundancy. However, an additional fallback is for the stations 104-108 to operate without communicating with server 110, to overcome the case when stations 104-108 cannot reach server 110.



FIG. 2 illustrates the steps implemented in an embodiment of the present invention for a new station to join an existing clique. In Step 2010, when a station joins the system or when it is going to start data transmission, the station obtains the system map information by querying a predefined address. In Step 2020, the query is processed by SMI server 110, which returns the system map information. In Step 2030, if there are existing cliques 102 in the system map information, the joining station determines if it can join a pre-existing clique 102 by listening to the request-to-send/clear-to-send signalling of all stations in each existing cliques. In Step 2040, if the station can hear the RTS(Y) and CTS (Y) of all the stations in an existing clique 102, the station will join clique 102. Alternatively, if there are multiple “qualified” cliques, the station chooses one of the qualified cliques. In Step 2050, after the station joins an existing clique, the station contacts SMI server 110 to obtain an inter-frame spacing value. In Step 2060, SMI server 110 assigns an inter-frame value that does not coincide with any of the existing inter-frame spacing values and distributes an updated system map information to all the stations.



FIG. 3 illustrates the steps implemented in an embodiment of the present invention for a new station to create a new clique. In Step 3010, when a station joins the system or when it is going to start data transmission, the station obtains the system map information by querying a predefined address. In Step 3020, the query is processed by SMI server 110, which returns the system map information. In Step 3030, if there are existing cliques 102 in the system map information, the joining station determines if it can join a pre-existing clique 102 by listening to the request-to-send/clear-to-send signalling of all stations in each existing cliques. In Step 3040, if there are no such existing qualified cliques, the joining station creates a new clique. In Step 3050, the joining station contacts SMI server 110 to obtain an inter-frame spacing value. In Step 3060, SMI server 110 assigns an inter-frame value that does not coincide with any of the existing inter-frame spacing values and distributes the updated system map information to all existing stations.



FIG. 4 illustrates the steps implemented in an embodiment of the present invention for updating an existing clique. In Step 4010, if hidden terminal conditions change in the cliques over time, a station may decide to reinitiate its clique determination procedure by listening for the request-to-send and clear-to-send signals of all stations in clique. In Step 4020, if the station cannot hear the request-to-send and clear-to-send signals of all stations in clique, the station may decide to leave the system. In Step 4030, when the station leaves the system or when it stops data transmission, it notifies SMI server 110, which updates the system map information and distributes the updated system map information to all stations 104-108. In Step 4040, SMI server 110 returns the inter-frame spacing value assigned to the leaving station to a pool of unassigned inter-frame spacing values. If the leaving station was “first” station in the clique, the next ranked station becomes the new “first” station. If the leaving station was “Last” station in the clique, the preceding ranked station becomes the new “last” station.



FIG. 5 illustrates the steps implemented in an embodiment of the present invention for an existing station to transmit data. In Step 5010, a station that has data to transmit will listen for clear-to-send signal of the “first” station of the clique to which the sending station belongs and start its inter-frame spacing timer at receipt of that clear-to-send signal. In Step 5020, a station that is first station of its clique, and that has data to transmit, will listen for clear-to-send signal of the “last” station of the preceding clique, wherein when that clear-to-send signal of the “last” station of the preceding clique is heard, the first transmitting station in the next clique issues a request-to-send signal. In Step 5030, at its normally scheduled time, as determined by its inter-frame spacing value, a station that is the last station of its clique transmits its data and issues a request-to-send signal. If the station that is the last station of its clique does not have data, it issues only a request-to-send signal.


The present invention has the advantages of both contention free and low overhead mechanisms. It eliminates contention and therefore the cost of collision and retransmission attempts, while providing guaranteed delay quality of service with virtually no signalling overhead. Therefore, the system can operate very close to its maximum capacity. The present invention also overcomes the hidden terminal problem and it does not require modifications to the access points. Furthermore, because contention is eliminated, this present invention is also very relevant for the WiFi mesh case. It is known that contention based access can result in serious throughput issues in mesh case. Although there can still be a hidden terminal problem if non-enhanced terminals coexist in the system, this problem may be addressed by assigning separate channels to non-enhanced terminals.


It should be appreciated by one skilled in art, that the present invention may be utilized in any device that implements the network availability information described above. The foregoing description has been directed to specific embodiments of this invention. It will be apparent; however, that other variations and modifications may be made to the described embodiments, with the attainment of some or all of their advantages. Therefore, it is the object of the appended claims to cover all such variations and modifications as come within the true spirit and scope of the invention.

Claims
  • 1. A station, comprising: a joining unit configured to join one of a plurality of cliques or to create a new clique, each of the plurality of cliques comprises at least one station and each station in a clique can hear all other stations within the clique, the station being of a wireless local area network;a communication unit configured to communicate with a server and to receive a unique value that is assigned by the server to each station in the clique when the station joins the network, the value is used to determine a rank associated with each station within the clique, the communication unit is configured to receive information in a system map that defines information associated with each of the plurality of cliques and all of the stations in the network, anda listening unit configured to listen for a predefined signal such that upon receipt of the predefined signal each station in the clique is configured to begin transmission based on an order determined by a ranking of the stations in the clique.
  • 2. The station of claim 1, wherein the joining unit is configured to obtain the system map when the station joins the network or at the start of data transmission, wherein a query for the system map from the station is processed by the server.
  • 3. The station of claim 1, wherein the communication unit is configured to receive an updated system map from the server when the information in the system map is updated by the server.
  • 4. The station of claim 1, wherein the joining unit is configured, on a periodic basis, to determine whether no not to reinitiate a clique determination procedure, wherein the station may leave a clique if it cannot hear the signalling of all station within the clique.
  • 5. The station of claim 5, wherein the joining unit is configured, upon leaving the clique, to notify the server such that the system map is updated and distribute the updated system map to other stations in the network, wherein the joining unit is further configured to return the value assigned to the leaving station to the server for placement in an unassigned pool of values.
  • 6. The station of claim 1, wherein upon joining the network, the joining unit is configured to determine if it can join at least one of a plurality of existing cliques by listening to signalling of all stations within each of the plurality of existing cliques, wherein if the station is capable of hearing all of the stations within one of plurality of existing cliques, the station joins that clique.
  • 7. The station of claim 1, wherein the joining unit is configured to select one of a plurality of existing cliques, if the station is capable of hearing all of the stations within a plurality of existing cliques.
  • 8. The station of claim 1, wherein upon joining the network, the joining unit is configured to determine if it can join at least one of a plurality of existing cliques by listening to signalling of all stations within each of the plurality of existing cliques, wherein if the station is not capable of hearing all of the stations within one of plurality of existing cliques, the station creates a new clique.
  • 9. The station of claim 8, wherein if the joining unit creates a single station clique, a station in a clique after the single station clique is configured to start transmission of a request-to-send signal only after hearing a predefined number of clear-to-send signals that were addressed to the station in the single station clique.
  • 10. The station of claim 8, wherein if the joining unit creates a single station clique, a station in a clique after the single station clique is configured to start a timer after a last clear-to-send signal, wherein at the expiration of the timer, the station in the clique after the single station clique is configured to transmit a request-to-send signal if there is on activity on a medium where the last clear-to-send signal was detected.
  • 11. The station of claim 1, wherein the communication unit is configured to obtain the system map that defines a specific clique to which each station belongs, the value associated with each station and an ordering of the plurality of cliques.
  • 12. The station of claim 1, wherein the communication unit is configured to obtain the system map such that if the station is defined with a lowest value in the clique then the station is defined as a first station of the clique and if the station is defined with a highest value in the clique then the station is defined as a last station of the clique.
  • 13. The station of claim 1, wherein the communication unit is configured to access the system map wherein a cycle in the system map denotes the sequence of the windows assigned to the plurality of cliques and the values of a clique are aligned to the start of a clique window and wherein there is at least one cycle for every periodicity requirement.
  • 14. The station of claim 13, wherein the communication unit is configured to communicate with the server for assigning non-overlapping time windows to each of the plurality of cliques, wherein a window associated with one of the plurality of cliques is dynamically adjusted based on the transmission needs of the stations in that clique.
  • 15. A method, comprising: enabling a station entering the network to join one of a plurality of cliques or create a new clique, wherein each of the plurality of cliques comprises at least one station and wherein each station in a clique can hear all other stations within the clique;receiving a unique value by a station in the clique when the station joins the network, wherein the value is used to determine a rank associated with each station within the clique;obtaining a system map that defines information associated with each of the plurality of cliques and all of the stations in the network; andlistening for a predefined signal such that upon receipt of the predefined signal each station in the clique is configured to begin transmission based on an order determined by a ranking of the stations in the clique.
  • 16. The method of claim 15, wherein the step of joining comprises obtaining the system map when the station joins the network or at the start of data transmission.
  • 17. The method of claim 15, wherein the step of receiving further comprises receiving an updated system map, by the station, from a server when the information in the system map is updated by the server.
  • 18. The method of claim 15, further comprising, on a periodic basis, determining by the station whether or not to reinitiate a clique determination procedure, wherein the station may leave a clique if it cannot hear the signalling of all station within the clique.
  • 19. The method of claim 18, further comprising, upon leaving the clique, notifying a server by the station, wherein the server updates the system map, returns the value assigned to the leaving station to an unassigned pool of values and distributes the updated system map to other stations in the network.
  • 20. The method of claim 15, further comprising, upon joining the network, determining by the station if it can join at least one of a plurality of existing cliques by listening to signalling of all stations within each of the plurality of existing cliques, wherein if the station is capable of hearing all of the stations within one of plurality of existing cliques, the station joins that clique.
  • 21. The method of claim 15, wherein the step of joining further comprises selecting, by the station, one of a plurality of existing cliques, if the station is capable of hearing all of the stations within a plurality of existing cliques.
  • 22. The method of claim 15, wherein the step of joining further comprises determining by the station if it can join at least one of a plurality of existing cliques by listening to signalling of all stations within each of the plurality of existing cliques, wherein if the station is not capable of hearing all of the stations within one of plurality of existing cliques, the station creates a new clique.
  • 23. The method of claim 22, wherein if the step of joining creates a single station clique, the method further comprises beginning transmission, by a station in a clique after the single station clique, of a request-to-send signal only after hearing a predefined number of clear-to-send signals that were addressed to the station in the single station clique.
  • 24. The method of claim 22, wherein if the step of joining creates a single station clique, the method further comprises beginning a timer, by a station in a clique after the single station clique, after a last clear-to-send signal, wherein at the expiration of the timer, the station in the clique after the single station clique is configured to transmit a request-to-send signal if there is on activity on a medium where the last clear-to-send signal was detected.
  • 25. A server, comprising: a communication unit configured to communicate with a station when the station joins one of a plurality of cliques or to create a new clique, each of the plurality of cliques comprising at least one station and each station in a clique being configured to hear all other stations within the clique;an assigning unit configured to assign a unique value to each station in the clique when the station joins the network, the value being used to determine a rank associated with each station within the clique; anda maintenance unit configured to maintain a system map that defines information associated with each of the plurality of cliques and all of the stations in the network, wherein each station is configured to listen for a predefined signal such that upon receipt of the predefined signal each station in the clique is configured to begin transmission based on an order determined by a ranking of the stations in the clique.
  • 26. The server of claim 25, wherein the communication unit is configured to process a query for the system map from the station when the station joins the network.
  • 27. The server of claim 25, wherein the maintenance unit is configured to distribute an updated system map to the station when the information in the system map is updated by the server.
  • 28. The server of claim 25, wherein the maintenance unit is configured to update the system map, return the value assigned to a station leaving the network to an unassigned pool of values and distribute the updated system map to other stations in the network.
  • 29. The server of claim 25, wherein the maintenance unit is configured to maintain the system map that defines a specific clique to which each station belongs, the value associated with each station and an ordering of the plurality of cliques.
  • 30. The server of claim 25, wherein the maintenance unit is configured to define the system map such that if the station is defined with a lowest value in the clique then the station is defined as a first station of the clique and if the station is defined with a highest value in the clique then the station is defined as a last station of the clique.
  • 31. The server of claim 25, wherein the maintenance unit is configured to define the system map such that a cycle in the system map denotes the sequence of the windows assigned to the plurality of cliques and the values of a clique are aligned to the start of a clique window and wherein there is at least one cycle for every periodicity requirement.
  • 32. The server of claim 25, wherein the maintenance unit is configured to define the system map such that non-overlapping time windows are assigned to each of the plurality of cliques, wherein a window associated with one of the plurality of cliques is dynamically adjusted based on the transmission needs of the stations in that clique.
  • 33. A method in a server, comprising: communicating with a station when the station joins one of a plurality of cliques or creates a new clique, wherein each of the plurality of cliques comprises at least one station and wherein each station in a clique can hear all other stations within the clique;assigning a unique value to each station in the clique when the station joins the network, wherein the value is used to determine a rank associated with each station within the clique; andmaintaining a system map that defines information associated with each of the plurality of cliques and all of the stations in the network, wherein each station in the clique configured to listen for a predefined signal such that upon receipt of the predefined signal each station in the clique is configured to begin transmission based on an order determined by a ranking of the stations in the clique.
  • 34. An apparatus comprising: enabling means for enabling a station entering the network to join one of a plurality of cliques or create a new clique, wherein each of the plurality of cliques comprises at least one station and wherein each station in a clique can hear all other stations within the clique;assigning means for assigning a unique value to each station in the clique when the station joins the network, wherein the value is used to determine a rank associated with each station within the clique;maintaining means for maintaining a system map that defines information associated with each of the plurality of cliques and all of the stations in the network; andlistening means for listening for a predefined signal such that upon receipt of the predefined signal each station in the clique is configured to begin transmission based on an order determined by a ranking of the stations in the clique.
  • 35. A computer program product embodied on a computer readable means, upon execution the computer program product being configured to perform the steps of: enabling a station entering the network to join one of a plurality of cliques or create a new clique, wherein each of the plurality of cliques comprises at least one station and wherein each station in a clique can hear all other stations within the clique;receiving a unique value by a station in the clique when the station joins the network, wherein the value is used to determine a rank associated with each station within the clique;obtaining a system map that defines information associated with each of the plurality of cliques and all of the stations in the network; andlistening for a predefined signal such that upon receipt of the predefined signal each station in the clique is configured to begin transmission based on an order determined by a ranking of the stations in the clique.