The application relates in general to ad hoc computer networking, and more particularly, in various embodiments, to improve Carrier Sense Multiple Access (CSMA) protocols to provide for prioritized communication.
One common protocol used in computer networking is the CSMA protocol. One version, CSMA/CD is often used in wireless networks. According to the CSMA protocol, communication nodes reserve time on a channel, typically on a first-come, first-serve basis. Each node waits a random period of a time after a channel clears before attempting to transmit its next data packet. The node with the shortest random wait time reserves the channel and is able to transmit. The random waiting, however, can leave some nodes with insufficient access to the channel to transmit higher priority data.
In another frequently used protocol, the Time Division Multiple Access (TDMA) protocol, each node is assigned a periodic time slot in which it can transmit data. While this protocol ensures a minimum bandwidth to each node, substantial bandwidth can be wasted if one node is responsible for transmitting much of the data traffic in the network.
A new protocol, referred to herein as the priorityCSMA protocol combines benefits of the TDMA and CSMA protocols to provide at least minimum bandwidth for priority messaging while still reducing the likelihood of wasted bandwidth. In a first embodiment, a node utilizing the priorityCSMA protocol maintains a condition table. The condition table includes at least one condition unrelated to network traffic conditions, which if met, triggers the node to reserve a set of time windows for receiving communications. During those time windows, the node refrains from initiating transmission of communication.
The node incorporates the set of time windows into a reservation table, which also keeps track of standard CSMA traffic-related time windows in which the node refrains from initiating communication. In one embodiment, subsequent to the time windows unrelated to network traffic being incorporated into the reservation table, the node determines whether it can transmit data, or whether it must refrain from such transmission, just as if it were using a standard CSMA protocol.
In general, a node incorporates the time windows unrelated to network traffic conditions in response to detecting that a traffic-independent condition is met. A node can store multiple sets of such time windows corresponding to different traffic-independent conditions. For example, the node may incorporate time windows into its reservation table in response to determining that the node is within a predetermined location. The predetermined location may be a fixed geographic location or a relative location, for example, within a kilometer of a second node, which may itself be mobile. In another example, the node incorporates time windows into its reservation table in exchange for gaining access to network services. Alternatively, or in addition, the node incorporates time windows into its reservation table upon the instruction or request of another node.
In another embodiment of the priority CSMA protocol, the time windows unrelated to network traffic conditions have corresponding classes. In this embodiment, nodes in such a time window refrain from initiating transmission of data unless the data belongs to the class that corresponds to the time window. Example classes include, without limitation, multicast data, high priority data, data originating from another specific node or group of nodes.
The invention may be better understood from the following illustrative description with reference to the following drawings.
Wireless nodes can use a number of protocols for communication. One common protocol is the Carrier Sense Multiple Access (CSMA) protocol. In a typical CSMA protocol, a transmitting node, for example, a node 102a, listens to a communication channel to determine whether the communication channel is clear for the transmitting node 102a to transmit a data message. If the channel is clear, the transmitting node 102a transmits a request to send (RTS) message to a destination node, for example, 102b. The RTS message includes a data field indicating the time the transmitting node 102a expects the transmission to take. The destination node 102b receives the RTS message, and if the no other node 102 is transmitting a message to the destination node 102b, the destination node 102b transmits a clear to send (CTS) message, indicating to the transmitting node 102a that it can begin transmission.
In wireless CSMA networks, the RTS and CTS messages are broadcast such that all nodes 102 within radio range (also known as neighbors) of the transmitting 102a and destination 102b nodes receive the messages. The neighbors record the time at which they receive the RTS and CTS messages, along with the expected duration of the corresponding transmission indicated in the RTS and CTS messages. Based on this information, the neighbors predict a future time that the channel is next going to be available for transmission. According to the protocol, the time period between the transmission of the CTS and the expected end of a transmission defines a time window during which neighboring nodes are to refrain from initiating transmissions of their own. Illustratively, these time windows are stored in a reservation table, also known as a network allocation vector (NAV) table. An enhanced reservation table, suitable for illustrative embodiments of the invention, is discussed further in relation to
According to the illustrative embodiment of the invention, the nodes 102 communicate according to a modified CSMA protocol, referred to herein as the priorityCSMA protocol. In addition to nodes 102 refraining from initiating transmissions based on receipt of RTS and CTS messages, or other network traffic related conditions, the nodes 102 operating according to the priorityCSMA protocol reserve additional time windows for ensuring another node 102 or the base station 104 has the ability to transmit data packets. These additional time windows are referred to herein as priority windows. Nodes 102 reserve the priority windows based on conditions which are unrelated to current network traffic. For example, the nodes 102 may reserve priority windows based on location (for example, see
The nodes 102a-102e communicate with one another via an ad hoc network. Example devices suitable for serving as nodes 102 for the purposes of the invention include desktop computers, laptop computers, personal data assistants, mobile telephones, and other computing devices having wireless communication capabilities. Preferably, the nodes 102 are portable or mobile.
The reservation table 210 includes two traffic based time windows 306a and 306b reserved at time t=0 (i.e., the present). The reservation table 210 may incorporate multiple traffic-related time windows 306 corresponding a single point in time. The overlapping time windows 306 result from transmissions being sent by two different neighbors that are each in radio range of the node 200, but which are not in range of one another. The first time window 306a in the reservation table 210 expires at time t=a, and the second window 306b expires at time t=b+δ.
The reservation table 210 also includes three priority windows 308a-308c. The priority windows 308a-308c in the illustrated reservation table 210 occur periodically. Each priority window 308a-308c lasts, for example, for 1 unit of time. The first priority window 308a begins at time t=b and ends at time t=b+1. The second priority window 308b begins at time t=b+x and ends at time t=b+x+1. The third priority window 308c begins at time t=b+2× and ends at time t=b+2x+1. Thus, based on the current status of the reservation table 210, the node 200 is permitted to attempting initiating transmission of data between times t=b+1 and t=b+x, between times t=b+x+1 and t=b+2×, and after time t=b+2x+1.
Note that the second traffic-based time window 306b partially overlaps with the first priority window 308a. This indicates that a second node, such as node 102b, will be transmitting during at least part of the first priority window 308a. It this implementation of the priorityCSMA protocol, the continuation of transmission into a priority window 308 is allowed, though such allowance is not essential. The priorityCSMA protocol prohibits the initiation of new transmissions during time windows 306 or 308 in the reservation table 210. That is, a priority window 308 is treated just like traffic related time windows 306 incorporated into the reservation table 210.
While only one set of priority windows 308 is depicted in the reservation table 210, the reservation table 210 may incorporate multiple sets of priority windows 308 corresponding to different classes of priority transmissions. Example priority transmission classes include, without limitation, multicast communications, transmissions originating from the base station 104, transmissions originating from a specific one, or group, of the other nodes 102, etc. The reservation table 210, however, in this implementation, need not keep track of the class of a priority window 308, or the fact that the priority window 308 is a priority window 308 at all.
In an alternative implementation of the priorityCSMA protocol, referred to herein as the priorityCSMA-b protocol, described further in relation to
If the reservation table 210 indicates that the node 200 is in a time window 306 or 308 in which the node 200 is to refrain from initiating transmissions, the node 200 waits until the end of the time window 306 or 308, as indicated by the reservation table 210, and then waits an additional random period of time (step 408). The random wait period ensures that all of the node's neighbors do not try to initiate communication at the same time, as soon as the time window 306 or 308 ends.
At the end of the random time period, the node 200 checks its reservation table 210 to determine if a new time window 306 or 308 in which it is to refrain from initiating transmission has begun (decision block 410). The node 200 ends up in a new time window 306 or 308, for example under three circumstances: 1) a neighboring node 102, which also had a data packet to transmit, waited a shorter random time period before initiating transmission of the data packet; 2) a neighboring node 102, which was not bound by the previous traffic-related time window 306, begins transmitting during the time the node 200 was waiting; and 3) the random waiting period ends in a priority time window 308. If a new time window, whether it is a priority window 308 or a traffic-related window 306, begins during the time the node 200 waits to initiate transmission, the node 200 waits until the end of the new time window 306 or 308 plus another additional random period of time (step 408).
If the reservation table 210, at the end of random waiting period, indicates that the node 200 is not in another time window 306 or 308 in which it is to refrain from initiating transmission, the node 200 initiates transmission of the data packet (step 406).
Periodically, the node 200 checks if any of the conditions in the conditions store 208 are met (step 502). If, at decision block 504, the node 200 determines that one such condition is met, the node 200 adds the priority windows 308 corresponding to that condition to its reservation table 210 (step 506). If none of the conditions are met, the node 200 waits a predetermined period of time and rechecks the conditions (step 502).
Referring back to
The conditions store 208 of the node 200, in this case, stores data identifying at least one location, such as an area surrounding the base station 104. If the node 200 enters one of the locations identified in the conditions store 208, the node 200 adds a set of priority windows 308 to its reservation table 210. Reserving priority windows 308 based on location helps ensure that traffic particular to a given area has the opportunity to be transmitted. For example, in a municipal setting, a municipality may want to ensure that emergency responders, such as police officers, firefighters, and emergency medical personnel have sufficient bandwidth to communicate. To this end, nodes 102 operated by non-emergency responders may be required to reserve priority windows 308 while near police stations, fire stations, and hospitals to ensure that emergency workers have some minimum access to the network 100.
In another example, in a military setting, communications may be routed through the base station 104. As a node, such as the node 102, approaches the base station 104, the node reserves priority windows 308 to allow the base station 104 a minimum amount of bandwidth to transmit routing or other multicast information.
To carry out the method 600 of location-based priority window 308 reservation, the node 200 determines its location (step 602). As mentioned in relation to
If the node 200 determines it is not to reserve priority windows 308 in its current location, the node 200 reviews its reservation table 210 to determine if the reservation table 210 currently incorporates any stale location-based priority windows 308 (decision block 608). Such priority windows 308 may have been added to the reservation table 210 based on the prior location of the node 200. If stale priority windows 308 exist in the reservation table 210, they are removed at this point (step 610). As the node 200 continues to move, it continues to monitor its location (step 602) to determine if it needs to add priority windows 308 to (step 606) or remove priority windows 308 from (step 610) its reservation table 210.
The method 700 begins with the node 200 requesting access to a network service (step 702). The node 200 then receives priority window 308 reservation requirements (step 704), which the node 200 must accept to gain access to the requested network services. Assuming the node 200 is willing to accept the reservation requirements, the node 200 transmits an acceptance message (step 706) indicating it will reserve the required priority windows 308. The node 200 is given the requested access (step 708) and the node 200 adds the required priority windows 308 to its reservation table 210 (step 710).
The methods illustrated in
As mentioned above, in another illustrative implementation of priorityCSMA (priorityCSMA-b), the node 200 differentiates between the priority windows 308 based on a class of data transmission that corresponds to a given priority window 308. In priorityCSMA-b, the limitation on initiating communications during a priority window 308 is not a prohibition on transmission initiation. Instead, priorityCSMA-b limits the class of data transmissions that can be initiated during a priority window 308.
The method 800 begins with the node 200 determining that it has a data packet to transmit (step 802). The node 200 then checks its reservation table 210 to determine if it is in a time window 306 or 308 during which it limits the initiation of data transmissions (decision block 804). If the node 200 is not in such a time window 306 or 308, the node 200 initiates transmission of the data packet (step 806).
If the node 200 is in a time window 306 or 308 during which it limits initiation of transmissions, the node 200 determines whether the time window 306 or 308 is related to network traffic (i.e., the channel is currently being used by other nodes), or whether the time window is a priority window 308 (decision block 808). If the time window 306 or 308 is related to network traffic, the node 200 waits until the end of the traffic-related time window 306 and another random period of time, thereafter (step 810). After the waiting period, the node 200 checks its reservation table 210 again to see if it is clear to transmit its data packet (decision block 804).
If the node 200 instead determines that it is in a priority window 308, the node 200 compares the class of the priority window 308 with the class of the data packet the node is attempting to transmit (decision block 812). If the data packet belongs to the priority window 308 class, the node 200 initiates transmission of the data packet (step 806). Otherwise, the node 200 waits until the end of the time window and an additional random time period thereafter (step 810) before attempting to reinitiate transmission at decision block 804.
The invention may be embodied in other specific forms without departing form the spirit or essential characteristics thereof. The forgoing embodiments are therefore to be considered in all respects illustrative, rather than limiting of the invention.
The instant application claims priority from provisional application No. 60/556,124, filed Mar. 25, 2004, the disclosure of which is incorporated herein by reference in its entirety.
This invention was made with Government support under Contract No. W911NF-04-C-0025, awarded by DARPA ATO. The Government has certain rights in this invention
Number | Date | Country | |
---|---|---|---|
60556124 | Mar 2004 | US |