The present invention relates to reducing power consumption in wireless networks and in particular to providing such power consumption by optimizing contention period overhead with station grouping, proxy CSMA, and TIM monitoring.
Also according to 802.11 standards, an AP periodically sends a traffic indication map (TIM) in its beacon to identify which stations in a power save mode have buffered frames in the AP. The TIM has a plurality of bits (e.g. 2008 bits), each bit corresponding to a particular association identification (AID). Note that an AID is assigned when the station associates with the AP (as used herein the term AID may also refer to its respective station). All stations in a power save mode must wake up to receive this beacon to determine whether their bit is set (which indicates that buffered data is available for the station in the AP).
The random back-off procedure of CSMA-CA is a necessary overhead. But for power-saving stations awakened by TIM notification, this overhead takes a toll on their power consumption due to increase in the awake time caused by contention resolution, random back-off, subsequent collisions, and re-trying.
Notably, the AP sends the TIM notification to all associated stations. As a result, all the awakened stations having buffered data attempt to win the channel at substantially the same time, but only one wins. For the remaining unsuccessful stations, the entire attempt was a waste of power. Unfortunately, as the number of stations associated with the AP increases, the number of station collisions and the amount of power wasted due to failed attempts increases.
Indeed, the highest contributor of station standby power is during the AWAKE_INTERVAL, which begins when the AP informs the station of available buffered data (as indicated by the appropriate bit of the TIM being set) to the station until the station finally wins use of the channel. Therefore, the AWAKE_INTERVAL is representative of the entire duration the station is not in a power-save mode. Notably, the standby power contribution has a direct correlation to the number of stations associated with the AP.
Therefore, a need arises for a technique that reduces the probability of collision, shortens the contention window, and creates a shorter AWAKE_INTERVAL.
A method of saving power in a wireless network is described. In this method, a plurality of stations associated with an access point (AP) can be determined. Station groups can be created from the plurality of stations using group selection logic. Notably, the group selection logic is transparent to the plurality of stations. A plurality of traffic indication maps (TIMs) can then be sent, each TIM allowing only one station group access to a channel during a predetermined time interval, such as a beacon interval.
In one embodiment, the group selection logic can include a modulo-N operation based on a predetermined number N of station groups. The number of station groups can be configurable in the AP. In another embodiment, the group selection logic can include a computational technique implemented by the AP to provide a randomized selection of association IDs divided between the station groups. In yet other embodiments, the group selection logic can be based on subscription levels, home-usage designations, or received signal strength indication (RSSI) range rings.
The method can further include creating station stagger using station selection logic. In this case, a beacon including the TIM can further include station stagger information to indicate station receiving order. The station selection logic can be based on a data rate and an amount of buffered data in the AP for each station in a selected station group having access to the channel. The station stagger information can include time offsets associated with the station receiving order. A final selection of an ordered subset can include
possibilities, which minimizes channel idle time, delay time of priority data classes, retransmission efforts, or a combination thereof.
A method of saving power in a first station operable in the wireless communication network is also described. In this method, a beacon from an access point (AP) can be received. This beacon includes a traffic indication map (TIM). A sleep duration of the first station can be determined based on at least one of first information from the TIM to generate a random sleep duration, second information regarding previous operation of the first station, and third information regarding a status of the first station.
In one embodiment, determining the sleep duration can include determining a number of stations associated with the AP and having buffered data based on the TIM, the first information including the number of stations. In one embodiment, a beacon interval can be divided into a number of slices, wherein the number of slices is equal to the number of stations. A slice for a wake up can then be arbitrarily picked. In another embodiment, the number of stations associated with the AP and having buffered data based on the TIM can be determined, the first information including the number of stations. A beacon interval can be divided into a first number of slices based on a fixed time duration for each slice. A number and slice composition of overlapping sets of slices can be determined. One set of slices can be chosen based on the number of stations. The station can then arbitrarily pick a slice of the one set for its wake up.
In one embodiment, determining the sleep duration can include reviewing historical collisions of the first station, wherein the second information includes the historical collisions. In another embodiment, determining the random sleep duration can include assessing a power status of the first station, wherein the third information includes the power status. In yet another embodiment, determining the sleep duration can include a multiple types of information, e.g. the second and third information.
An access point (AP) is also described. This AP can include a non-transitory medium storing executable instructions for saving power in the wireless network. When the instructions are executed, the AP can perform certain of the described steps. A first station is also described. This first station can include a non-transitory medium storing executable instructions for saving power in the wireless network. When the instructions are executed, the first station can perform certain of the described steps. A non-transitory computer-readable medium storing instructions for saving power in a wireless network is also described. When the instructions are executed, a processor can perform the steps described above. A wireless network including an AP and a plurality of stations associated with the AP is described. The AP includes a non-transitory medium storing executable instructions for saving power in the wireless network. When the instructions are executed, the AP can perform the described steps. An electronic device including a processor block and a communication block in operative relation to the processor block is also described. The communication block can be configured to perform the described steps.
Notably, this group selection logic can be transparent to the plurality of stations. That is, forming the groups by the AP can be done autonomously from the stations. Specifically, the formation of these groups can be done without input from the stations or special messages/signals sent to the stations.
The group selection logic can vary based on the AP and/or the wireless network. In one embodiment, the group selection logic can be an algorithm, such as simple modulo-N logic or some other computational technique implemented by the AP to provide a randomized selection of the AIDs for the N groups.
For example, assume the following associated stations with AIDs {10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22} are in a power save mode. Further assume that the AP has buffered data for the stations with AIDs {10, 11, 12, 13, 14, 15, 16, 17, 18}. In step 303, the AP, instead of setting the bits for AIDs {10, 11, 12, 13, 14, 15, 16, 17, 18} in the TIM at same time, triggers a proxy CSMA.
This proxy CSMA can be characterized as a first level contention resolution. For example, with N=3 and using simple modulo-N logic, the AP can generate the following groups: Group_ID=0{12, 15, 18}, Group_ID=1{10, 13, 16}, and Group_ID=2{11, 14, 17}. In accordance with one aspect of this first level proxy CSMA, the AP selects one of the N groups, which allows only the stations of that group to contend for the channel at that point in time. Note that this selection determines which group “wins” the channel, and therefore which stations will have the opportunity to use the channel at that point in time. Assuming that Group_ID=0 is the first group that wins (with Group_ID=1 and Group_ID=2 being later, successive winners), only three stations with AIDs {12, 15, 18} can contend for the channel.
In another embodiment, with respect to creating the groups for first level proxy CSMA, groups that may include stations not having buffered data can be created. For example, Group_ID=0 could include {12, 15, 18}, wherein {12, 15}have buffered data, but {18} does not have buffered data. In this case, the AP can perform another level of classification to determine which stations in the selected group have buffered data before generating the TIM, which as indicted above sets bits only for the stations having buffered data.
In step 303, the AP can set the appropriate bits of its TIM based on the selected group. Note that depending on the value of N, which affects the number of stations in each group, each group still comprises only stations having buffered data. In contrast, in accordance with a standard CSMA technique, all eight stations (i.e. AIDs {10, 11, 12, 13, 14, 15, 16, 17, 18}) having buffered data would contend for the one channel. Therefore, the above-described technique 300 can advantageously decrease the probability of collision as well as the channel silence period, thereby improving overall channel usage. Note that all associated stations must wake up to receive the TIM, but only those stations with AIDs having set bits in the TIM must stay awake—all other stations can immediately return to a power save mode. In one embodiment, steps 301-303 can be performed for each beacon. That is, the AP can generate new groups for each beacon interval, wherein the station bits set in the TIM are those stations that have buffered data and have not been serviced in the prior beacon interval. Thus, the stations in this embodiment are changing dynamically for each beacon interval. In another embodiment, the AP can use the created groups to continue servicing stations having buffered data until all stations in the created groups have been serviced. For example, assuming that only the station having AID {12} is serviced during a first beacon interval, then during the second beacon interval the AP can proceed to service the station with AIDs {15, 18} (Group_ID=0) and then proceed to service the station with AID {10} (Group_ID=1) etc. as time permits for each beacon interval. Thus, this type of round-robin scheduling can include both intra-group and inter-group scheduling aspects.
In one embodiment, the first level proxy CSMA can be AP-only implemented. Notably, no change in the 802.11 standards is needed if technique 300 is limited to the first level proxy CSMA. Specifically, the AP sets the TIM notification only for the stations having buffered data that are members of the winning group. The notified stations can then contend for the channel in a manner specified by the 802.11 standards.
In yet another embodiment, the group selection logic technique can provide home control 403 of the stations. For example, the AIDs of stations used by minors of a household can be assigned to a low priority Group_ID. In contrast, those AIDs of stations used by the parents can be assigned to a high priority Group_ID. In another embodiment, stations within a home can be identified or designated based on use rather than users. For example, the AIDs of stations associated with Internet access and/or wireless music can be assigned to a higher priority Group_ID than AIDs of stations associated with game consoles. Thus, this embodiment can optimize wireless medium usage inside a home and provide bandwidth control, at the same time not penalizing the other stations from a power standpoint.
In yet another embodiment, the group selection logic technique can be based on the RSSI (received signal strength indication) range rings 404. For example, based on a last known RSSI of each station, the AP can determine the approximate distance of the station from the AP. A station farther away from the AP will typically require more re-transmissions and/or a lower data rate (i.e. a lower PHY rate). Thus, a station farther away from the AP will typically take longer to service. In one embodiment, a plurality of RSSI range rings (with the AP in the center) can be defined based on the last RSSI sampled before the stations went into a power save mode. The stations in the ring(s) closest to the AP can be given higher priority in the group selection than those farther from the AP. For example, a first predetermined number of stations in one or more rings closest to the AP can be treated preferentially (i.e. their AIDs assigned to a priority Group_ID) compared to a second predetermined number of station in one or more rings farther from the AP. Note that this RSSI range ring technique can be used in conjunction with the 802.11 Fast Link Adaptation. Specifically, the RSSI range ring technique merely adds another dimension to the group selection logic during the power save mode. In one embodiment, the RSSI range ring technique can be dynamic in nature with constant learning and correction of the last-known RSSI with a more recently acquired value.
In accordance with another embodiment of an improved CSMA-CA technique, the AP can also perform a second level proxy CSMA technique in which the AP can effectively identify the winning station of the notified Group_ID by triggering the CSMA recursively until reduced to the final winner. By doing so, the contention probability drops down to 0 and the system assumes a completely AP-scheduled mode of operation. While the recursive CSMA can be implemented with a variety of selection algorithms, as indicated in the above embodiments, a completely randomized lottery can be used, where a completely AP-scheduled mode is in effect, to ensure the essence of CSMA-CA is upheld. Therefore, as noted above, only one station within the AIDs {12, 15, 18} will emerge as the winner, say, AID {12}, and will be contending for the channel to receive its buffered data. While such a method does optimize the system to have zero probability of collision, it may not be the most optimal in all scenarios and can lead to dead air time. For example, the chosen station can get serviced by the AP earlier than the next Target Beacon Transmission Time (TBTT), thereby leaving a gap in channel where no other station gets serviced. This problem, however, can be remedied by using rate-controlled second level proxy CSMA.
Instead of selecting one final winning station from a recursive proxy-CSMA, a smaller ordered subset can be selected, i.e. {(12), (15), (18), (12, 15), (15, 12), (12, 18), (18, 12), (15, 18), (18, 15), (12, 15, 18), (12, 18, 15), (15, 12, 18), (15, 18, 12), (18, 12, 15), (18, 15, 12)}, of stations within the winning group, selected and ordered in a way such as to minimize the dead air-time. Such a selection can be achieved by coupling the 2nd level proxy CSMA with rate-control logic.
Specifically, in one embodiment, station selection logic can be based on the amount of buffered data to be transmitted and the data rate of the station, thereby allowing the AP to determine what percentage of the beacon interval (which is typically 100 ms) will be taken by each station in receiving its buffered data (as measured in time units or % of the beacon interval). In one embodiment, stations requiring more time units are given higher priority than stations using fewer time units.
In one embodiment, the rate-controlled 2nd level proxy CSMA can be reduced to a single station selection, if the data associated with the station is sufficient to use up one whole beacon interval. In another embodiment, all the stations in the group may be accommodated within one beacon interval because their buffered data can all be transmitted within one beacon interval. In this embodiment, the stations can be ordered based on (i) internal priority of associated data, for example the station with AID {12} may have buffered data in AC_BE (access category best effort) category, while the station with AID {15} may have buffered data in AC_BK (access category background data) category, (ii) last known RSSI, (iii) time to completion, or any other classification known to those skilled in the art. In one embodiment, the final ordered subset selection can be reduced into a multi-dimensional constrained optimization problem to select the right subset from the possible
combinations, where Nr represents the number of stations within the winning group of stations having buffered data. Thus, for the example Group_ID=0 with Nr=3 (assuming station with AID {18} is included), 3+6+6=15 possible station combinations exist. Those skilled in the art can define an optimization problem with the right set of tradeoffs to arrive at an optimal selection, befitting the needs of the wireless application. Note that any subset selected that does not include all the Nr stations would have one or more stations of the winning group (i.e. with buffered data) that are not serviced immediately and potentially marked for delivery in the next beacon period. In one embodiment, the left-over stations from the previous beacon interval can be automatic candidates for the next beacon interval under the assumption that the previous winning group has not been catered to yet. In another embodiment, the left-over stations can be subjected again to a group selection logic process.
Referring back to the above example and referring to
In one embodiment, this stagger information will indicate that the station with AID 12 will have access to the channel at time T3, or immediate reception, for receiving its buffered data (transmitted by the AP in step 603). Moreover, this stagger information can indicate when the station with AID 15 must wake up (i.e. at time T4) for its buffered data (transmitted by the AP in step 604). For example, the AP can indicate the receive offset for station 15 in predetermined time units, thereby allowing station 15 to return to a “micro-sleep” mode until it needs to wake up (e.g. immediately preceding its data window at time T4). In the example above, the station with AID 15 can be in a micro-sleep mode for 60% of the beacon interval, thereby providing considerable power savings to station with AID 15. Because the AP is actually resolving the priority of the stations within the selected Group_ID, this second level proxy CSMA can be used to eliminate contention overhead (i.e. provide a second level contention resolution, see step 303,
In one embodiment, the instructions for staggered receive for the stations having buffered data in the selected Group_ID can be provided in a currently-undesignated field of the beacon. In this embodiment, the above-described second level proxy CSMA requires a MAC frame format that is known by the AP and the stations associated with the AP.
As described above, the AP can perform various techniques to save power. These techniques can be transparent to the stations associated with the AP. In accordance with another embodiment shown in
In one embodiment, determining the sleep duration can include determining a number of stations associated with the AP and having buffered data, as determined by the TIM (and thus those stations that will be contending for the channel), wherein the first information includes the number of stations. In one embodiment, if any other stations are contending for the channel, then the station can divide the beacon interval into N slices, and then randomly choose a slice in which to wake up and poll the data from the AP. In one embodiment, the number of slices N is determined by the number of stations (e.g., N=the number of stations). In another embodiment, each slice can represent a predetermined time duration. This slicing can be set by protocol, the AP, or the station in various embodiments.
In general, each beacon interval can include P slices. In this embodiment, overlapping sets of slices can be formed from the P slices. One slice can include the P slices, while all other sets include less than P slices. For example, one embodiment can include three sets: a first set with 5 slices, a second set with 10 slices (overlapping the first set), and a third set with 20 slices (overlapping the first and second sets)(wherein P=20). In this example, the second set includes all the slices of the first set, i.e. a complete overlap, plus 5 additional slices. Similarly, in this example, the third set includes all the slices of the second set, i.e. a complete overlap, plus 10 additional slices. In other embodiments, the overlap between sets can be partial. In one embodiment, the slices are time consecutive slices, but in other embodiments, the slices need not be consecutive slices.
In the described embodiment, the station can randomly choose a slice from one of the first, second, and third sets of slices, the set of slices chosen based on the number of stations. For example, if the number of stations is less than 5, then the station can randomly chose a slice from the first set. If the number of stations is greater than 5, but less than 10, then the station can randomly chose a slice from the second set. If the number of stations is greater than 10, but less than 20, then the station can randomly chose a slice from the third set. Although three sets of slices are described above, any number of sets can be created as well as the time duration for each slice.
In another embodiment, determining the sleep duration can include reviewing historical collision data of the station, wherein the second information includes historical collision data. That is, if the station has experienced a predetermined number of collisions within a predetermined period of time, then the station may schedule its wake up for a sooner or later wake up. For example, if the station has repeatedly experienced collisions when scheduling wake ups in sooner slices (e.g. the last M wake ups with an average sleep duration D), then the station may schedule its next wake up for a later wake up, e.g. D+D1, wherein D1 is a predetermined time period.
In yet another embodiment, determining the sleep duration can include assessing the power status of the station, wherein the third information includes the power status. For example, if the battery in the station is low, then the station can set its sleep duration to be shorter rather than longer to improve its chances of receiving the data. In yet another embodiment, step 702 can take into account multiple types of information (e.g. historical collision data and power status) to determine its sleep duration.
Certain aspects of the power saving techniques 300, 500, 700 described in
Computer program code for carrying out operations of the embodiments may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on a user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN), a personal area network (PAN), or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Although the power saving techniques are described as being performed by an AP or a station, an electronic device having wireless capability typically includes certain components that may or may not be characterized as part of an AP or a station. Indeed, in some embodiments, certain components of the electronic device may be characterized as outside the AP or station, but still assist in one or more steps of the data scheduling technique.
The electronic device 800 can include a processor block 802 (possibly including multiple processors, multiple cores, multiple nodes, and/or implementing multi-threading, etc.). The electronic device 800 can also include a memory block 803, which may include cache, SRAM, DRAM, zero capacitor RAM, Twin Transistor RAM, eDRAM, EDO RAM, DDR RAM, EEPROM, NRAM, RRAM, SONGS, PRAM, and/or another type of memory cell array. The electronic device 800 also includes a network interface block 804, which may include at least a WLAN 802.11 interface. Other network interfaces may include a Bluetooth interface, a WiMAX interface, a ZigBee® interface, a Wireless USB interface, and/or a wired network interface (such as an Ethernet interface, or a powerline communication interface, etc.). The processor block 802, the memory block 803, and the network interface block 804 are coupled to a bus 801, which may be implemented in accordance with PCI, ISA, PCI-Express, HyperTransport®, InfiniBand®, NuBus, AHB, AXI, or another bus standard.
The electronic device 800 also includes a communication block 805, which can include a power saving block 805A for implementing one of the above-described techniques and another processing block 805B. The other processing block 805B may include, but is not limited to, portions of a transceiver for processing received signals, for processing to be transmitted signals, and for coordinating actions of the receiver and transmitter portions. Other embodiments may include fewer or additional components not illustrated in
The above description of the disclosed embodiments is provided to enable any person skilled in the art to make or use the present invention. Various modifications to these embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments without departing from the spirit or scope of the invention. Thus, the present invention is not intended to be limited to the embodiments shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
This application claims priority of U.S. Provisional Patent Application 61/560,778, entitled “Reducing Power Consumption In Wireless Network Stations By Optimizing Contention Period Overhead With Station Grouping And Proxy CSMA” filed Nov. 16, 2011.
Number | Date | Country | |
---|---|---|---|
61560778 | Nov 2011 | US |