CA2300157C - Adaptive media control - Google Patents
Adaptive media control Download PDFInfo
- Publication number
- CA2300157C CA2300157C CA2300157A CA2300157A CA2300157C CA 2300157 C CA2300157 C CA 2300157C CA 2300157 A CA2300157 A CA 2300157A CA 2300157 A CA2300157 A CA 2300157A CA 2300157 C CA2300157 C CA 2300157C
- Authority
- CA
- Canada
- Prior art keywords
- polling
- communication
- session
- stations
- sessions
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W72/00—Local resource management
- H04W72/50—Allocation or scheduling criteria for wireless resources
- H04W72/54—Allocation or scheduling criteria for wireless resources based on quality criteria
- H04W72/543—Allocation or scheduling criteria for wireless resources based on quality criteria based on requested quality, e.g. QoS
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W72/00—Local resource management
- H04W72/04—Wireless resource allocation
- H04W72/044—Wireless resource allocation based on the type of the allocated resource
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W74/00—Wireless channel access, e.g. scheduled or random access
- H04W74/04—Scheduled or contention-free access
- H04W74/06—Scheduled or contention-free access using polling
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W84/00—Network topologies
- H04W84/02—Hierarchically pre-organised networks, e.g. paging networks, cellular networks, WLAN [Wireless Local Area Network] or WLL [Wireless Local Loop]
- H04W84/10—Small scale networks; Flat hierarchical networks
- H04W84/12—WLAN [Wireless Local Area Networks]
Abstract
A media control approach that supports transmission of data streams with QoS requirements, such as minimum throughput or maximum delay, while adapting to the changing characteristics of the transmission medium. The media control approach includes use of a polling manager (324) and a resource manager (322). The resource manager (322) provides an admission control procedure that prevents admission of sessions that cannot be supported by the system and allocates network resources needed to support admitted sessions. The polling manager (324) uses an efficient "just in time" polling of stations based on their allocated bandwidth or communication rates. Stations that do not use their allocated rates are polled less often than those which use their allocation, thereby increasing the total throughput of the system and providing proper quality of service support for real-time application.
Description
ADAPTIVE MEDIA CONTROL
Background of the Invention This invention relates to media control in a communication network.
Use of shared communication media for network communication typically requires control of those shared media. For example, the media may provide a limited communication capacity and media control, including media allocation and management, provides mechanisms for controlling access by stations on the network to the media in order to provide fair and efficient communication over the network.
Coupling of multiple stations using a wireless local area network (WLAN) can provide the benefits of a wired local area network (LAN) without requiring the stations to be physically coupled using transmission "wires" such as coaxial conductors, twisted pairs of wires, or optical fibers. Data is transferred using radio frequency (RF) or optical frequency (e.g., infra-red (IR)) transmission through space. Radio-based wireless networks, in general, have several characteristics that differ from wired networks. These characteristics include lower achievable data capacity due to factors including bandwidth and power limitation, time-varying communication capacity that may depend on the particular source and destination of a transmission, and higher error rates, for example, due to interfering signals.
Wireless networks typically use a similar software architecture as wired networks. A multi-layer communication protocol "stack," such as the OSI reference model, is used to implement communication over the WLAN.
In current LANs, as in WLANs, the media access control (MAC) layer is responsible for access control of the communication medium. It is the MAC layer, between the communication protocols above the physical layer, that differs most between wired and wireless networks.
Various MAC approaches for WLANs have been proposed.
These approaches use techniques including random access and time-, frequency-, or code-division multiple access (TDMA, FDMA, CDMA) in which each wireless station is allocated a portion of the total available communication capacity. For example, the IEEE 802.11 media access control standard is a random access technique which uses a carrier sense with a collision avoidance (CSMA/CA) scheme.
Polling techniques have been used to control access to shared communication resources, such as to a shared communication medium in a communication network. In such polling techniques, stations transmit in response to being polled by a master station in the network. In this way, multiple stations are prevented from transmitting concurrently. Concurrent transmission would, in general corrupt the data being transmitted. A polled station must respond in some way to a polling message before the master station can poll another station. Stations are typically polled in a round-robin manner. In such a round-robin approach, polling messages are sent to all other stations, and responses are sent from those stations, before a station is polled again.
Local area networks are increasingly used to transfer data, including multimedia data streams, that have various quality-of-service requirements. Examples of such requirements include a guaranteed minimum data rate and maximum delay. Applications that have such quality-of-service requirements include audio or video telephony and conferencing, multimedia collaboration, and multimedia distribution.
Background of the Invention This invention relates to media control in a communication network.
Use of shared communication media for network communication typically requires control of those shared media. For example, the media may provide a limited communication capacity and media control, including media allocation and management, provides mechanisms for controlling access by stations on the network to the media in order to provide fair and efficient communication over the network.
Coupling of multiple stations using a wireless local area network (WLAN) can provide the benefits of a wired local area network (LAN) without requiring the stations to be physically coupled using transmission "wires" such as coaxial conductors, twisted pairs of wires, or optical fibers. Data is transferred using radio frequency (RF) or optical frequency (e.g., infra-red (IR)) transmission through space. Radio-based wireless networks, in general, have several characteristics that differ from wired networks. These characteristics include lower achievable data capacity due to factors including bandwidth and power limitation, time-varying communication capacity that may depend on the particular source and destination of a transmission, and higher error rates, for example, due to interfering signals.
Wireless networks typically use a similar software architecture as wired networks. A multi-layer communication protocol "stack," such as the OSI reference model, is used to implement communication over the WLAN.
In current LANs, as in WLANs, the media access control (MAC) layer is responsible for access control of the communication medium. It is the MAC layer, between the communication protocols above the physical layer, that differs most between wired and wireless networks.
Various MAC approaches for WLANs have been proposed.
These approaches use techniques including random access and time-, frequency-, or code-division multiple access (TDMA, FDMA, CDMA) in which each wireless station is allocated a portion of the total available communication capacity. For example, the IEEE 802.11 media access control standard is a random access technique which uses a carrier sense with a collision avoidance (CSMA/CA) scheme.
Polling techniques have been used to control access to shared communication resources, such as to a shared communication medium in a communication network. In such polling techniques, stations transmit in response to being polled by a master station in the network. In this way, multiple stations are prevented from transmitting concurrently. Concurrent transmission would, in general corrupt the data being transmitted. A polled station must respond in some way to a polling message before the master station can poll another station. Stations are typically polled in a round-robin manner. In such a round-robin approach, polling messages are sent to all other stations, and responses are sent from those stations, before a station is polled again.
Local area networks are increasingly used to transfer data, including multimedia data streams, that have various quality-of-service requirements. Examples of such requirements include a guaranteed minimum data rate and maximum delay. Applications that have such quality-of-service requirements include audio or video telephony and conferencing, multimedia collaboration, and multimedia distribution.
Summary of the Invention In a wireless local area network (WLAN) environment, a WLAN media access control (MAC) module can directly address the quality-of-service (QoS) requirements of data streams. Support for QoS requirements is more easily provided at the MAC layer than at higher layers or the protocols. In particular, an adaptive MAC polling approach in combination with a resource manager provides efficient use of limited and time varying communication resources while satisfying QoS requirements, if possible.
In accordance with one aspect of the present invention, there is provided a method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources including data rates in accordance with the data rate requirements of a plurality of sessions in the quality of service class including optimizing a utility function subject to a set of constraints; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein the data rate requirements include minimum required and maximum desired data rates for the plurality of sessions in the quality of service class, the utility function depends on the assigned rates, and the set of constraints includes the assigned rate for each admitted session being in a range from its minimum required data rate to its maximum desired data rate and the assigned data rates taken together not exceeding an available communication capacity.
In accordance with a second aspect of the present invention, there is provided a method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources including data rates in accordance with the data rate requirements of a plurality of sessions in the quality of service class; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence; wherein polling the stations includes polling sessions with lower assigned data rates less frequently than stations with higher assigned data rates.
In accordance with a third aspect of the present invention, there is provided a method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the -4a-quality of service class; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein adapting the polling sequence includes reducing the rate of polling for a session in response the monitored transmissions for that session corresponding to a reduction in actual rate of transmission for that session, and increasing the rate of polling for a session in response the monitored transmissions for that session corresponding to an increase in actual rate of transmission for that session.
In accordance with a fourth aspect of the present invention, there is provided a method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling is performed in a periodic cycle and during each period of the cycle a subset of the sessions in the quality of service class are polled in accordance with their -4b-allocated communication resources, and the polling sequence is determined by the values of a plurality of state variables, each associated with a corresponding session, and adapting the polling sequence is effected by changing the values of the state variable.
In accordance with a fifth aspect of the present invention, there is provided an apparatus for polling a plurality of stations configured to communicate over a shared communication medium in a communication network comprising: a polling manager which sends polling messages to the stations in the network in accordance with a polling sequence; a transmitter which accepts polling messages from the polling manager and transmits the messages over the shared communication medium to the stations; and a receiver which receives messages over the shared communication medium from the stations and provides monitoring information to the polling manager; a resource manager which accepts requests to admit communication sessions and provides resource allocations for admitted sessions to the polling manager;
and a plurality of state indices associated with corresponding admitted sessions; wherein the polling manager adapts the polling sequence in accordance with the monitoring information, and initializes the state indices in accordance with the resource allocations, updates the state indices in accordance with the monitoring information, and determines the polling sequence in accordance with the state indices.
In accordance with a sixth aspect of the present invention, there is provided a computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of communication stations which communicate over a shared communication medium in a communication network, to perform -4c-the functions: assigning communication resources including data rates in accordance with data rate requirements of a plurality of sessions in a quality of service class including optimizing a utility function subject to a set of constraints; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein the data rate requirements include minimum required and maximum desired data rates for the plurality of sessions in the quality of service class, the utility function depends on the assigned rates, and the set of constraints includes the assigned rate for each admitted session being in a range from its minimum required data rate to its maximum desired data rate and the assigned data rates taken together not exceeding an available communication capacity.
In accordance with a seventh aspect of the present invention, there is provided a computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of communication stations which communicate over a shared communication medium in a communication network, to perform the functions: assigning communication resources including data rates in accordance with data rate requirements of a plurality of sessions in a quality of service class including optimizing a utility function subject to a set of constraints; polling the communication stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in -4d-response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling the stations includes polling sessions with lower assigned data rates less frequently than stations with higher assigned data rates.
In accordance with an eighth aspect of the present invention, there is provided a computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of communication stations which communicate over a shared communication medium in a communication network, to perform the furictiorns: assiyriiny com[municaLion resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence; wherein adapting the polling sequence includes reducing the rate of polling for a session in response the monitored transmissions for that session corresponding to a reduction in actual rate of transmission for that session, and increasing the rate of polling for a session in response the monitored transmissions for that session corresponding to an increase in actual rate of transmission for that session.
In accordance with a ninth aspect of the present invention, there is provided a computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of -4e-communication stations which communicate over a shared communication medium in a communication network, to perform the functions: assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence; wherein polling is performed in a periodic cycle and during each period of the cycle a subset of the sessions in the quality of service class are polled in accordance with their allocated communication resources, and the polling sequence is determined by the values of a plurality of state variables, each associated with a corresponding session, and adapting the polling sequence is effected by changing the values of the state variable.
According to another aspect of the present invention, there is provided a method for media access control in a communication system which includes a plurality of communication stations which communicate over a shared communication medium, the method comprising: assigning communication resources in accordance with quality of service requirements of a plurality of communication sessions, including determining a polling pattern; polling each of a plurality of communication stations to transmit data over a shared communication medium for the plurality of communication sessions according to the polling pattern; monitoring data transmitted by the communication stations in response to the polling; and adapting assignment of the communication resources in accordance with the monitoring, including adapting the polling pattern for one or more of the communication sessions, wherein adapting the polling pattern includes reducing a rate of polling for the session if the session is not utilizing assigned communication resources; or increasing a rate of polling for the session if the session is utilizing more than the assigned communication resources.
According to still another aspect of the present invention, there is provided an apparatus for controlling media access by a plurality of stations configured to communicate over a shared communication medium in a -4f-communication system, the apparatus comprising: means for assigning communication resources based on quality of service requirements of a plurality of communication sessions, including means for determining a polling pattern;
means for polling each of the communication stations to transmit data over a shared communication medium for the plurality of communication sessions according to the polling pattern; means for monitoring data transmitted by the communication stations in response to the polling; and means for adapting assignment of the communication resources based on the monitored data, including adapting the polling pattern for one or more of the communication sessions, wherein adapting the polling pattern comprises: reducing a rate of polling for a specific session if the session is not utilizing assigned communication resources, thereby reducing an actual rate of transmission for that session;
or increasing a rate of polling for the specific session if the session is utilizing more than the assigned communication resources, thereby increasing an actual rate of transmission for that session.
According to yet another aspect of the present invention, there is provided a computer readable medium encoded with software which, when executed by one or more computing systems, causes the one or more computing systems to perform a method comprising: assigning communication resources on a shared communication medium based on quality of service requirements of a plurality of communication sessions, including determining a polling pattern;
polling each of a plurality of communication stations to transmit data for the plurality of communication sessions according to the polling pattern;
monitoring data transmitted over the shared communication medium by the communication stations in response to the polling; and modifying the polling pattern for one or more of the communication sessions, wherein modifying the polling pattern comprises: reducing a rate of polling for a session if the session is not utilizing assigned communication resources; or increasing a rate of polling for a session if the session is utilizing more than the assigned communication resources.
According to a further aspect of the present invention, there is provided an apparatus for polling a plurality of stations configured to communicate over a shared communication medium in a communication system, the apparatus -4g-comprising: a polling manager configured to generate polling messages to a plurality of stations based on a polling pattern; a transmitter coupled to the polling manager, wherein the transmitter is configured to initiate transmission of the polling messages over a shared communication medium to the plurality of stations; and a receiver coupled to the polling manager, wherein the receiver is configured to receive messages over the shared communication medium from the stations, and provide monitoring information to the polling manager, wherein the polling manager is configured to adapt the polling pattern by reducing a rate of polling for a specific session based on monitored transmissions for the specific session if the session is not utilizing assigned communication resources, or increasing a rate of polling for the specific session based on the monitored transmissions for the specific session if the session is utilizing more than the assigned communication resources.
According to yet a further aspect of the present invention, there is provided in a communication system in which a plurality of stations share access to a communication network according to a multiple-access media access control protocol, a method for controlling access by the stations to the network, the method comprising: at an arbiter station that is coupled to a communication network, determining a polling pattern for polling a plurality of stations coupled to the communication network, wherein determining a polling pattern includes:
reducing a rate of polling for a station if the session is not utilizing assigned communication resources, or increasing the rate of polling for a station if the session is utilizing more than the assigned communication resources, wherein the rate of polling for a station satisfies quality of service requirements for a plurality of communication sessions at the station; transmitting polling messages from the arbiter station to each of the plurality of communication stations according to the polling pattern; and at each of the plurality of stations, using received polling messages to determine times when to transmit onto the communication network, and at the determined times transmitting data onto the communication network using a multiple access media access control protocol.
Embodiments of the invention provide, in general, a media control that supports transmission of data streams with QoS requirements, such as -4h-minimum throughput or maximum delay, while adapting to the changing characteristics of the wireless transmission medium. In addition, assignment of limited resources, in particular, the limited communication capacity of the transmission medium, is tightly coupled to the media control approach.
-4i-The media control approach includes use of a polling manager and a resource manager. The resource manager provides an admission control procedure that prevents admission of sessions that cannot be supported by the system and allocates network resources needed to support admitted sessions. The resource manager allocates bandwidth to sessions by taking into account the data rate requested for the sessions and the achievable throughput. The resource manager can also consider other factors such as utility and priorities of communication sessions. The available bandwidth is taken into account to allow a requested data rate to be achieved despite retransmissions necessitated by interference, physical separation, or other error-causing situations. The polling manager uses an efficient "just in time" polling of stations based on their allocated bandwidth or communication rates. Stations that do not use their allocated rates are polled less often than those which use their allocation, thereby increasing the total throughput of the system and providing proper quality of service support for real-time applications. Advantages of the invention include quality of service support which is needed for real-time multimedia applications, responsiveness to time varying communication capacity, resource allocation in accordance with effective bandwidth between pairs of stations, and admission of sessions only if their minimum required data rates are achievable.
In general, in another aspect of the invention, there is provided media control in a communication network which includes multiple communication stations coupled over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements. Media control includes assigning communication resources in -4j -accordance with the data rate requirements of sessions in the quality of service class, polling the stations to transmit data for particular sessions according to a polling sequence, monitoring data transmissions in response to the polling, and adaptively allocating the communication resources in accordance with the monitored data transmissions. Adaptively allocating the communication resources can include adapting the polling sequence used for polling the stations. In addition, one or more of the following features may be included.
Media control can also involve accepting a request to establish a new communication session in the quality of service class, admitting the new session if its data rate requirement can be provided without exceeding a limit on available communication capacity on the shared communication medium, and rejecting the new session if its data rate requirement cannot be provided without exceeding the limit on available communication resources.
The data rate requirements of sessions in the quality of service class may include minimum required and a maximum desired data rates, and may also include maximum intervals between polling of those sessions.
Assigning communication resources as part of media control can include determining a set of sessions in the quality of service class that can be provided with their minimum required data rate, and assigning data rates to each of those sessions in accordance with their minimum required data rates and their maximum desired data rates.
Monitoring data transmission can include collecting data retransmission statistics, and assigning communication resources includes adjusting data rate requirements in accordance with the collected retransmission statistics.
Assigning communication resources can also include optimizing a utility function subject to a set of constraints. The utility function depends on the assigned rates. The set of constraints includes the assigned rate for each admitted session being in the range from its minimum required data rate to its maximum desired data rate and the assigned data rates taken together not exceeding an available communication capacity.
Polling of sessions can be such that sessions with lower assigned data rates are polled less frequently than stations with higher assigned data rates. Also, adapting the polling sequence can include reducing the rate of polling for a session in response the monitored transmissions for that session corresponding to a reduction in actual rate of transmission for that session, and increasing the rate of polling for a session in response the monitored transmissions for that session corresponding to an increase in actual rate of transmission for that session. Polling can be performed in a periodic cycle and during each period of the cycle a subset of the sessions in the quality of service class are polled in accordance with their allocated communication resources. The polling sequence can be determined by the values of state variables, each associated with a corresponding session, and adapting the polling sequence can be effected by changing the values of the state variable. Polling a station to transmit data for a particular session can include assembling a data message identifying the session, transmitting the data message to the station using either a radio frequency or an optical frequency transmitter, and monitoring data transmissions can includes receiving the data transmissions using either a radio frequency or an optical frequency receiver.
Other features and advantages will be apparent from the following description, and from the claims.
Brief Description of the Drawing Fig. 1 shows an exemplary arrangement of stations coupled over a wireless network;
Fig. 2 shows elements of a wireless station;
Fig. 3 shows software modules which execute on a wireless station;
Fig. 4 shows an exemplary transmission cycle in which an arbiter station polls QoS and non-QoS sessions;
Fig. 5 illustrates a state machine used to adapt the polling pattern for a session in response to data transmissions for that session; and Fig. 6 is a flowchart showing processing of a Permission-To-Send (PTS) message.
In accordance with one aspect of the present invention, there is provided a method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources including data rates in accordance with the data rate requirements of a plurality of sessions in the quality of service class including optimizing a utility function subject to a set of constraints; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein the data rate requirements include minimum required and maximum desired data rates for the plurality of sessions in the quality of service class, the utility function depends on the assigned rates, and the set of constraints includes the assigned rate for each admitted session being in a range from its minimum required data rate to its maximum desired data rate and the assigned data rates taken together not exceeding an available communication capacity.
In accordance with a second aspect of the present invention, there is provided a method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources including data rates in accordance with the data rate requirements of a plurality of sessions in the quality of service class; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence; wherein polling the stations includes polling sessions with lower assigned data rates less frequently than stations with higher assigned data rates.
In accordance with a third aspect of the present invention, there is provided a method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the -4a-quality of service class; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein adapting the polling sequence includes reducing the rate of polling for a session in response the monitored transmissions for that session corresponding to a reduction in actual rate of transmission for that session, and increasing the rate of polling for a session in response the monitored transmissions for that session corresponding to an increase in actual rate of transmission for that session.
In accordance with a fourth aspect of the present invention, there is provided a method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling is performed in a periodic cycle and during each period of the cycle a subset of the sessions in the quality of service class are polled in accordance with their -4b-allocated communication resources, and the polling sequence is determined by the values of a plurality of state variables, each associated with a corresponding session, and adapting the polling sequence is effected by changing the values of the state variable.
In accordance with a fifth aspect of the present invention, there is provided an apparatus for polling a plurality of stations configured to communicate over a shared communication medium in a communication network comprising: a polling manager which sends polling messages to the stations in the network in accordance with a polling sequence; a transmitter which accepts polling messages from the polling manager and transmits the messages over the shared communication medium to the stations; and a receiver which receives messages over the shared communication medium from the stations and provides monitoring information to the polling manager; a resource manager which accepts requests to admit communication sessions and provides resource allocations for admitted sessions to the polling manager;
and a plurality of state indices associated with corresponding admitted sessions; wherein the polling manager adapts the polling sequence in accordance with the monitoring information, and initializes the state indices in accordance with the resource allocations, updates the state indices in accordance with the monitoring information, and determines the polling sequence in accordance with the state indices.
In accordance with a sixth aspect of the present invention, there is provided a computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of communication stations which communicate over a shared communication medium in a communication network, to perform -4c-the functions: assigning communication resources including data rates in accordance with data rate requirements of a plurality of sessions in a quality of service class including optimizing a utility function subject to a set of constraints; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein the data rate requirements include minimum required and maximum desired data rates for the plurality of sessions in the quality of service class, the utility function depends on the assigned rates, and the set of constraints includes the assigned rate for each admitted session being in a range from its minimum required data rate to its maximum desired data rate and the assigned data rates taken together not exceeding an available communication capacity.
In accordance with a seventh aspect of the present invention, there is provided a computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of communication stations which communicate over a shared communication medium in a communication network, to perform the functions: assigning communication resources including data rates in accordance with data rate requirements of a plurality of sessions in a quality of service class including optimizing a utility function subject to a set of constraints; polling the communication stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in -4d-response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling the stations includes polling sessions with lower assigned data rates less frequently than stations with higher assigned data rates.
In accordance with an eighth aspect of the present invention, there is provided a computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of communication stations which communicate over a shared communication medium in a communication network, to perform the furictiorns: assiyriiny com[municaLion resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence; wherein adapting the polling sequence includes reducing the rate of polling for a session in response the monitored transmissions for that session corresponding to a reduction in actual rate of transmission for that session, and increasing the rate of polling for a session in response the monitored transmissions for that session corresponding to an increase in actual rate of transmission for that session.
In accordance with a ninth aspect of the present invention, there is provided a computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of -4e-communication stations which communicate over a shared communication medium in a communication network, to perform the functions: assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class; polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence; monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence; wherein polling is performed in a periodic cycle and during each period of the cycle a subset of the sessions in the quality of service class are polled in accordance with their allocated communication resources, and the polling sequence is determined by the values of a plurality of state variables, each associated with a corresponding session, and adapting the polling sequence is effected by changing the values of the state variable.
According to another aspect of the present invention, there is provided a method for media access control in a communication system which includes a plurality of communication stations which communicate over a shared communication medium, the method comprising: assigning communication resources in accordance with quality of service requirements of a plurality of communication sessions, including determining a polling pattern; polling each of a plurality of communication stations to transmit data over a shared communication medium for the plurality of communication sessions according to the polling pattern; monitoring data transmitted by the communication stations in response to the polling; and adapting assignment of the communication resources in accordance with the monitoring, including adapting the polling pattern for one or more of the communication sessions, wherein adapting the polling pattern includes reducing a rate of polling for the session if the session is not utilizing assigned communication resources; or increasing a rate of polling for the session if the session is utilizing more than the assigned communication resources.
According to still another aspect of the present invention, there is provided an apparatus for controlling media access by a plurality of stations configured to communicate over a shared communication medium in a -4f-communication system, the apparatus comprising: means for assigning communication resources based on quality of service requirements of a plurality of communication sessions, including means for determining a polling pattern;
means for polling each of the communication stations to transmit data over a shared communication medium for the plurality of communication sessions according to the polling pattern; means for monitoring data transmitted by the communication stations in response to the polling; and means for adapting assignment of the communication resources based on the monitored data, including adapting the polling pattern for one or more of the communication sessions, wherein adapting the polling pattern comprises: reducing a rate of polling for a specific session if the session is not utilizing assigned communication resources, thereby reducing an actual rate of transmission for that session;
or increasing a rate of polling for the specific session if the session is utilizing more than the assigned communication resources, thereby increasing an actual rate of transmission for that session.
According to yet another aspect of the present invention, there is provided a computer readable medium encoded with software which, when executed by one or more computing systems, causes the one or more computing systems to perform a method comprising: assigning communication resources on a shared communication medium based on quality of service requirements of a plurality of communication sessions, including determining a polling pattern;
polling each of a plurality of communication stations to transmit data for the plurality of communication sessions according to the polling pattern;
monitoring data transmitted over the shared communication medium by the communication stations in response to the polling; and modifying the polling pattern for one or more of the communication sessions, wherein modifying the polling pattern comprises: reducing a rate of polling for a session if the session is not utilizing assigned communication resources; or increasing a rate of polling for a session if the session is utilizing more than the assigned communication resources.
According to a further aspect of the present invention, there is provided an apparatus for polling a plurality of stations configured to communicate over a shared communication medium in a communication system, the apparatus -4g-comprising: a polling manager configured to generate polling messages to a plurality of stations based on a polling pattern; a transmitter coupled to the polling manager, wherein the transmitter is configured to initiate transmission of the polling messages over a shared communication medium to the plurality of stations; and a receiver coupled to the polling manager, wherein the receiver is configured to receive messages over the shared communication medium from the stations, and provide monitoring information to the polling manager, wherein the polling manager is configured to adapt the polling pattern by reducing a rate of polling for a specific session based on monitored transmissions for the specific session if the session is not utilizing assigned communication resources, or increasing a rate of polling for the specific session based on the monitored transmissions for the specific session if the session is utilizing more than the assigned communication resources.
According to yet a further aspect of the present invention, there is provided in a communication system in which a plurality of stations share access to a communication network according to a multiple-access media access control protocol, a method for controlling access by the stations to the network, the method comprising: at an arbiter station that is coupled to a communication network, determining a polling pattern for polling a plurality of stations coupled to the communication network, wherein determining a polling pattern includes:
reducing a rate of polling for a station if the session is not utilizing assigned communication resources, or increasing the rate of polling for a station if the session is utilizing more than the assigned communication resources, wherein the rate of polling for a station satisfies quality of service requirements for a plurality of communication sessions at the station; transmitting polling messages from the arbiter station to each of the plurality of communication stations according to the polling pattern; and at each of the plurality of stations, using received polling messages to determine times when to transmit onto the communication network, and at the determined times transmitting data onto the communication network using a multiple access media access control protocol.
Embodiments of the invention provide, in general, a media control that supports transmission of data streams with QoS requirements, such as -4h-minimum throughput or maximum delay, while adapting to the changing characteristics of the wireless transmission medium. In addition, assignment of limited resources, in particular, the limited communication capacity of the transmission medium, is tightly coupled to the media control approach.
-4i-The media control approach includes use of a polling manager and a resource manager. The resource manager provides an admission control procedure that prevents admission of sessions that cannot be supported by the system and allocates network resources needed to support admitted sessions. The resource manager allocates bandwidth to sessions by taking into account the data rate requested for the sessions and the achievable throughput. The resource manager can also consider other factors such as utility and priorities of communication sessions. The available bandwidth is taken into account to allow a requested data rate to be achieved despite retransmissions necessitated by interference, physical separation, or other error-causing situations. The polling manager uses an efficient "just in time" polling of stations based on their allocated bandwidth or communication rates. Stations that do not use their allocated rates are polled less often than those which use their allocation, thereby increasing the total throughput of the system and providing proper quality of service support for real-time applications. Advantages of the invention include quality of service support which is needed for real-time multimedia applications, responsiveness to time varying communication capacity, resource allocation in accordance with effective bandwidth between pairs of stations, and admission of sessions only if their minimum required data rates are achievable.
In general, in another aspect of the invention, there is provided media control in a communication network which includes multiple communication stations coupled over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements. Media control includes assigning communication resources in -4j -accordance with the data rate requirements of sessions in the quality of service class, polling the stations to transmit data for particular sessions according to a polling sequence, monitoring data transmissions in response to the polling, and adaptively allocating the communication resources in accordance with the monitored data transmissions. Adaptively allocating the communication resources can include adapting the polling sequence used for polling the stations. In addition, one or more of the following features may be included.
Media control can also involve accepting a request to establish a new communication session in the quality of service class, admitting the new session if its data rate requirement can be provided without exceeding a limit on available communication capacity on the shared communication medium, and rejecting the new session if its data rate requirement cannot be provided without exceeding the limit on available communication resources.
The data rate requirements of sessions in the quality of service class may include minimum required and a maximum desired data rates, and may also include maximum intervals between polling of those sessions.
Assigning communication resources as part of media control can include determining a set of sessions in the quality of service class that can be provided with their minimum required data rate, and assigning data rates to each of those sessions in accordance with their minimum required data rates and their maximum desired data rates.
Monitoring data transmission can include collecting data retransmission statistics, and assigning communication resources includes adjusting data rate requirements in accordance with the collected retransmission statistics.
Assigning communication resources can also include optimizing a utility function subject to a set of constraints. The utility function depends on the assigned rates. The set of constraints includes the assigned rate for each admitted session being in the range from its minimum required data rate to its maximum desired data rate and the assigned data rates taken together not exceeding an available communication capacity.
Polling of sessions can be such that sessions with lower assigned data rates are polled less frequently than stations with higher assigned data rates. Also, adapting the polling sequence can include reducing the rate of polling for a session in response the monitored transmissions for that session corresponding to a reduction in actual rate of transmission for that session, and increasing the rate of polling for a session in response the monitored transmissions for that session corresponding to an increase in actual rate of transmission for that session. Polling can be performed in a periodic cycle and during each period of the cycle a subset of the sessions in the quality of service class are polled in accordance with their allocated communication resources. The polling sequence can be determined by the values of state variables, each associated with a corresponding session, and adapting the polling sequence can be effected by changing the values of the state variable. Polling a station to transmit data for a particular session can include assembling a data message identifying the session, transmitting the data message to the station using either a radio frequency or an optical frequency transmitter, and monitoring data transmissions can includes receiving the data transmissions using either a radio frequency or an optical frequency receiver.
Other features and advantages will be apparent from the following description, and from the claims.
Brief Description of the Drawing Fig. 1 shows an exemplary arrangement of stations coupled over a wireless network;
Fig. 2 shows elements of a wireless station;
Fig. 3 shows software modules which execute on a wireless station;
Fig. 4 shows an exemplary transmission cycle in which an arbiter station polls QoS and non-QoS sessions;
Fig. 5 illustrates a state machine used to adapt the polling pattern for a session in response to data transmissions for that session; and Fig. 6 is a flowchart showing processing of a Permission-To-Send (PTS) message.
Description of the Preferred Embodiments A first embodiment of the invention involves communication among a number of stations over a wireless local area network (WLAN). Fig. 1 shows an exemplary arrangement of four stations 100a-d which communicate in a WLAN over a broadcast wireless medium 105, such as radio frequency propagation through the interior space of an office building. Stations communicate directly with one another through broadcast medium 105. Embodiments of the invention use a variety of radio or optical frequencies and transmission methods. In this first embodiment, the stations communicate using radio frequency spread spectrum transmission in the Industrial Scientific and Medical (ISM) band in the range of 2.4GHz using an overall bandwidth of approximately 83MHz. The transmission technique provides a raw system data rate of iMb/s between stations. The transmission characteristics between stations 100a-d depend on a variety of factors including the transmission power at a station, the physical distance and interfering physical structures between stations, and the nature of interfering signal sources. In addition, these transmission characteristics can change during operation, due, for example, to a station's or a physical barrier's moving. As a result, the achievable throughput over the channel may be substantially lower than the raw data rate and may also vary over time.
As shown in Fig. 1, wireless stations 100a-d include network interface controllers (NICs) 102a-d coupled to antennas 104a-d. They also include general purpose central processing units (CPUs) 106a-d and memories 108a-d. Application programs execute on the CPUs and communicate over the WLAN through the NICs. Memories 108a-d are used for application storage. The stations can be a variety of devices such as personal computers, computer peripherals, gateway devices to other networks, or any other of devices that require data communication services.
In this first embodiment, one station (e.g., station 100a) is designated as the arbiter station. The arbiter station is responsible for managing allocation and use of communication resources. As will be described further below, arbiter station 100a accepts requests to admit communication sessions into the system, assigns communication rates to admitted sessions and, in accordance with their assigned communication rates, polls stations to transmit data for particular sessions.
In general, the arbiter session polls sessions frequently enough to sustain the assigned communication rates for those sessions, but does not poll substantially more often than required to sustain the assigned rates.
This polling approach avoids use of bandwidth with the overhead of unnecessary polling.
Sessions belong to one of two classes. The first class includes sessions with rate or delay related quality-of-service requirements. This class is referred to as the QoS class. The other class of sessions is the non-QoS class. The arbiter station allocates resources to QoS sessions in preference to non-QoS sessions. In polling, the QoS sessions are polled to satisfy their QoS
requirements while non-QoS sessions are polled as a second priority. Other embodiments may have multiple QoS
classes where the QoS classes are ordered by their priority.
A QoS session may be used, for example, to transmit motion video data or other multimedia information. If a minimum data rate were not maintained for such a QoS
session, the signal would be unacceptably degraded. Non-QoS sessions are used for data transfers that are not time critical. For example, a file transfer does not require a sustained minimum transfer rate.
The arbiter station may also penalize sessions that do not consume their allocated data rates by polling them less often. This reduced polling frees up communication capacity for other sessions.
An additional feature of the polling approach is that QoS sessions at a station always takes priority over non-QoS sessions at that station. Therefore, when the arbiter station polls non-QoS session at a station, that station may substitute transmission of a QoS session.
Also, a station always sends some data in response to a poll unless the station has no pending data for any session of any class.
In this embodiment data in a communication session is transferred directly between stations without the intervention of the arbiter station (i.e., the arbiter station does not in general route data). A station receiving data responds directly after receiving the data with either an acknowledgment (ACK) or a negative acknowledgment (NACK) message to the sender indicating a correct or erroneous receipt of the data. If a NACK is received, or a timeout expires with neither an ACK nor a NACK's being received, a link layer retransmission protocol is used by the sending station to retransmit the data when that session is next polled. As the arbiter station can monitor transmission between any two stations, explicit acknowledgment of a polling message from the arbiter is not always needed. Moreover, by monitoring the transmission between any two stations participating in a session, the arbiter station can collect retransmission statistics about this session to estimate the achievable throughput between the two stations. These statistics are used by the resource manager to provide proper admission control and bandwidth allocation.
Fig. 2 shows the arrangement of the hardware components of a representative wireless station, in this case arbiter station 100a. General purpose CPU 106a executes application programs 210 and communication modules 212 stored in working memory 214 such as dynamic RAM. Non-volatile memory 216, typically a magnetic disk or read-only memory (ROM), is used to store application programs and communication modules prior to initialization of the station. CPU 106a communicates with network interface controller (NIC) 102a. In this embodiment, NIC 102a is coupled to CPU 106a using a PCMCIA bus. In other embodiments the NIC may be coupled to the CPU in any one of a variety of different ways including over an ISA bus, or a parallel or serial port.
NIC 102a includes a control processor 220 which communicates with CPU 106a. NIC 102a has a memory 228 which is used for data buffers 226, session state for active sessions 224, and media control modules 222 which execute on control processor 220.
Control processor 220 communicates with transceiver 230 which is coupled to antenna 104a. Transceiver 230 converts a baseband data signal into the radio frequency signal transmitted through antenna 104a and converts a radio signal received at antenna 104a into a baseband data signal. A variety of transceivers can be used in embodiments of the invention. For example, in this first embodiment, transceiver 230 includes a Harris Semiconductor "PRISM" chipset that includes a quadrature modem, a voltage controlled oscillator, an RF/IF
converter, a RF power amplifier with transmit/receive switch, and a low noise RF amplifier. The chipset implements a direct sequence (spread spectrum) transmission technique to reduce interference from other transmission sources.
Fig. 3 shows the arrangement of software modules on an arbiter station, such as station 100a shown in Fig. 1.
The arrangement of software modules on a non-arbiter station, such as stations 100b-d, is the same except that elements indicated with broken lines in Fig. 3 are not included. The description below of the elements shown in Fig. 3 is applicable to both arbiter and non-arbiter stations unless noted otherwise.
Application programs 210 include a graphical user interface (GUI) application 302 and communication applications 300. Communication applications 300 communicate with applications executing at other stations. GUI application 302 is used by a user to interactively control QoS requirements of communication sessions involving communication applications 300. Each session involves a single unidirectional data stream between two stations. Each QoS session that is admitted is promised either a minimum. data rate or a maximum delay between polling, or both. The arbiter station endeavors to maintain a promised minimum data rate, even during periods when the overall system capacity is reduced due, for example, to an interfering signal.
Each session communicates through a standard communication protocol stack 310, implementing in this embodiment TCP/IP and UDP/IP protocols. The stations operate using the Microsoft Windows 95 or Windows NT
operating system. Protocol stack 310 is provided by Microsoft Corporation for use with the Windows 95 and NT
operating systems. Application programs 210 communicate with protocol stack 310 using standard techniques for the Windows operating systems.
Protocol stack 310 communicates with the Network Driver Interface Specification (NDIS) driver 312 that provides the interface to media control modules 222 executing on the Network Interface Controller (NIC). In addition to providing a standard interface for higher layer protocols, an NDIS driver contains code that controls the NIC. Higher level protocols, implemented in protocol stack 310, use calls to the NDIS driver to submit data packets for transmission to the network or to retrieve data received from the network. When packets arrive from the network, media control modules 222 pass them to the low level controller code in the operating system which then calls NDIS driver routines to forward these packets for processing by protocol stack 310.
In this embodiment, protocol stack 310 does not have explicit provisions for supporting QoS sessions.
Therefore, a second control path is provided to NDIS
driver 312 through virtual device driver VxD 314. GUI
application 302 accepts control information from a user and passes this information through VxD 314 to NDIS
driver 312. For example, a user may specify using GUI
application 302 that all data streams addressed to a particular IP port (i.e., to a particular IP socket number on a remote host) on other stations have a particular minimum data rate and maximum delay requirement, and a maximum data rate that can be used.
This information is passed to NDIS driver 312 which in turn tags packets that arrive from protocol stack 310 and are transferred to media control modules 222. In this way, media control modules are able to differentiate between QoS and non-QoS sessions.
MAC 320 in media control modules 222 stores the data received from communication modules 212 in data buffers 226. Data buffers 226 include separate session buffers 330, one for each session.
MAC 320 waits to receive a Permission-To-Send (PTS) message initiated by a polling manager 324 at the arbiter station before sending data in data buffers 226. On a non-arbiter station, the MAC receives a PTS message from the polling manager on the arbiter station via the WLAN.
On the arbiter station, MAC 320 receives a PTS message directly from polling manager 324.
On the arbiter station, media control modules 222 include polling manager 324 and a resource manager 322.
Resource manager 322 maintains session state 224 which includes fixed and assigned session parameters 350 for each session, adaptive parameters 360 for each session, and retransmission rate estimates 362 for pairs of stations. Fixed parameters for a session may include the minimum achievable data rate required and the maximum achievable data rate that can be used by the session, as well as the maximum allowable delay, while the assigned parameters for a session include the assigned data rate.
Adaptive parameters 360 are used to track a session's actual communication pattern and to adjust the polling pattern to avoid unnecessary polling.
After describing the operation of the system when communication sessions have already been established and data rates assigned, we then describe the procedure for adapting to the pattern of data transmissions from individual stations, the procedure for assigning resources, and finally the procedure used to establish a new session.
Polling manager 324 at the arbiter station of the WLAN polls sessions on the stations in the WLAN by sending PTS messages for individual sessions to the MAC
on the station sending the session. If communication applications at a station have multiple active sessions for transmission to other stations, the polling manager polls the station separately for each session.
Referring to Fig. 4, the polling manager polls by repeating a fixed-duration polling cycle of duration Tcycle 410. During one cycle, there is a first QoS phase of duration T,.s 412, followed by a non-QoS phase of duration Tnon-Q.s 414. The durations of the QoS and non-QoS phases vary from cycle to cycle, but the sum of their durations remains fixed at Tcycle= During both phases of the cycle, the following sequence of transmissions is repeated:
a) The arbiter station transmits a Permission-to-Send (PTS) message that indicates which session is permitted to transmit;
b) The station that is sending that session either:
i) transmits a data packet for the indicated session, ii) transmits a data packet for some other session, or iii) transmits a Nothing-To-Send (NTS) message indicating that it has no data to transmit.
c) If the station transmits data in step b-i) or b-ii) and the data is received, the receiving station transmits either an ACK or a NACK, depending on whether the data was correctly received.
Before the arbiter station initiates the sequence for the next session, it waits to receive a NTS, ACK or NACK
message, or to time out, for example, due to the PTS, NTS, ACK or NACK message being lost.
During the first, QoS, phase, the PTS messages from the arbiter indicate QoS sessions, while the PTS messages in the second, non-QoS, phase indicate non-QoS sessions.
Note, however, that although a PTS message may indicate a QoS session in step a), data transmitted in step b-ii) may be for a non-QoS session if the transmitting station has no data buffered for QoS sessions. Similarly, a PTS
message indicating a non-QoS session in step a) may result in QoS sessions being transmitted in step b-ii) if the transmitting station has a backlog of data for QoS
As shown in Fig. 1, wireless stations 100a-d include network interface controllers (NICs) 102a-d coupled to antennas 104a-d. They also include general purpose central processing units (CPUs) 106a-d and memories 108a-d. Application programs execute on the CPUs and communicate over the WLAN through the NICs. Memories 108a-d are used for application storage. The stations can be a variety of devices such as personal computers, computer peripherals, gateway devices to other networks, or any other of devices that require data communication services.
In this first embodiment, one station (e.g., station 100a) is designated as the arbiter station. The arbiter station is responsible for managing allocation and use of communication resources. As will be described further below, arbiter station 100a accepts requests to admit communication sessions into the system, assigns communication rates to admitted sessions and, in accordance with their assigned communication rates, polls stations to transmit data for particular sessions.
In general, the arbiter session polls sessions frequently enough to sustain the assigned communication rates for those sessions, but does not poll substantially more often than required to sustain the assigned rates.
This polling approach avoids use of bandwidth with the overhead of unnecessary polling.
Sessions belong to one of two classes. The first class includes sessions with rate or delay related quality-of-service requirements. This class is referred to as the QoS class. The other class of sessions is the non-QoS class. The arbiter station allocates resources to QoS sessions in preference to non-QoS sessions. In polling, the QoS sessions are polled to satisfy their QoS
requirements while non-QoS sessions are polled as a second priority. Other embodiments may have multiple QoS
classes where the QoS classes are ordered by their priority.
A QoS session may be used, for example, to transmit motion video data or other multimedia information. If a minimum data rate were not maintained for such a QoS
session, the signal would be unacceptably degraded. Non-QoS sessions are used for data transfers that are not time critical. For example, a file transfer does not require a sustained minimum transfer rate.
The arbiter station may also penalize sessions that do not consume their allocated data rates by polling them less often. This reduced polling frees up communication capacity for other sessions.
An additional feature of the polling approach is that QoS sessions at a station always takes priority over non-QoS sessions at that station. Therefore, when the arbiter station polls non-QoS session at a station, that station may substitute transmission of a QoS session.
Also, a station always sends some data in response to a poll unless the station has no pending data for any session of any class.
In this embodiment data in a communication session is transferred directly between stations without the intervention of the arbiter station (i.e., the arbiter station does not in general route data). A station receiving data responds directly after receiving the data with either an acknowledgment (ACK) or a negative acknowledgment (NACK) message to the sender indicating a correct or erroneous receipt of the data. If a NACK is received, or a timeout expires with neither an ACK nor a NACK's being received, a link layer retransmission protocol is used by the sending station to retransmit the data when that session is next polled. As the arbiter station can monitor transmission between any two stations, explicit acknowledgment of a polling message from the arbiter is not always needed. Moreover, by monitoring the transmission between any two stations participating in a session, the arbiter station can collect retransmission statistics about this session to estimate the achievable throughput between the two stations. These statistics are used by the resource manager to provide proper admission control and bandwidth allocation.
Fig. 2 shows the arrangement of the hardware components of a representative wireless station, in this case arbiter station 100a. General purpose CPU 106a executes application programs 210 and communication modules 212 stored in working memory 214 such as dynamic RAM. Non-volatile memory 216, typically a magnetic disk or read-only memory (ROM), is used to store application programs and communication modules prior to initialization of the station. CPU 106a communicates with network interface controller (NIC) 102a. In this embodiment, NIC 102a is coupled to CPU 106a using a PCMCIA bus. In other embodiments the NIC may be coupled to the CPU in any one of a variety of different ways including over an ISA bus, or a parallel or serial port.
NIC 102a includes a control processor 220 which communicates with CPU 106a. NIC 102a has a memory 228 which is used for data buffers 226, session state for active sessions 224, and media control modules 222 which execute on control processor 220.
Control processor 220 communicates with transceiver 230 which is coupled to antenna 104a. Transceiver 230 converts a baseband data signal into the radio frequency signal transmitted through antenna 104a and converts a radio signal received at antenna 104a into a baseband data signal. A variety of transceivers can be used in embodiments of the invention. For example, in this first embodiment, transceiver 230 includes a Harris Semiconductor "PRISM" chipset that includes a quadrature modem, a voltage controlled oscillator, an RF/IF
converter, a RF power amplifier with transmit/receive switch, and a low noise RF amplifier. The chipset implements a direct sequence (spread spectrum) transmission technique to reduce interference from other transmission sources.
Fig. 3 shows the arrangement of software modules on an arbiter station, such as station 100a shown in Fig. 1.
The arrangement of software modules on a non-arbiter station, such as stations 100b-d, is the same except that elements indicated with broken lines in Fig. 3 are not included. The description below of the elements shown in Fig. 3 is applicable to both arbiter and non-arbiter stations unless noted otherwise.
Application programs 210 include a graphical user interface (GUI) application 302 and communication applications 300. Communication applications 300 communicate with applications executing at other stations. GUI application 302 is used by a user to interactively control QoS requirements of communication sessions involving communication applications 300. Each session involves a single unidirectional data stream between two stations. Each QoS session that is admitted is promised either a minimum. data rate or a maximum delay between polling, or both. The arbiter station endeavors to maintain a promised minimum data rate, even during periods when the overall system capacity is reduced due, for example, to an interfering signal.
Each session communicates through a standard communication protocol stack 310, implementing in this embodiment TCP/IP and UDP/IP protocols. The stations operate using the Microsoft Windows 95 or Windows NT
operating system. Protocol stack 310 is provided by Microsoft Corporation for use with the Windows 95 and NT
operating systems. Application programs 210 communicate with protocol stack 310 using standard techniques for the Windows operating systems.
Protocol stack 310 communicates with the Network Driver Interface Specification (NDIS) driver 312 that provides the interface to media control modules 222 executing on the Network Interface Controller (NIC). In addition to providing a standard interface for higher layer protocols, an NDIS driver contains code that controls the NIC. Higher level protocols, implemented in protocol stack 310, use calls to the NDIS driver to submit data packets for transmission to the network or to retrieve data received from the network. When packets arrive from the network, media control modules 222 pass them to the low level controller code in the operating system which then calls NDIS driver routines to forward these packets for processing by protocol stack 310.
In this embodiment, protocol stack 310 does not have explicit provisions for supporting QoS sessions.
Therefore, a second control path is provided to NDIS
driver 312 through virtual device driver VxD 314. GUI
application 302 accepts control information from a user and passes this information through VxD 314 to NDIS
driver 312. For example, a user may specify using GUI
application 302 that all data streams addressed to a particular IP port (i.e., to a particular IP socket number on a remote host) on other stations have a particular minimum data rate and maximum delay requirement, and a maximum data rate that can be used.
This information is passed to NDIS driver 312 which in turn tags packets that arrive from protocol stack 310 and are transferred to media control modules 222. In this way, media control modules are able to differentiate between QoS and non-QoS sessions.
MAC 320 in media control modules 222 stores the data received from communication modules 212 in data buffers 226. Data buffers 226 include separate session buffers 330, one for each session.
MAC 320 waits to receive a Permission-To-Send (PTS) message initiated by a polling manager 324 at the arbiter station before sending data in data buffers 226. On a non-arbiter station, the MAC receives a PTS message from the polling manager on the arbiter station via the WLAN.
On the arbiter station, MAC 320 receives a PTS message directly from polling manager 324.
On the arbiter station, media control modules 222 include polling manager 324 and a resource manager 322.
Resource manager 322 maintains session state 224 which includes fixed and assigned session parameters 350 for each session, adaptive parameters 360 for each session, and retransmission rate estimates 362 for pairs of stations. Fixed parameters for a session may include the minimum achievable data rate required and the maximum achievable data rate that can be used by the session, as well as the maximum allowable delay, while the assigned parameters for a session include the assigned data rate.
Adaptive parameters 360 are used to track a session's actual communication pattern and to adjust the polling pattern to avoid unnecessary polling.
After describing the operation of the system when communication sessions have already been established and data rates assigned, we then describe the procedure for adapting to the pattern of data transmissions from individual stations, the procedure for assigning resources, and finally the procedure used to establish a new session.
Polling manager 324 at the arbiter station of the WLAN polls sessions on the stations in the WLAN by sending PTS messages for individual sessions to the MAC
on the station sending the session. If communication applications at a station have multiple active sessions for transmission to other stations, the polling manager polls the station separately for each session.
Referring to Fig. 4, the polling manager polls by repeating a fixed-duration polling cycle of duration Tcycle 410. During one cycle, there is a first QoS phase of duration T,.s 412, followed by a non-QoS phase of duration Tnon-Q.s 414. The durations of the QoS and non-QoS phases vary from cycle to cycle, but the sum of their durations remains fixed at Tcycle= During both phases of the cycle, the following sequence of transmissions is repeated:
a) The arbiter station transmits a Permission-to-Send (PTS) message that indicates which session is permitted to transmit;
b) The station that is sending that session either:
i) transmits a data packet for the indicated session, ii) transmits a data packet for some other session, or iii) transmits a Nothing-To-Send (NTS) message indicating that it has no data to transmit.
c) If the station transmits data in step b-i) or b-ii) and the data is received, the receiving station transmits either an ACK or a NACK, depending on whether the data was correctly received.
Before the arbiter station initiates the sequence for the next session, it waits to receive a NTS, ACK or NACK
message, or to time out, for example, due to the PTS, NTS, ACK or NACK message being lost.
During the first, QoS, phase, the PTS messages from the arbiter indicate QoS sessions, while the PTS messages in the second, non-QoS, phase indicate non-QoS sessions.
Note, however, that although a PTS message may indicate a QoS session in step a), data transmitted in step b-ii) may be for a non-QoS session if the transmitting station has no data buffered for QoS sessions. Similarly, a PTS
message indicating a non-QoS session in step a) may result in QoS sessions being transmitted in step b-ii) if the transmitting station has a backlog of data for QoS
sessions. The arbiter station monitors transmissions in step b) and repeats the sequence when the transmission in step b) terminates. During the first phase, the arbiter polls QoS sessions at most once. The polling restarts as soon as the cycle duration Tc,C1e elapses. If the polling of non-QoS sessions completes before the end of the cycle duration, the non-QoS sessions are polled again, terminating at the end of the cycle's duration.
Before returning to a discussion of Fig. 4, consider the flowchart in Fig. 6. A MAC receiving a PTS message for a session performs a series of tests to determine which data in its data buffers to transmit. Associated steps in the flowchart are indicated by the parenthesized numerals below. The MAC processing a PTS message for a session k first checks if session k is a QoS session (612). If it is, the MAC checks if there is data pending in the data buffers for session k (614) and if there is, transmits data for session k (616). If session k does not have pending data, a check is made if some other QoS
session j has pending data (618) and if there is, data for QoS session j is transmitted (620). If there are no pending QoS sessions, the MAC checks if there is a non-QoS session with pending data (622) and if there is, data for non-QoS session i is transmitted (624). If no data is pending for transmission, an NTS message is sent (626). If session k is a non-QoS session (612), a check is made if any QoS session j has pending data (630), and if it does, data from that session j is transmitted (632). Otherwise, if session k has pending data (634) data for session k is transmitted (636). If session k does not have pending data, data for some other non-QoS
session i is transmitted (624) or an NTS message is sent (626) if there is no pending data for any session.
In order to more fully understand the polling operation, consider the sequence of transmissions illustrated in Fig. 4. This example shows the arbiter polling eight active sessions originating at three stations, B, C and D. Sessions 1-4 are QoS sessions and sessions 5-8 are non-QoS sessions. The state of the sessions originating at each of the three stations in this example is as follows:
= Station B:
QoS session 1 has two pending data packets in its transmission buffer, - non-QoS session 5 has no data in its buffer.
= Station C:
- QoS session 2 has no data in its buffer, - non-QoS session 6 has no data in its buffer.
= Station D:
- QoS session 3 has no data in its buffer, - QoS session 4 has one pending data packet, - non-QoS session 7 has no data in its buffer, - non-QoS session 8 has a large amount of pending data.
The series of polling sequences is illustrated in Fig. 4. Each polling sequence includes a transmission of a PTS message (step a) followed by a transmission by the polled station (step b). The transmission of ACKs or NACKs (step c) is not shown in the figure. The series of these sequences is illustrated as follows. The parenthesized numerals refer to the transmissions illustrated in Fig. 4.
la. A PTS message for QoS session 1 is sent to station B (421).
lb. Station B sends data for session 1 (422).
2a. A PTS message for QoS session 2 is sent to station C (423).
2b. Station C has no data buffered for session 2.
Station C does not have any data buffered for any other QoS session, nor does it have data buffered for a non-QoS session. Station C
therefore responds with an NTS message (424).
3a. A PTS message for QoS session 3 is sent to station D (425).
3b. Station D has no data buffered for session 3.
It does however have data buffered for QoS
session 4 which it transmits (426).
4a. A PTS message for QoS session 4 is sent to station D (427).
4b. Station D had one pending data packet for session 4 at the beginning of the cycle, but it was already transmitted. Station D has no other pending QoS packets. It does have a non-QoS packet for session 8, which it transmits (428).
5a. A PTS message for non-QoS session 5 is sent to station B (429).
5b. Station B has pending QoS sessions for session 1 which it transmits (430).
6a. A PTS message for non-QoS session 6 is sent to station C (431).
6b. Station C has no pending data and therefore transmits an NTS message (432).
7a. A PTS message for non-QoS session 7 is sent to station D (433).
7b. Station D has no pending QoS sessions and no pending data for session 7. It does have pending data for non-QoS session 8 which it transmits (434).
8a. A PTS message for non-QoS session 8 is sent to station D (435) .
8b. Station D has no pending QoS sessions. It transmits a packet from non-QoS session 8 (436).
Before returning to a discussion of Fig. 4, consider the flowchart in Fig. 6. A MAC receiving a PTS message for a session performs a series of tests to determine which data in its data buffers to transmit. Associated steps in the flowchart are indicated by the parenthesized numerals below. The MAC processing a PTS message for a session k first checks if session k is a QoS session (612). If it is, the MAC checks if there is data pending in the data buffers for session k (614) and if there is, transmits data for session k (616). If session k does not have pending data, a check is made if some other QoS
session j has pending data (618) and if there is, data for QoS session j is transmitted (620). If there are no pending QoS sessions, the MAC checks if there is a non-QoS session with pending data (622) and if there is, data for non-QoS session i is transmitted (624). If no data is pending for transmission, an NTS message is sent (626). If session k is a non-QoS session (612), a check is made if any QoS session j has pending data (630), and if it does, data from that session j is transmitted (632). Otherwise, if session k has pending data (634) data for session k is transmitted (636). If session k does not have pending data, data for some other non-QoS
session i is transmitted (624) or an NTS message is sent (626) if there is no pending data for any session.
In order to more fully understand the polling operation, consider the sequence of transmissions illustrated in Fig. 4. This example shows the arbiter polling eight active sessions originating at three stations, B, C and D. Sessions 1-4 are QoS sessions and sessions 5-8 are non-QoS sessions. The state of the sessions originating at each of the three stations in this example is as follows:
= Station B:
QoS session 1 has two pending data packets in its transmission buffer, - non-QoS session 5 has no data in its buffer.
= Station C:
- QoS session 2 has no data in its buffer, - non-QoS session 6 has no data in its buffer.
= Station D:
- QoS session 3 has no data in its buffer, - QoS session 4 has one pending data packet, - non-QoS session 7 has no data in its buffer, - non-QoS session 8 has a large amount of pending data.
The series of polling sequences is illustrated in Fig. 4. Each polling sequence includes a transmission of a PTS message (step a) followed by a transmission by the polled station (step b). The transmission of ACKs or NACKs (step c) is not shown in the figure. The series of these sequences is illustrated as follows. The parenthesized numerals refer to the transmissions illustrated in Fig. 4.
la. A PTS message for QoS session 1 is sent to station B (421).
lb. Station B sends data for session 1 (422).
2a. A PTS message for QoS session 2 is sent to station C (423).
2b. Station C has no data buffered for session 2.
Station C does not have any data buffered for any other QoS session, nor does it have data buffered for a non-QoS session. Station C
therefore responds with an NTS message (424).
3a. A PTS message for QoS session 3 is sent to station D (425).
3b. Station D has no data buffered for session 3.
It does however have data buffered for QoS
session 4 which it transmits (426).
4a. A PTS message for QoS session 4 is sent to station D (427).
4b. Station D had one pending data packet for session 4 at the beginning of the cycle, but it was already transmitted. Station D has no other pending QoS packets. It does have a non-QoS packet for session 8, which it transmits (428).
5a. A PTS message for non-QoS session 5 is sent to station B (429).
5b. Station B has pending QoS sessions for session 1 which it transmits (430).
6a. A PTS message for non-QoS session 6 is sent to station C (431).
6b. Station C has no pending data and therefore transmits an NTS message (432).
7a. A PTS message for non-QoS session 7 is sent to station D (433).
7b. Station D has no pending QoS sessions and no pending data for session 7. It does have pending data for non-QoS session 8 which it transmits (434).
8a. A PTS message for non-QoS session 8 is sent to station D (435) .
8b. Station D has no pending QoS sessions. It transmits a packet from non-QoS session 8 (436).
9a. The cycle of non-QoS sessions repeats with a PTS message for non-QoS session 5 is sent to station B (437).
9b. Station B has no remaining pending QoS packets, and no pending non-QoS packets. Station B
therefore transmits an NTS message (438).
10a. A PTS message for non-QoS session 6 is sent to station C (439).
lob. Station C has no pending data and therefore transmits an NTS message (440). This transmission completes the cycle since the overall duration Tcycle has elapsed.
In this embodiment, the duration of the polling cycle, Tcycle, is fixed, as is the duration of any data message, Tdata= A session that is polled once every cycle therefore receives a fraction Tdata/Tcycle of the overall system capacity. For illustration, if the overall system communication rate is 1Mb/s, then Tdata=lms and Tcycle=4ms would yield a data rate of approximately 256kb/s for a session polled once every cycle. Such a choice for Tdata and Tcycie would support up to 4 sessions transmitting per cycle if PTS messages, NTS messages, and switching time between transmitting and receiving modes take essentially no time. As these other transmissions do take time, less than 4 sessions can transmit in practice for this choice of Tdata and Tcycie This embodiment includes a mechanism for avoiding unnecessary polling and thereby increasing the amount of each cycle used on average for data transmissions. For example, if the maximum session data rate is 256kb/s and a session is allocated 64kb/s, that session can be polled every fourth cycle and still be provided its allocated data rate. Each QoS session k has a session state index Sk, such that 1/Sk is equal to the fraction of cycles in which that session is to be polled. The value of Sk for a session is initially determined by the resource manager such that the session's allocated rate can be satisfied by the resulting polling pattern.
As introduced above, this embodiment also includes an adaptive mechanism that is used by the polling manager to adjust the polling pattern for a session in response to that session's actual data transmissions. If a session does not have data ready for transmission when polled, that session may not require polling as often in the future to support it's actual data rate. Similarly, when data for a session is provided in response to PTS
messages for another session, this is an indication that the session is backlogged and requires polling more often in the future.
Referring to Fig. 5, each session k is associated with a finite-state machine consisting of a chain of four states 501-504, having state values Sk equal to 1 through 4, respectively. If a session is in state Sk=11 that session is polled once during every cycle. If it is in state Sk=2, it is polled every other cycle, in state Sk=3, once every 3 cycles, and in state Sk=4, every 4 cycles.
In general, the state Sk of a session k is changed in two situations:
1) The state index Sk is reduced by 1 whenever a data packet for session k is transmitted in response to a PTS message for some other session, (state transitions 510) and 2) If session k is a QoS session, and a data packet for session k is not transmitted in response to a PTS message for session k, then the state index Sk is increased by 1 (state transitions 512).
Referring again to Fig. 4, the polling manager increases the state S2 for session 2 by 1 after transmission of NTS message 424 since no data is transmitted for session 2 in response to PTS message 423 indicating session 2. Similarly, the polling manager increases S3 by 1 after transmission of data 426 for session 4 in response to PTS message 425 indicating session 3. In addition, the polling manager reduces S4 by 1 after transmission of data packet 426 since data for QoS session 4 is transmitted by station D in response to PTS message 425 for a session other than session 4, session 3 in this case. Following the same rules, the polling manager increases S. by 1 after transmission of data packet 428, and reduces S1 by 1 after transmission of data packet 430. If a session is already in state 1, the state index is not reduced. Similarly, if the state index is at it's highest value, 4 in this embodiment, the state index is not increased.
In addition to limiting the state index to be in the range 1 to 4, the polling manager uses a supplementary policing mechanism to limit the rate of polling for a session. This policing mechanism determines the minimum state index that a session can be in. This limitation is imposed on a session by the polling manager when the session exceeded its allocated data rate for a period of time. For example, as illustrated in Fig. 5 by line 520, the polling manager does not allow the state for the session to go below 2 thereby limiting the peak data rate to M of the maximum session data rate. This prevents a session from using an unfair portion of the overall system data capacity. This limit is removed after the session does not exceed its allocated rate for a specified period of time.
In order to guarantee a maximum delay requirement, the state index of a session may be prevented from being too high. For example, if the duration of a cycle, Tcycle, is 4ms and a session requires a maximum delay of 15ms, then the state index must be 3 or less, as illustrated with line 530 in Fig. 5. If the state index were 4, the session would be polled once every four cycles, or every 16ms, which would not satisfy the maximum delay constraint.
Periodically, resource manager 322 (shown in Fig. 3) reallocates data rates for all sessions. If no new sessions have been admitted, reassignment may still be needed, for example due to changing transmission characteristics resulting in a new retransmission rate for some session.
Referring again to Fig. 3, GUI application 302 accepts QoS requirements for QoS sessions from a user.
In this embodiment, these include one or more of a minimum required data rate rk, a maximum data rate Rk, and a maximum delay Mk. These requirements are transmitted through VxD 314 and NDIS driver 312 to resource manager 322 at the arbiter station when a session is to be considered for admission and is stored in fixed and assigned parameters 350 for subsequent reallocation of data rates.
GUI application 302 accepts a quality of service requirement from a user for a session either by the user explicitly specifying the requirement for the session, such as by specifying a minimum data rate, or by choosing from a pre-determined set of classes of sessions. Such classes can be defined by a number of quality of service metrics, such as a maximum and minimum data rate, maximum delay, security, compression, or any other communication related parameters. When a specific class is chosen, GUI
application 302 translates the class into pre-determined parameter values or range of parameters values to that class.
Quality of service requirements can include security-based requirements. For example, three classes may be defined for security requirements: high security, medium security and low security. A high security class means that the data transmitted using very powerful encryption methods with appropriate authentication. Encryption may change the amount of data that needs to be transmitted or other parameters such as time delay. Therefore, the security requirements for a session are used to compute the raw transmission rate and other parameters needed to support the session.
Resource manager 322 also maintains retransmission rate estimates 362 for each pair of stations by monitoring transmissions between stations and noting when data is NACKed rather than ACKed, and when a timeout occurs waiting for transmission of a data packet or an ACK or NACK by a receiving station. For each admitted or considered session k, resource manager 322 computes Ak, the expected number of transmissions (including the initial transmission as well as retransmissions of a packet) per successful transmission. The resource manager then uses these retransmission rate estimates to determine the adjusted minimum and maximum data rates, denoted by dk=Akrk and Dk=AkRk respectively, for each session. Note that these adjusted rates may change in future reallocations as the retransmission rate estimates change. The resource manager assigns a rate Xk for each session k without exceeding the overall system data rate Uc. If Ek Dk < Uc, then all sessions can be allocated their maximum adjusted desired rates. If Ekdk > U, then there is no feasible solution of assigned rates that will give all the QoS sessions their minimum required rates.
Assuming a feasible solution exists, the resource manager assigns each session k a data rate Xk (not counting retransmissions) which satisfies rk s Xk s Rk. If a feasible solution exists but all sessions cannot be assigned their maximum desired rates, rates Xk are allocated such that the adjusted excess rates Xk beyond the minimum rates rk are assigned proportionally to the differences Rk-rk. That the is, excess rates Xk'=Xk-rk are proportional to Rk'=Rk-rk for all k. Therefore, if Uc' _ UC-Ek dk, then Xk = (1/Ak) (dk + Uc' (AkRk' /Ei AiRi')) .
If the resource manager cannot find a feasible set of assigned rates Xk, then it removes one or more QoS
sessions from the set of sessions polled during the first phase of each cycle. For example, sessions with the highest data rate requirements may be removed first.
In order to account for overhead due to factors such as header information in a data transmission and the time needed by transceivers to switch between receiving and transmitting modes, the total communication capacity U, is reduced from the transmission rate B using an efficiency factor E. To illustrate this, consider the situation as follows: the raw data rate is B=lMb/s; data transmissions are Tdata=lms in duration resulting in transmissions of length B= Tdata=lMb/s= lms=lkb; polling and acknowledgment messages are insignificant in duration; transceiver switching takes Tswitch=O.Olms and the transceiver switches twice per data transmission (i.e., once to switch from receiving to transmitting and once to switchback); and header information uses h=32b. In this situation, the efficiency factor is E=Tdata/ (Tdta+2 Tewitch) - (1+h/B- Tdata) which is approximately 95%.
After computing the allocated data rates, the rates and the maximum delay requirements are transferred from the resource manager to the polling manager. The initial state for each session is chosen so that the session is polled as infrequently as possible while still supporting the allocated rate and that satisfies the maximum delay requirement.
Referring again to Fig. 3, when one of the communicating applications 300 wants to establish a new session, it opens a data stream using protocol stack 310.
This request is transferred through the NDIS driver 312 and on to MAC 320. If the user wants the session to be a QoS session, the user provides QoS parameters to GUI
application 302 which communicates those parameters through VxD 314 and NDIS driver 312 to MAC 320. MAC 320 then waits to be queried by resource manager 322 at the arbiter station for requests to establish new sessions.
Periodically, resource manager 322 at the arbiter station queries the MACs at all stations for new QoS
sessions. Requests to establish QoS sessions are accompanied by QoS requirements including the minimum and maximum effective data rates rk and Rk required for the session.
Resource manager 322 at the arbiter station considers whether a feasible solution to the resource assignment problem can be obtained with the new QoS session being considered for admission into the system. If a feasible solution cannot be obtained which includes the new sessions, one or more of the requested QoS sessions is not admitted, for example in order of decreasing minimum required data rate, and a feasible solution is again attempted. This is repeated until a feasible solution is obtained. Therefore, at least at the time that a session is admitted, the resource manager expects that at least the minimum required data rate can be provided to all existing and newly admitted QoS sessions. The arbiter station communicates acceptance or rejection of a QoS
session to the MAC 320 on the requesting station, which in turn informs GUI application 302 through NDIS driver 312 and VxD 314.
When a session is closed by an application program, the sending station signals the end of the session to the arbiter station and no further resources are assigned to the session. Alternatively, if the sending station simply stops sending, the state index for the session will adapt to the highest value. After a predetermined time at that value during which time no data is transmitted for the session, the arbiter station notifies the sending station that the session has been terminated and frees resources associated with that session.
A second embodiment of the invention admits and allocates data rates for both QoS sessions and non-QoS
sessions according to an overall utility function. In addition to specifying minimum and maximum data rates rk and Rk for a session k, a user also specifies a priority (or utility) Pk for the session. In addition, non-QoS
sessions k also have requirements rk, Rk and Pk specified, although in general Pk is lower than that used for QoS
sessions, and rk may be zero if a sustained data rate is not required.
The overall utility function in this second embodiment is Ek PkXk. This utility function is maximized subject to the constraints that rk s Xk z Rk for all sessions k and Ek AkXk Z Uc. This Linear Programming formulation is a version of the well-known "knapsack"
problem. The optimal solution is found by ordering the sessions in descending order according to Pk/Ak. Sessions are allocated in order. Unless the communication capacity Uc is reached, each session receives it's maximum desired data rate Xk=Dk. The last session allocated receives whatever data rate is available (given that the data rate available is at least the minimum required data rate for the session) and the remaining sessions are allocated zero data rate. Note that since the retransmission rate Ak is considered as well as the priority Pk of a session, a high priority session with a high retransmission rate may not receive its required data rate while a low priority session with a low retransmission rate may.
In an alternative embodiment each session can have a penalty or cost Pk associated with it. An overall penalty function, of the same form as the overall utility function above, is minimized in this case.
Other embodiments involving optimization of an overall utility or penalty function can include other constraints. An example of other constraints would be reservation of a percentage of the overall communication rate for non-QoS sessions. In addition, other linear programming solution techniques can be employed to find feasible solutions.
Other embodiments of the invention can incorporate one or more of the following features. For example, the cycle time Tcycle can be modified during operation to reflect the highest data rate actually assigned to a session rather than remaining fixed.
QoS sessions can also be prioritized as in the second embodiment, but excess data rates beyond the minimum required for each session can be assigned first to the highest priority QoS sessions, rather than proportionally to the excess demands of all QoS sessions as in the first embodiment. Excess data rates can be assigned also to non-QoS sessions.
An alternative finite state machine can be used to adapt the polling pattern for a session. For example, the chain of states can be extended to a larger number of states than the four of the first embodiment. Also, transitions from a current state to a state with an index two or more smaller than the current state can be used allowing faster response to a QoS session that has a burst of transmissions. As an alternative to, or in addition to, changing the states of a session based on monitored transmissions for a session, the arbiter can use other statistics related to that session. For example, a station can provide the number of pending packets for a session (queue length) and the arbiter can reduce the state by one or more (i.e., increase the frequency of polling) for that session if the queue length is high. This allows the polling pattern for a session to be adapted by the arbiter more quickly than if the monitored transmission pattern from the station were used alone. Other statistics, such as maximum delay or age of packets in a session's queue can also be used.
The station can provide session-related statistics in response to an arbiter's polling, or in some other way such as indicating the statistics for a session with data messages for that session.
A variable amount of data can be transmitted by a station in response to a poll. In one approach, the arbiter station sends a station group polling message to permit a station to transmit data packets for each of a set of sessions rather than sending a separate polling message for each session. In another approach, the arbiter sends a system group polling message which is received by all stations. The stations each transmit data for their sessions in turn. The stations transmit in a prescribed order and each station waits for the previous station in the order to complete its transmissions before transmitting.
In the situation that a previously admitted QoS
session cannot be accommodated in a feasible solution when data rates are reassigned by resource manager 322, the sending station can be informed that a previously admitted session has been ejected. The application program associated with that session can then take appropriate action. In addition, it is possible if sessions are prioritized, that a request for admitting a new QoS session results in that session being admitted but some other previously admitted but lower priority session being ejected.
In yet another embodiment, although at any one time there is'a single arbiter station, one or more stations perform the identical resource assignment procedure in parallel and function as shadow arbiter stations. In this way, these stations are able to become the arbiter station if for some reason the arbiter station cannot serve that role.
In the embodiments described above, the arbiter station can also execute application programs. The arbiter station can also solely serve the role of an arbiter station without the ability to execute application programs. In addition, such a dedicated arbiter station can also serve a gateway role to another network, such as a wired LAN.
The stations do not necessarily communicate directly with one another. For example, in an application such as a use of wireless communication for the local loop of a telephone system to fixed locations, an arbiter can poll a station at each location and that station can communicate with the arbiter.
In other applications, multicast transmission may be used to reach a number of stations with the same communication session. Bandwidth is allocated as in the point-to-point case described previously with the exception that the worst-case retransmission rate is used to estimate the bandwidth needed to sustain the required actual data rate.
As support for QoS requirements is introduced into standard communication protocol stacks, such as into protocol stack 310 in Fig. 3, applications may be able to specify QoS requirements directly. In that case, GUI
application 302 and VxD 314 would not be needed to provide QoS requirements. Media control modules 222 in Fig. 3 would operate as in the above embodiments.
Other embodiments can have any of a variety of hardware configurations at the stations. For example, a single processor can serve the roles of the CPU 106a and control processor 220 shown in Fig. 2.
Alternative arrangements of processors, memory, and other hardware components can be used. Referring to Fig.
2, NIC 102a includes a control processor 220 which implements the media control protocol. Alternatively, some or all of the functions implemented using control processor 220 and memory 228 can be implemented on a general purpose computer, such as a CPU 106a and memory 108a.
One particular alternative hardware arrangement uses a standard network interface controller for a broadcast medium such as a controller for wired Ethernet IEEE 802.3 based communication, or a controller for wireless IEEE
802.11 based communication. Other modules, such as polling manager 324 (Fig. 3) and resource manager 322, are then implemented using the general purpose processor which is coupled to the standard network interface controller.
Other embodiments of the invention can use both higher and lower radio frequency ranges, as well as optical frequencies such as in the infra-red range, and may be applicable to other shared access channels that may share a communication medium other than air such as a conductor not dedicated for network communication. Also, frequency hopping spread spectrum may be used instead of direct sequence spread spectrum. In addition, the polling approach is not limited to wireless situations.
For example, the polling approach is also useful for shared access wired networks. Other embodiments may also include media control (that is, a polling manager and resource manager) for multiple communication channels.
For example, an arbiter station may concurrently control concurrent spread spectrum transmissions which use different hopping patterns of code sequences.
9b. Station B has no remaining pending QoS packets, and no pending non-QoS packets. Station B
therefore transmits an NTS message (438).
10a. A PTS message for non-QoS session 6 is sent to station C (439).
lob. Station C has no pending data and therefore transmits an NTS message (440). This transmission completes the cycle since the overall duration Tcycle has elapsed.
In this embodiment, the duration of the polling cycle, Tcycle, is fixed, as is the duration of any data message, Tdata= A session that is polled once every cycle therefore receives a fraction Tdata/Tcycle of the overall system capacity. For illustration, if the overall system communication rate is 1Mb/s, then Tdata=lms and Tcycle=4ms would yield a data rate of approximately 256kb/s for a session polled once every cycle. Such a choice for Tdata and Tcycie would support up to 4 sessions transmitting per cycle if PTS messages, NTS messages, and switching time between transmitting and receiving modes take essentially no time. As these other transmissions do take time, less than 4 sessions can transmit in practice for this choice of Tdata and Tcycie This embodiment includes a mechanism for avoiding unnecessary polling and thereby increasing the amount of each cycle used on average for data transmissions. For example, if the maximum session data rate is 256kb/s and a session is allocated 64kb/s, that session can be polled every fourth cycle and still be provided its allocated data rate. Each QoS session k has a session state index Sk, such that 1/Sk is equal to the fraction of cycles in which that session is to be polled. The value of Sk for a session is initially determined by the resource manager such that the session's allocated rate can be satisfied by the resulting polling pattern.
As introduced above, this embodiment also includes an adaptive mechanism that is used by the polling manager to adjust the polling pattern for a session in response to that session's actual data transmissions. If a session does not have data ready for transmission when polled, that session may not require polling as often in the future to support it's actual data rate. Similarly, when data for a session is provided in response to PTS
messages for another session, this is an indication that the session is backlogged and requires polling more often in the future.
Referring to Fig. 5, each session k is associated with a finite-state machine consisting of a chain of four states 501-504, having state values Sk equal to 1 through 4, respectively. If a session is in state Sk=11 that session is polled once during every cycle. If it is in state Sk=2, it is polled every other cycle, in state Sk=3, once every 3 cycles, and in state Sk=4, every 4 cycles.
In general, the state Sk of a session k is changed in two situations:
1) The state index Sk is reduced by 1 whenever a data packet for session k is transmitted in response to a PTS message for some other session, (state transitions 510) and 2) If session k is a QoS session, and a data packet for session k is not transmitted in response to a PTS message for session k, then the state index Sk is increased by 1 (state transitions 512).
Referring again to Fig. 4, the polling manager increases the state S2 for session 2 by 1 after transmission of NTS message 424 since no data is transmitted for session 2 in response to PTS message 423 indicating session 2. Similarly, the polling manager increases S3 by 1 after transmission of data 426 for session 4 in response to PTS message 425 indicating session 3. In addition, the polling manager reduces S4 by 1 after transmission of data packet 426 since data for QoS session 4 is transmitted by station D in response to PTS message 425 for a session other than session 4, session 3 in this case. Following the same rules, the polling manager increases S. by 1 after transmission of data packet 428, and reduces S1 by 1 after transmission of data packet 430. If a session is already in state 1, the state index is not reduced. Similarly, if the state index is at it's highest value, 4 in this embodiment, the state index is not increased.
In addition to limiting the state index to be in the range 1 to 4, the polling manager uses a supplementary policing mechanism to limit the rate of polling for a session. This policing mechanism determines the minimum state index that a session can be in. This limitation is imposed on a session by the polling manager when the session exceeded its allocated data rate for a period of time. For example, as illustrated in Fig. 5 by line 520, the polling manager does not allow the state for the session to go below 2 thereby limiting the peak data rate to M of the maximum session data rate. This prevents a session from using an unfair portion of the overall system data capacity. This limit is removed after the session does not exceed its allocated rate for a specified period of time.
In order to guarantee a maximum delay requirement, the state index of a session may be prevented from being too high. For example, if the duration of a cycle, Tcycle, is 4ms and a session requires a maximum delay of 15ms, then the state index must be 3 or less, as illustrated with line 530 in Fig. 5. If the state index were 4, the session would be polled once every four cycles, or every 16ms, which would not satisfy the maximum delay constraint.
Periodically, resource manager 322 (shown in Fig. 3) reallocates data rates for all sessions. If no new sessions have been admitted, reassignment may still be needed, for example due to changing transmission characteristics resulting in a new retransmission rate for some session.
Referring again to Fig. 3, GUI application 302 accepts QoS requirements for QoS sessions from a user.
In this embodiment, these include one or more of a minimum required data rate rk, a maximum data rate Rk, and a maximum delay Mk. These requirements are transmitted through VxD 314 and NDIS driver 312 to resource manager 322 at the arbiter station when a session is to be considered for admission and is stored in fixed and assigned parameters 350 for subsequent reallocation of data rates.
GUI application 302 accepts a quality of service requirement from a user for a session either by the user explicitly specifying the requirement for the session, such as by specifying a minimum data rate, or by choosing from a pre-determined set of classes of sessions. Such classes can be defined by a number of quality of service metrics, such as a maximum and minimum data rate, maximum delay, security, compression, or any other communication related parameters. When a specific class is chosen, GUI
application 302 translates the class into pre-determined parameter values or range of parameters values to that class.
Quality of service requirements can include security-based requirements. For example, three classes may be defined for security requirements: high security, medium security and low security. A high security class means that the data transmitted using very powerful encryption methods with appropriate authentication. Encryption may change the amount of data that needs to be transmitted or other parameters such as time delay. Therefore, the security requirements for a session are used to compute the raw transmission rate and other parameters needed to support the session.
Resource manager 322 also maintains retransmission rate estimates 362 for each pair of stations by monitoring transmissions between stations and noting when data is NACKed rather than ACKed, and when a timeout occurs waiting for transmission of a data packet or an ACK or NACK by a receiving station. For each admitted or considered session k, resource manager 322 computes Ak, the expected number of transmissions (including the initial transmission as well as retransmissions of a packet) per successful transmission. The resource manager then uses these retransmission rate estimates to determine the adjusted minimum and maximum data rates, denoted by dk=Akrk and Dk=AkRk respectively, for each session. Note that these adjusted rates may change in future reallocations as the retransmission rate estimates change. The resource manager assigns a rate Xk for each session k without exceeding the overall system data rate Uc. If Ek Dk < Uc, then all sessions can be allocated their maximum adjusted desired rates. If Ekdk > U, then there is no feasible solution of assigned rates that will give all the QoS sessions their minimum required rates.
Assuming a feasible solution exists, the resource manager assigns each session k a data rate Xk (not counting retransmissions) which satisfies rk s Xk s Rk. If a feasible solution exists but all sessions cannot be assigned their maximum desired rates, rates Xk are allocated such that the adjusted excess rates Xk beyond the minimum rates rk are assigned proportionally to the differences Rk-rk. That the is, excess rates Xk'=Xk-rk are proportional to Rk'=Rk-rk for all k. Therefore, if Uc' _ UC-Ek dk, then Xk = (1/Ak) (dk + Uc' (AkRk' /Ei AiRi')) .
If the resource manager cannot find a feasible set of assigned rates Xk, then it removes one or more QoS
sessions from the set of sessions polled during the first phase of each cycle. For example, sessions with the highest data rate requirements may be removed first.
In order to account for overhead due to factors such as header information in a data transmission and the time needed by transceivers to switch between receiving and transmitting modes, the total communication capacity U, is reduced from the transmission rate B using an efficiency factor E. To illustrate this, consider the situation as follows: the raw data rate is B=lMb/s; data transmissions are Tdata=lms in duration resulting in transmissions of length B= Tdata=lMb/s= lms=lkb; polling and acknowledgment messages are insignificant in duration; transceiver switching takes Tswitch=O.Olms and the transceiver switches twice per data transmission (i.e., once to switch from receiving to transmitting and once to switchback); and header information uses h=32b. In this situation, the efficiency factor is E=Tdata/ (Tdta+2 Tewitch) - (1+h/B- Tdata) which is approximately 95%.
After computing the allocated data rates, the rates and the maximum delay requirements are transferred from the resource manager to the polling manager. The initial state for each session is chosen so that the session is polled as infrequently as possible while still supporting the allocated rate and that satisfies the maximum delay requirement.
Referring again to Fig. 3, when one of the communicating applications 300 wants to establish a new session, it opens a data stream using protocol stack 310.
This request is transferred through the NDIS driver 312 and on to MAC 320. If the user wants the session to be a QoS session, the user provides QoS parameters to GUI
application 302 which communicates those parameters through VxD 314 and NDIS driver 312 to MAC 320. MAC 320 then waits to be queried by resource manager 322 at the arbiter station for requests to establish new sessions.
Periodically, resource manager 322 at the arbiter station queries the MACs at all stations for new QoS
sessions. Requests to establish QoS sessions are accompanied by QoS requirements including the minimum and maximum effective data rates rk and Rk required for the session.
Resource manager 322 at the arbiter station considers whether a feasible solution to the resource assignment problem can be obtained with the new QoS session being considered for admission into the system. If a feasible solution cannot be obtained which includes the new sessions, one or more of the requested QoS sessions is not admitted, for example in order of decreasing minimum required data rate, and a feasible solution is again attempted. This is repeated until a feasible solution is obtained. Therefore, at least at the time that a session is admitted, the resource manager expects that at least the minimum required data rate can be provided to all existing and newly admitted QoS sessions. The arbiter station communicates acceptance or rejection of a QoS
session to the MAC 320 on the requesting station, which in turn informs GUI application 302 through NDIS driver 312 and VxD 314.
When a session is closed by an application program, the sending station signals the end of the session to the arbiter station and no further resources are assigned to the session. Alternatively, if the sending station simply stops sending, the state index for the session will adapt to the highest value. After a predetermined time at that value during which time no data is transmitted for the session, the arbiter station notifies the sending station that the session has been terminated and frees resources associated with that session.
A second embodiment of the invention admits and allocates data rates for both QoS sessions and non-QoS
sessions according to an overall utility function. In addition to specifying minimum and maximum data rates rk and Rk for a session k, a user also specifies a priority (or utility) Pk for the session. In addition, non-QoS
sessions k also have requirements rk, Rk and Pk specified, although in general Pk is lower than that used for QoS
sessions, and rk may be zero if a sustained data rate is not required.
The overall utility function in this second embodiment is Ek PkXk. This utility function is maximized subject to the constraints that rk s Xk z Rk for all sessions k and Ek AkXk Z Uc. This Linear Programming formulation is a version of the well-known "knapsack"
problem. The optimal solution is found by ordering the sessions in descending order according to Pk/Ak. Sessions are allocated in order. Unless the communication capacity Uc is reached, each session receives it's maximum desired data rate Xk=Dk. The last session allocated receives whatever data rate is available (given that the data rate available is at least the minimum required data rate for the session) and the remaining sessions are allocated zero data rate. Note that since the retransmission rate Ak is considered as well as the priority Pk of a session, a high priority session with a high retransmission rate may not receive its required data rate while a low priority session with a low retransmission rate may.
In an alternative embodiment each session can have a penalty or cost Pk associated with it. An overall penalty function, of the same form as the overall utility function above, is minimized in this case.
Other embodiments involving optimization of an overall utility or penalty function can include other constraints. An example of other constraints would be reservation of a percentage of the overall communication rate for non-QoS sessions. In addition, other linear programming solution techniques can be employed to find feasible solutions.
Other embodiments of the invention can incorporate one or more of the following features. For example, the cycle time Tcycle can be modified during operation to reflect the highest data rate actually assigned to a session rather than remaining fixed.
QoS sessions can also be prioritized as in the second embodiment, but excess data rates beyond the minimum required for each session can be assigned first to the highest priority QoS sessions, rather than proportionally to the excess demands of all QoS sessions as in the first embodiment. Excess data rates can be assigned also to non-QoS sessions.
An alternative finite state machine can be used to adapt the polling pattern for a session. For example, the chain of states can be extended to a larger number of states than the four of the first embodiment. Also, transitions from a current state to a state with an index two or more smaller than the current state can be used allowing faster response to a QoS session that has a burst of transmissions. As an alternative to, or in addition to, changing the states of a session based on monitored transmissions for a session, the arbiter can use other statistics related to that session. For example, a station can provide the number of pending packets for a session (queue length) and the arbiter can reduce the state by one or more (i.e., increase the frequency of polling) for that session if the queue length is high. This allows the polling pattern for a session to be adapted by the arbiter more quickly than if the monitored transmission pattern from the station were used alone. Other statistics, such as maximum delay or age of packets in a session's queue can also be used.
The station can provide session-related statistics in response to an arbiter's polling, or in some other way such as indicating the statistics for a session with data messages for that session.
A variable amount of data can be transmitted by a station in response to a poll. In one approach, the arbiter station sends a station group polling message to permit a station to transmit data packets for each of a set of sessions rather than sending a separate polling message for each session. In another approach, the arbiter sends a system group polling message which is received by all stations. The stations each transmit data for their sessions in turn. The stations transmit in a prescribed order and each station waits for the previous station in the order to complete its transmissions before transmitting.
In the situation that a previously admitted QoS
session cannot be accommodated in a feasible solution when data rates are reassigned by resource manager 322, the sending station can be informed that a previously admitted session has been ejected. The application program associated with that session can then take appropriate action. In addition, it is possible if sessions are prioritized, that a request for admitting a new QoS session results in that session being admitted but some other previously admitted but lower priority session being ejected.
In yet another embodiment, although at any one time there is'a single arbiter station, one or more stations perform the identical resource assignment procedure in parallel and function as shadow arbiter stations. In this way, these stations are able to become the arbiter station if for some reason the arbiter station cannot serve that role.
In the embodiments described above, the arbiter station can also execute application programs. The arbiter station can also solely serve the role of an arbiter station without the ability to execute application programs. In addition, such a dedicated arbiter station can also serve a gateway role to another network, such as a wired LAN.
The stations do not necessarily communicate directly with one another. For example, in an application such as a use of wireless communication for the local loop of a telephone system to fixed locations, an arbiter can poll a station at each location and that station can communicate with the arbiter.
In other applications, multicast transmission may be used to reach a number of stations with the same communication session. Bandwidth is allocated as in the point-to-point case described previously with the exception that the worst-case retransmission rate is used to estimate the bandwidth needed to sustain the required actual data rate.
As support for QoS requirements is introduced into standard communication protocol stacks, such as into protocol stack 310 in Fig. 3, applications may be able to specify QoS requirements directly. In that case, GUI
application 302 and VxD 314 would not be needed to provide QoS requirements. Media control modules 222 in Fig. 3 would operate as in the above embodiments.
Other embodiments can have any of a variety of hardware configurations at the stations. For example, a single processor can serve the roles of the CPU 106a and control processor 220 shown in Fig. 2.
Alternative arrangements of processors, memory, and other hardware components can be used. Referring to Fig.
2, NIC 102a includes a control processor 220 which implements the media control protocol. Alternatively, some or all of the functions implemented using control processor 220 and memory 228 can be implemented on a general purpose computer, such as a CPU 106a and memory 108a.
One particular alternative hardware arrangement uses a standard network interface controller for a broadcast medium such as a controller for wired Ethernet IEEE 802.3 based communication, or a controller for wireless IEEE
802.11 based communication. Other modules, such as polling manager 324 (Fig. 3) and resource manager 322, are then implemented using the general purpose processor which is coupled to the standard network interface controller.
Other embodiments of the invention can use both higher and lower radio frequency ranges, as well as optical frequencies such as in the infra-red range, and may be applicable to other shared access channels that may share a communication medium other than air such as a conductor not dedicated for network communication. Also, frequency hopping spread spectrum may be used instead of direct sequence spread spectrum. In addition, the polling approach is not limited to wireless situations.
For example, the polling approach is also useful for shared access wired networks. Other embodiments may also include media control (that is, a polling manager and resource manager) for multiple communication channels.
For example, an arbiter station may concurrently control concurrent spread spectrum transmissions which use different hopping patterns of code sequences.
Other embodiments are within the scope of the present invention.
Claims (39)
1. A method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources including data rates in accordance with the data rate requirements of a plurality of sessions in the quality of service class including optimizing a utility function subject to a set of constraints;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein the data rate requirements include minimum required and maximum desired data rates for the plurality of sessions in the quality of service class, the utility function depends on the assigned rates, and the set of constraints includes the assigned rate for each admitted session being in a range from its minimum required data rate to its maximum desired data rate and the assigned data rates taken together not exceeding an available communication capacity.
assigning communication resources including data rates in accordance with the data rate requirements of a plurality of sessions in the quality of service class including optimizing a utility function subject to a set of constraints;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein the data rate requirements include minimum required and maximum desired data rates for the plurality of sessions in the quality of service class, the utility function depends on the assigned rates, and the set of constraints includes the assigned rate for each admitted session being in a range from its minimum required data rate to its maximum desired data rate and the assigned data rates taken together not exceeding an available communication capacity.
2. A method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources including data rates in accordance with the data rate requirements of a plurality of sessions in the quality of service class;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling the stations includes polling sessions with lower assigned data rates less frequently than stations with higher assigned data rates.
assigning communication resources including data rates in accordance with the data rate requirements of a plurality of sessions in the quality of service class;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling the stations includes polling sessions with lower assigned data rates less frequently than stations with higher assigned data rates.
3. A method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein adapting the polling sequence includes reducing the rate of polling for a session in response the monitored transmissions for that session corresponding to a reduction in actual rate of transmission for that session, and increasing the rate of polling for a session in response the monitored transmissions for that session corresponding to an increase in actual rate of transmission for that session.
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein adapting the polling sequence includes reducing the rate of polling for a session in response the monitored transmissions for that session corresponding to a reduction in actual rate of transmission for that session, and increasing the rate of polling for a session in response the monitored transmissions for that session corresponding to an increase in actual rate of transmission for that session.
4. A method for media access control in a communication network which includes a plurality of communication stations which communicate over a shared communication medium and which supports a quality of service class of communication sessions such that sessions in that class have data rate requirements, comprising:
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling is performed in a periodic cycle and during each period of the cycle a subset of the sessions in the quality of service class are polled in accordance with their allocated communication resources, and the polling sequence is determined by the values of a plurality of state variables, each associated with a corresponding session, and adapting the polling sequence is effected by changing the values of the state variable.
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling is performed in a periodic cycle and during each period of the cycle a subset of the sessions in the quality of service class are polled in accordance with their allocated communication resources, and the polling sequence is determined by the values of a plurality of state variables, each associated with a corresponding session, and adapting the polling sequence is effected by changing the values of the state variable.
5. An apparatus for polling a plurality of stations configured to communicate over a shared communication medium in a communication network comprising:
a polling manager which sends polling messages to the stations in the network in accordance with a polling sequence;
a transmitter which accepts polling messages from the polling manager and transmits the messages over the shared communication medium to the stations; and a receiver which receives messages over the shared communication medium from the stations and provides monitoring information to the polling manager;
a resource manager which accepts requests to admit communication sessions and provides resource allocations for admitted sessions to the polling manager; and a plurality of state indices associated with corresponding admitted sessions;
wherein the polling manager adapts the polling sequence in accordance with the monitoring information, and initializes the state indices in accordance with the resource allocations, updates the state indices in accordance with the monitoring information, and determines the polling sequence in accordance with the state indices.
a polling manager which sends polling messages to the stations in the network in accordance with a polling sequence;
a transmitter which accepts polling messages from the polling manager and transmits the messages over the shared communication medium to the stations; and a receiver which receives messages over the shared communication medium from the stations and provides monitoring information to the polling manager;
a resource manager which accepts requests to admit communication sessions and provides resource allocations for admitted sessions to the polling manager; and a plurality of state indices associated with corresponding admitted sessions;
wherein the polling manager adapts the polling sequence in accordance with the monitoring information, and initializes the state indices in accordance with the resource allocations, updates the state indices in accordance with the monitoring information, and determines the polling sequence in accordance with the state indices.
6. A computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of communication stations which communicate over a shared communication medium in a communication network, to perform the functions:
assigning communication resources including data rates in accordance with data rate requirements of a plurality of sessions in a quality of service class including optimizing a utility function subject to a set of constraints;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein the data rate requirements include minimum required and maximum desired data rates for the plurality of sessions in the quality of service class, the utility function depends on the assigned rates, and the set of constraints includes the assigned rate for each admitted session being in a range from its minimum required data rate to its maximum desired data rate and the assigned data rates taken together not exceeding an available communication capacity.
assigning communication resources including data rates in accordance with data rate requirements of a plurality of sessions in a quality of service class including optimizing a utility function subject to a set of constraints;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein the data rate requirements include minimum required and maximum desired data rates for the plurality of sessions in the quality of service class, the utility function depends on the assigned rates, and the set of constraints includes the assigned rate for each admitted session being in a range from its minimum required data rate to its maximum desired data rate and the assigned data rates taken together not exceeding an available communication capacity.
7. A computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of communication stations which communicate over a shared communication medium in a communication network, to perform the functions:
assigning communication resources including data rates in accordance with data rate requirements of a plurality of sessions in a quality of service class including optimizing a utility function subject to a set of constraints;
polling the communication stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling the stations includes polling sessions with lower assigned data rates less frequently than stations with higher assigned data rates.
assigning communication resources including data rates in accordance with data rate requirements of a plurality of sessions in a quality of service class including optimizing a utility function subject to a set of constraints;
polling the communication stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling the stations includes polling sessions with lower assigned data rates less frequently than stations with higher assigned data rates.
8. A computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of communication stations which communicate over a shared communication medium in a communication network, to perform the functions:
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein adapting the polling sequence includes reducing the rate of polling for a session in response the monitored transmissions for that session corresponding to a reduction in actual rate of transmission for that session, and increasing the rate of polling for a session in response the monitored transmissions for that session corresponding to an increase in actual rate of transmission for that session.
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein adapting the polling sequence includes reducing the rate of polling for a session in response the monitored transmissions for that session corresponding to a reduction in actual rate of transmission for that session, and increasing the rate of polling for a session in response the monitored transmissions for that session corresponding to an increase in actual rate of transmission for that session.
9. A computer readable medium on which is stored a set of instructions which, when executed, cause a computer, which is coupled to a plurality of communication stations which communicate over a shared communication medium in a communication network, to perform the functions:
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling is performed in a periodic cycle and during each period of the cycle a subset of the sessions in the quality of service class are polled in accordance with their allocated communication resources, and the polling sequence is determined by the values of a plurality of state variables, each associated with a corresponding session, and adapting the polling sequence is effected by changing the values of the state variable.
assigning communication resources in accordance with the data rate requirements of a plurality of sessions in the quality of service class;
polling the stations to transmit data over the shared communication medium for particular ones of the plurality of sessions according to a polling sequence;
monitoring data transmitted by the stations in response to the polling; and adaptively allocating the communication resources in accordance with the monitored data transmissions including adapting the polling sequence;
wherein polling is performed in a periodic cycle and during each period of the cycle a subset of the sessions in the quality of service class are polled in accordance with their allocated communication resources, and the polling sequence is determined by the values of a plurality of state variables, each associated with a corresponding session, and adapting the polling sequence is effected by changing the values of the state variable.
10. A method for media access control in a communication system which includes a plurality of communication stations which communicate over a shared communication medium, the method comprising:
assigning communication resources in accordance with quality of service requirements of a plurality of communication sessions, including determining a polling pattern;
polling each of a plurality of communication stations to transmit data over a shared communication medium for the plurality of communication sessions according to the polling pattern;
monitoring data transmitted by the communication stations in response to the polling; and adapting assignment of the communication resources in accordance with the monitoring, including adapting the polling pattern for one or more of the communication sessions, wherein adapting the polling pattern includes reducing a rate of polling for the session if the session is not utilizing assigned communication resources; or increasing a rate of polling for the session if the session is utilizing more than the assigned communication resources.
assigning communication resources in accordance with quality of service requirements of a plurality of communication sessions, including determining a polling pattern;
polling each of a plurality of communication stations to transmit data over a shared communication medium for the plurality of communication sessions according to the polling pattern;
monitoring data transmitted by the communication stations in response to the polling; and adapting assignment of the communication resources in accordance with the monitoring, including adapting the polling pattern for one or more of the communication sessions, wherein adapting the polling pattern includes reducing a rate of polling for the session if the session is not utilizing assigned communication resources; or increasing a rate of polling for the session if the session is utilizing more than the assigned communication resources.
11. The method of claim 10 further comprising:
admitting a new communication session if a quality of service requirement for the new session can be provided without exceeding a limit on available communication resources on the shared communication medium; and rejecting the new communication session if the quality of service requirement cannot be provided without exceeding the limit on available communication resources.
admitting a new communication session if a quality of service requirement for the new session can be provided without exceeding a limit on available communication resources on the shared communication medium; and rejecting the new communication session if the quality of service requirement cannot be provided without exceeding the limit on available communication resources.
12. The method of claim 10 wherein assigning communication resources in accordance with the quality of service requirements includes assigning the communication resources according to data rate requirements for the plurality of communication sessions.
13. The method of claim 12 wherein assigning communication resources includes:
determining a subset of the plurality of communication sessions that can be provided with data rate requirements required by the respective session;
and assigning data rates to each of the subset of sessions in accordance with the data rate requirements.
determining a subset of the plurality of communication sessions that can be provided with data rate requirements required by the respective session;
and assigning data rates to each of the subset of sessions in accordance with the data rate requirements.
14. The method of claim 13 wherein monitoring data transmission includes collecting data retransmission statistics; and assigning communication resources includes adjusting data rate requirements in accordance with the collected retransmission statistics.
15. The method of claim 12 wherein assigning communication resources includes optimizing a utility function subject to a set of constraints.
16. The method of claim 10 wherein assigning communication resources in accordance with the quality of service requirements includes assigning the communication resources according to maximum intervals between polling of the plurality of sessions.
17. The method of claim 10 wherein the polling pattern includes a periodic cycle such that during each period of the cycle a subset of the communication sessions are polled in accordance with their allocated communication resources.
18. The method of claim 10 wherein polling the communication stations to transmit data for the plurality of communication sessions includes:
assembling a data message identifying at least one of the communication sessions; and transmitting the data message to one of the communication stations using a wireless transmitter, wherein monitoring data transmitted by the communication stations includes receiving the data transmissions using a wireless receiver.
assembling a data message identifying at least one of the communication sessions; and transmitting the data message to one of the communication stations using a wireless transmitter, wherein monitoring data transmitted by the communication stations includes receiving the data transmissions using a wireless receiver.
19. The method of claim 18 wherein assigning the communication resources is performed at a designated arbiter station, and wherein transmitting the data message includes transmitting the data message from the arbiter station to one or more of the communication stations.
20. The method of claim 19 wherein assigning the communication resources is additionally performed at one or more of the communication stations, and wherein the method further comprises designating one of the one or more communication stations to assume the role of the arbiter station.
21. The method of claim 10 further comprising receiving statistics related to the communication session, wherein adapting assignment of the communication resources further includes allocating the communication resources in accordance with the received statistics.
22. The method of claim 21 wherein the statistics related to the session includes a queue length for a session, and wherein adapting assignment of the communication resources includes adapting the polling sequence based on the queue length.
23. The method of claim 10 wherein assigning communication resources in accordance with the quality of service requirements includes assigning the communication resources according to maximum delay requirements of the plurality of communication sessions.
24. The method of claim 10 wherein polling the communication stations to transmit data includes:
assembling a data message identifying a two or more communication sessions originating at two or more of the communication stations and identifying time intervals during which the communication stations are permitted to transmit data over the shared communication medium; and initiating transmission of the data message to the two or more communication stations.
assembling a data message identifying a two or more communication sessions originating at two or more of the communication stations and identifying time intervals during which the communication stations are permitted to transmit data over the shared communication medium; and initiating transmission of the data message to the two or more communication stations.
25. The method of claim 10 wherein assigning communication resources includes assigning communication resources for each of a plurality of communication channels on the shared communication medium.
26. The method of claim 25 wherein assigning communication resources for each of the plurality of communication channels includes determining a separate polling pattern for each of the channels.
27. The method of claim 10 wherein the communication system includes a distributed telecommunication system.
28. The method of claim 27 wherein the distributed telecommunication system is a wireless local loop system.
29. An apparatus for controlling media access by a plurality of stations configured to communicate over a shared communication medium in a communication system, the apparatus comprising:
means for assigning communication resources based on quality of service requirements of a plurality of communication sessions, including means for determining a polling pattern;
means for polling each of the communication stations to transmit data over a shared communication medium for the plurality of communication sessions according to the polling pattern;
means for monitoring data transmitted by the communication stations in response to the polling; and means for adapting assignment of the communication resources based on the monitored data, including adapting the polling pattern for one or more of the communication sessions, wherein adapting the polling pattern comprises:
reducing a rate of polling for a specific session if the session is not utilizing assigned communication resources, thereby reducing an actual rate of transmission for that session; or increasing a rate of polling for the specific session if the session is utilizing more than the assigned communication resources, thereby increasing an actual rate of transmission for that session.
means for assigning communication resources based on quality of service requirements of a plurality of communication sessions, including means for determining a polling pattern;
means for polling each of the communication stations to transmit data over a shared communication medium for the plurality of communication sessions according to the polling pattern;
means for monitoring data transmitted by the communication stations in response to the polling; and means for adapting assignment of the communication resources based on the monitored data, including adapting the polling pattern for one or more of the communication sessions, wherein adapting the polling pattern comprises:
reducing a rate of polling for a specific session if the session is not utilizing assigned communication resources, thereby reducing an actual rate of transmission for that session; or increasing a rate of polling for the specific session if the session is utilizing more than the assigned communication resources, thereby increasing an actual rate of transmission for that session.
30. The apparatus of claim 29 further comprising:
means for admitting a new communication session if a quality of service requirement for the new communication session can be provided without exceeding a limit on available communication resources or rejecting the new communication session if the quality of service requirement cannot be provided without exceeding the limit on available communication resources.
means for admitting a new communication session if a quality of service requirement for the new communication session can be provided without exceeding a limit on available communication resources or rejecting the new communication session if the quality of service requirement cannot be provided without exceeding the limit on available communication resources.
31. A computer readable medium encoded with software which, when executed by one or more computing systems, causes the one or more computing systems to perform a method comprising:
assigning communication resources on a shared communication medium based on quality of service requirements of a plurality of communication sessions, including determining a polling pattern;
polling each of a plurality of communication stations to transmit data for the plurality of communication sessions according to the polling pattern;
monitoring data transmitted over the shared communication medium by the communication stations in response to the polling; and modifying the polling pattern for one or more of the communication sessions, wherein modifying the polling pattern comprises:
reducing a rate of polling for a session if the session is not utilizing assigned communication resources; or increasing a rate of polling for a session if the session is utilizing more than the assigned communication resources.
assigning communication resources on a shared communication medium based on quality of service requirements of a plurality of communication sessions, including determining a polling pattern;
polling each of a plurality of communication stations to transmit data for the plurality of communication sessions according to the polling pattern;
monitoring data transmitted over the shared communication medium by the communication stations in response to the polling; and modifying the polling pattern for one or more of the communication sessions, wherein modifying the polling pattern comprises:
reducing a rate of polling for a session if the session is not utilizing assigned communication resources; or increasing a rate of polling for a session if the session is utilizing more than the assigned communication resources.
32. The computer readable medium of claim 31, wherein the method further comprises:
admitting a new communication session if a quality of service requirement for the new session can be provided without exceeding a limit on available communication resources; and rejecting the new communication session if the quality of service requirement cannot be provided without exceeding the limit on available communication resources.
admitting a new communication session if a quality of service requirement for the new session can be provided without exceeding a limit on available communication resources; and rejecting the new communication session if the quality of service requirement cannot be provided without exceeding the limit on available communication resources.
33. The computer readable medium of claim 32 wherein the quality of service requirement for the new communication session includes a minimum required rate and a maximum desired data rate.
34. An apparatus for polling a plurality of stations configured to communicate over a shared communication medium in a communication system, the apparatus comprising:
a polling manager configured to generate polling messages to a plurality of stations based on a polling pattern;
a transmitter coupled to the polling manager, wherein the transmitter is configured to initiate transmission of the polling messages over a shared communication medium to the plurality of stations; and a receiver coupled to the polling manager, wherein the receiver is configured to receive messages over the shared communication medium from the stations, and provide monitoring information to the polling manager, wherein the polling manager is configured to adapt the polling pattern by reducing a rate of polling for a specific session based on monitored transmissions for the specific session if the session is not utilizing assigned communication resources, or increasing a rate of polling for the specific session based on the monitored transmissions for the specific session if the session is utilizing more than the assigned communication resources.
a polling manager configured to generate polling messages to a plurality of stations based on a polling pattern;
a transmitter coupled to the polling manager, wherein the transmitter is configured to initiate transmission of the polling messages over a shared communication medium to the plurality of stations; and a receiver coupled to the polling manager, wherein the receiver is configured to receive messages over the shared communication medium from the stations, and provide monitoring information to the polling manager, wherein the polling manager is configured to adapt the polling pattern by reducing a rate of polling for a specific session based on monitored transmissions for the specific session if the session is not utilizing assigned communication resources, or increasing a rate of polling for the specific session based on the monitored transmissions for the specific session if the session is utilizing more than the assigned communication resources.
35. The apparatus of claim 34 further comprising a resource manager coupled to the polling manager, wherein the resource manager is configured to accept requests to admit communication sessions and to provide resource allocations for admitted sessions to the polling manager.
36. In a communication system in which a plurality of stations share access to a communication network according to a multiple-access media access control protocol, a method for controlling access by the stations to the network, the method comprising:
at an arbiter station that is coupled to a communication network, determining a polling pattern for polling a plurality of stations coupled to the communication network, wherein determining a polling pattern includes:
reducing a rate of polling for a station if the session is not utilizing assigned communication resources, or increasing the rate of polling for a station if the session is utilizing more than the assigned communication resources, wherein the rate of polling for a station satisfies quality of service requirements for a plurality of communication sessions at the station;
transmitting polling messages from the arbiter station to each of the plurality of communication stations according to the polling pattern; and at each of the plurality of stations, using received polling messages to determine times when to transmit onto the communication network, and at the determined times transmitting data onto the communication network using a multiple access media access control protocol.
at an arbiter station that is coupled to a communication network, determining a polling pattern for polling a plurality of stations coupled to the communication network, wherein determining a polling pattern includes:
reducing a rate of polling for a station if the session is not utilizing assigned communication resources, or increasing the rate of polling for a station if the session is utilizing more than the assigned communication resources, wherein the rate of polling for a station satisfies quality of service requirements for a plurality of communication sessions at the station;
transmitting polling messages from the arbiter station to each of the plurality of communication stations according to the polling pattern; and at each of the plurality of stations, using received polling messages to determine times when to transmit onto the communication network, and at the determined times transmitting data onto the communication network using a multiple access media access control protocol.
37. The method of claim 36 further comprising: at each of the plurality of stations providing a software interface to a network layer protocol module and accepting messages over the software interface from the network layer protocol module, wherein determining the times when to transmit onto the communication network includes determining times when to transmit the messages accepted over the software interface.
38. The method of claim 37 wherein transmitting data onto the communication network includes transmit ting the accepted messages using an Ethernet protocol.
39. The method of claim 38 wherein the network layer protocol module includes an Internet Protocol (IP) module.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US08/907,812 US6049549A (en) | 1997-08-14 | 1997-08-14 | Adaptive media control |
US08/907,812 | 1997-08-14 | ||
PCT/US1998/016836 WO1999009691A1 (en) | 1997-08-14 | 1998-08-13 | Adaptive media control |
Publications (2)
Publication Number | Publication Date |
---|---|
CA2300157A1 CA2300157A1 (en) | 1999-02-25 |
CA2300157C true CA2300157C (en) | 2011-04-26 |
Family
ID=25424679
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CA2300157A Expired - Fee Related CA2300157C (en) | 1997-08-14 | 1998-08-13 | Adaptive media control |
Country Status (7)
Country | Link |
---|---|
US (2) | US6049549A (en) |
EP (1) | EP1004179B1 (en) |
JP (1) | JP2001516173A (en) |
AU (1) | AU742990B2 (en) |
CA (1) | CA2300157C (en) |
IL (1) | IL134508A0 (en) |
WO (1) | WO1999009691A1 (en) |
Families Citing this family (152)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
SE508050C2 (en) * | 1995-11-09 | 1998-08-17 | Ericsson Telefon Ab L M | Device and method of packet delivery |
US6049549A (en) | 1997-08-14 | 2000-04-11 | University Of Massachusetts | Adaptive media control |
US6370592B1 (en) * | 1997-11-04 | 2002-04-09 | Hewlett-Packard Company | Network interface device which allows peripherals to utilize network transport services |
WO1999023791A1 (en) * | 1997-11-04 | 1999-05-14 | British Telecommunications Public Limited Company | Communications network |
US6252886B1 (en) * | 1998-07-06 | 2001-06-26 | Sony Corporation | Bandwidth reservation |
US6862622B2 (en) | 1998-07-10 | 2005-03-01 | Van Drebbel Mariner Llc | Transmission control protocol/internet protocol (TCP/IP) packet-centric wireless point to multi-point (PTMP) transmission system architecture |
US6453336B1 (en) * | 1998-09-14 | 2002-09-17 | Siemens Information And Communication Networks, Inc. | Video conferencing with adaptive client-controlled resource utilization |
US6747959B1 (en) | 1998-10-07 | 2004-06-08 | At&T Corp. | Voice data integrated mulitaccess by self-reservation and blocked binary tree resolution |
US6963545B1 (en) | 1998-10-07 | 2005-11-08 | At&T Corp. | Voice-data integrated multiaccess by self-reservation and stabilized aloha contention |
US6785280B1 (en) * | 1998-12-23 | 2004-08-31 | Ericsson Inc. | Mechanism and method dynamically allocating ATM connections between exchanges |
US6760308B1 (en) | 1999-02-26 | 2004-07-06 | Bitbytebit Information Services, Inc. | Adaptive transmission in multi-access asynchronous channels |
JP3808660B2 (en) | 1999-03-31 | 2006-08-16 | 株式会社東芝 | Communication system and terminal device |
US7817666B2 (en) * | 1999-05-21 | 2010-10-19 | Wi-Lan, Inc. | Method and system for adaptively obtaining bandwidth allocation requests |
US8462810B2 (en) * | 1999-05-21 | 2013-06-11 | Wi-Lan, Inc. | Method and system for adaptively obtaining bandwidth allocation requests |
US7006530B2 (en) * | 2000-12-22 | 2006-02-28 | Wi-Lan, Inc. | Method and system for adaptively obtaining bandwidth allocation requests |
US6925068B1 (en) * | 1999-05-21 | 2005-08-02 | Wi-Lan, Inc. | Method and apparatus for allocating bandwidth in a wireless communication system |
US20090219879A1 (en) | 1999-05-21 | 2009-09-03 | Wi-Lan, Inc. | Method and apparatus for bandwidth request/grant protocols in a wireless communication system |
US6577644B1 (en) * | 1999-06-22 | 2003-06-10 | Lucent Technologies Inc. | Quality of service (QoS) enhancement to multilink point-to-point protocol (PPP) |
EP1069736B1 (en) * | 1999-07-15 | 2012-09-05 | TELEFONAKTIEBOLAGET LM ERICSSON (publ) | Scheduling and admission control of packet data traffic |
US6574668B1 (en) * | 2000-01-25 | 2003-06-03 | Cirrus Logic, Inc. | Retransmission scheme in wireless computer networks |
US7933249B2 (en) * | 2000-02-08 | 2011-04-26 | Ipr Licensing, Inc. | Grade of service and fairness policy for bandwidth reservation system |
US6977895B1 (en) * | 2000-03-23 | 2005-12-20 | Cisco Technology, Inc. | Apparatus and method for rate-based polling of input interface queues in networking devices |
ES2194694T3 (en) * | 2000-04-28 | 2003-12-01 | Cit Alcatel | METHOD, MOBILE TERMINAL AND BASE STATION TO ENSURE RESOURCES IN A SHARED CHANNEL. |
US7068633B1 (en) | 2000-07-14 | 2006-06-27 | At&T Corp. | Enhanced channel access mechanisms for QoS-driven wireless lans |
US7151762B1 (en) | 2000-07-14 | 2006-12-19 | At&T Corp. | Virtual streams for QoS-driven wireless LANs |
EP1303946A2 (en) * | 2000-07-14 | 2003-04-23 | AT & T Corp. | Frame classification for qos-driven wireless local area networks |
US6999442B1 (en) | 2000-07-14 | 2006-02-14 | At&T Corp. | RSVP/SBM based down-stream session setup, modification, and teardown for QOS-driven wireless lans |
US6804222B1 (en) * | 2000-07-14 | 2004-10-12 | At&T Corp. | In-band Qos signaling reference model for QoS-driven wireless LANs |
US7756092B1 (en) | 2000-07-14 | 2010-07-13 | At&T Intellectual Property Ii, L.P. | In-band QoS signaling reference model for QoS-driven wireless LANs connected to one or more networks |
US6970422B1 (en) | 2000-07-14 | 2005-11-29 | At&T Corp. | Admission control for QoS-Driven Wireless LANs |
US7031287B1 (en) | 2000-07-14 | 2006-04-18 | At&T Corp. | Centralized contention and reservation request for QoS-driven wireless LANs |
US6950397B1 (en) | 2000-07-14 | 2005-09-27 | At&T Corp. | RSVP/SBM based side-stream session setup, modification, and teardown for QoS-driven wireless lans |
US6850981B1 (en) | 2000-07-14 | 2005-02-01 | At&T Corp. | System and method of frame scheduling for QoS-driven wireless local area network (WLAN) |
US7068632B1 (en) * | 2000-07-14 | 2006-06-27 | At&T Corp. | RSVP/SBM based up-stream session setup, modification, and teardown for QOS-driven wireless LANs |
US6862270B1 (en) | 2000-07-14 | 2005-03-01 | At&T Corp. | Architectural reference model for QoS-driven wireless LANs |
US7039032B1 (en) | 2000-07-14 | 2006-05-02 | At&T Corp. | Multipoll for QoS-Driven wireless LANs |
US20020031114A1 (en) * | 2000-07-21 | 2002-03-14 | Coaxmedia, Inc. | Priority packet transmission system for telephony, latency-sensitive data, best-effort data and video streams in a shared transmission media such as passive coax distribution |
US6990104B1 (en) * | 2000-08-03 | 2006-01-24 | Lucent Technologies Inc. | Methods and devices for scheduling transmissions in interference-limited networks |
JP2002057699A (en) * | 2000-08-11 | 2002-02-22 | Nec Corp | Packet transmission system, packet transmission method and recording medium |
US20020141376A1 (en) * | 2000-09-18 | 2002-10-03 | Sharp Labs Of America | Devices, softwares, and methods for wireless devices to form a network on the fly by performing admission control in the second layer |
US6577609B2 (en) * | 2000-09-29 | 2003-06-10 | Symbol Technologies, Inc. | Local addressing of mobile units in a WLAN with multicast packet addressing |
US20020159418A1 (en) * | 2000-11-02 | 2002-10-31 | Sharp Laboratories Of America, Inc. | Quality of service using wireless lan |
US6839331B2 (en) * | 2000-11-02 | 2005-01-04 | Sharp Laboratories Of America, Inc. | Method to dynamically change all MIB parameters of a wireless data network |
US7254638B2 (en) * | 2000-12-15 | 2007-08-07 | International Business Machines Corporation | Method and apparatus for identifying slow links and for providing application-based responses to slow links in a distributed computer network |
US6823378B2 (en) | 2000-12-18 | 2004-11-23 | International Business Machines Corporation | Method and apparatus in network management system for performance-based network protocol layer firewall |
US8849276B2 (en) * | 2000-12-29 | 2014-09-30 | At&T Mobility Ii Llc | Intelligent network selection based on quality of service and applications over different wireless networks |
US7433929B2 (en) * | 2000-12-29 | 2008-10-07 | At&T Mobility Ii Llc | Intelligent network selection based on quality of service and applications over different wireless networks |
FR2819658B1 (en) * | 2001-01-12 | 2004-04-09 | Cit Alcatel | METHOD FOR MANAGING PROCESSING RESOURCES IN A MOBILE RADIO COMMUNICATION SYSTEM |
US6874036B2 (en) * | 2001-02-08 | 2005-03-29 | International Business Machines Corporation | Network management server combining PDUs to minimize bandwidth consumption at data link layer |
US20020107949A1 (en) * | 2001-02-08 | 2002-08-08 | International Business Machines Corporation | Polling for and transfer of protocol data units in a data processing network |
US20020107955A1 (en) * | 2001-02-08 | 2002-08-08 | International Business Machines Corporation | Protocol data unit prioritization in a data processing network |
US7120134B2 (en) * | 2001-02-15 | 2006-10-10 | Qualcomm, Incorporated | Reverse link channel architecture for a wireless communication system |
US7142563B1 (en) | 2001-02-20 | 2006-11-28 | At&T Corp. | Service interface for QoS-driven HPNA networks |
US7180855B1 (en) | 2001-04-19 | 2007-02-20 | At&T Corp. | Service interface for QoS-driven HPNA networks |
US7512940B2 (en) * | 2001-03-29 | 2009-03-31 | Microsoft Corporation | Methods and apparatus for downloading and/or distributing information and/or software resources based on expected utility |
US7054274B2 (en) * | 2001-04-11 | 2006-05-30 | Alcatel Canada Inc. | Method and apparatus for processing requests for statistics in a communication network |
US20090031419A1 (en) | 2001-05-24 | 2009-01-29 | Indra Laksono | Multimedia system and server and methods for use therewith |
US8291457B2 (en) | 2001-05-24 | 2012-10-16 | Vixs Systems, Inc. | Channel selection in a multimedia system |
CA2354177A1 (en) | 2001-07-26 | 2003-01-26 | Waverider Communications Inc. | Polling using multiple dynamically updated lists |
US20030076809A1 (en) * | 2001-08-03 | 2003-04-24 | Coaxmedia, Inc. | Methods for detecting and polling downstream modems |
US20030039226A1 (en) * | 2001-08-24 | 2003-02-27 | Kwak Joseph A. | Physical layer automatic repeat request (ARQ) |
EP1419603B1 (en) * | 2001-08-24 | 2011-03-23 | Interdigital Technology Corporation | Method for physical layer automatic repeat request for a base station |
US7213044B2 (en) * | 2001-08-31 | 2007-05-01 | Microsoft Corporation | Point-to-point data communication implemented with multipoint network data communication components |
US7123627B2 (en) * | 2001-09-11 | 2006-10-17 | Sharp Laboratories Of America, Inc. | Class of computationally parsimonious schedulers for enforcing quality of service over packet based AV-centric home networks |
JP3788402B2 (en) * | 2001-09-14 | 2006-06-21 | 株式会社村田製作所 | Dielectric filter, dielectric duplexer, and communication device |
US20030093526A1 (en) * | 2001-11-13 | 2003-05-15 | Koninklijke Philips Electronics N. V. | Apparatus and method for providing quality of service signaling for wireless mac layer |
US20030135632A1 (en) * | 2001-12-13 | 2003-07-17 | Sophie Vrzic | Priority scheduler |
US20030119558A1 (en) * | 2001-12-20 | 2003-06-26 | Karl Steadman | Adaptive antenna pattern formation in wireless ad-hoc packet-switched networks |
US7342876B2 (en) * | 2001-12-20 | 2008-03-11 | Sri International | Interference mitigation and adaptive routing in wireless ad-hoc packet-switched networks |
US7529263B1 (en) * | 2002-01-19 | 2009-05-05 | Ucentric Systems, Inc. | Local area-networked system having intelligent traffic control and efficient bandwidth management |
EP1335537A1 (en) * | 2002-02-01 | 2003-08-13 | Thomson Licensing S.A. | Method for evaluating radio links in a communication network |
WO2003067453A1 (en) * | 2002-02-08 | 2003-08-14 | Bermai, Inc. | Medium access control in a wireless network |
US7400733B1 (en) * | 2002-02-27 | 2008-07-15 | Atheros Communications, Inc. | Key refresh at the MAC layer |
US20030223365A1 (en) * | 2002-06-04 | 2003-12-04 | Sharp Laboratories Of America, Inc. | Class of dynamic programming schedulers |
US20040037257A1 (en) * | 2002-08-23 | 2004-02-26 | Koninklijke Philips Electronics N.V. | Method and apparatus for assuring quality of service in wireless local area networks |
KR20040020639A (en) * | 2002-08-31 | 2004-03-09 | 삼성전자주식회사 | Dynamic control method of realtime multimedia data generation rate, and apparatus thereof. |
WO2004028049A1 (en) * | 2002-09-17 | 2004-04-01 | Broadcom Corporation | Method and system for network management in a hybrid wired/wireless network |
US20040049570A1 (en) * | 2002-09-17 | 2004-03-11 | Frank Ed H. | Method and system for network management in a hybrid wired/wireless network |
US7453844B1 (en) * | 2002-10-22 | 2008-11-18 | Hong Kong Applied Science and Technology Research Institute, Co., Ltd. | Dynamic allocation of channels in a wireless network |
US7280537B2 (en) * | 2003-08-07 | 2007-10-09 | Teamon Systems, Inc. | Communications system providing adaptive polling based upon positive and negative polling events and related methods |
US7403531B2 (en) * | 2003-05-30 | 2008-07-22 | Texas Instruments Incorporated | WLAN admission control for multimedia service |
US6931460B2 (en) * | 2003-05-19 | 2005-08-16 | Emulex Design & Manufacturing Corporation | Dynamically self-adjusting polling mechanism |
US7274740B2 (en) * | 2003-06-25 | 2007-09-25 | Sharp Laboratories Of America, Inc. | Wireless video transmission system |
US20050224596A1 (en) * | 2003-07-08 | 2005-10-13 | Panopoulos Peter J | Machine that is an automatic pesticide, insecticide, repellant, poison, air freshener, disinfectant or other type of spray delivery system |
US7289495B2 (en) * | 2003-08-07 | 2007-10-30 | Teamon Systems, Inc. | Communications system providing adaptive polling based upon user usage patterns and related methods |
US20050163151A1 (en) * | 2003-08-12 | 2005-07-28 | Omnitek Partners Llc | Projectile having a casing and/or interior acting as a communication bus between electronic components |
AU2003260446A1 (en) * | 2003-08-21 | 2005-03-10 | Docomo Communications Laboratories Europe Gmbh | Resource reservation in a wireless network with distributed medium access control |
US9325998B2 (en) * | 2003-09-30 | 2016-04-26 | Sharp Laboratories Of America, Inc. | Wireless video transmission system |
ATE447309T1 (en) * | 2003-11-10 | 2009-11-15 | Mitsubishi Electric Inf Tech | ACCESS CONTROL TO A COMMON TRANSMISSION MEDIUM FOR MULTIPLE CONNECTIONS |
KR100592907B1 (en) * | 2003-12-22 | 2006-06-23 | 삼성전자주식회사 | Wireless internet terminal and method for transmitting packet to enhance QoS |
US20050141546A1 (en) * | 2003-12-31 | 2005-06-30 | Lg Electronics Inc. | Method of avoiding collisions between access terminals |
US8018850B2 (en) * | 2004-02-23 | 2011-09-13 | Sharp Laboratories Of America, Inc. | Wireless video transmission system |
KR100989314B1 (en) * | 2004-04-09 | 2010-10-25 | 삼성전자주식회사 | display apparatus |
US8121595B2 (en) * | 2004-06-02 | 2012-02-21 | Intel Corporation | Adaptive polling of wireless devices |
US20080144493A1 (en) * | 2004-06-30 | 2008-06-19 | Chi-Hsiang Yeh | Method of interference management for interference/collision prevention/avoidance and spatial reuse enhancement |
US20070226344A1 (en) * | 2004-07-23 | 2007-09-27 | General Instrument Corporation | Centralized Resource Manager With Power Switching System |
US9031568B2 (en) * | 2004-07-28 | 2015-05-12 | Broadcom Corporation | Quality-of-service (QoS)-based association with a new network using background network scanning |
FR2875667A1 (en) * | 2004-09-22 | 2006-03-24 | France Telecom | PREEMPTION METHOD FOR MANAGING RADIO RESOURCES IN A MOBILE COMMUNICATION NETWORK |
US7809128B2 (en) * | 2004-10-07 | 2010-10-05 | Genband Us Llc | Methods and systems for per-session traffic rate policing in a media gateway |
KR100703688B1 (en) * | 2004-10-18 | 2007-04-05 | 삼성전자주식회사 | Method and network apparatus for displaying informations of network by selection |
US7797723B2 (en) * | 2004-10-30 | 2010-09-14 | Sharp Laboratories Of America, Inc. | Packet scheduling for video transmission with sender queue control |
US8356327B2 (en) * | 2004-10-30 | 2013-01-15 | Sharp Laboratories Of America, Inc. | Wireless video transmission system |
US7784076B2 (en) * | 2004-10-30 | 2010-08-24 | Sharp Laboratories Of America, Inc. | Sender-side bandwidth estimation for video transmission with receiver packet buffer |
US8737920B2 (en) * | 2004-11-10 | 2014-05-27 | Interdigital Technology Corporation | Method and apparatus for managing wireless communication network radio resources |
US20060146709A1 (en) * | 2004-12-30 | 2006-07-06 | Boris Ginzburg | Device, system and method for limiting data rates supported by a wireless LAN |
US8483200B2 (en) * | 2005-04-07 | 2013-07-09 | Interdigital Technology Corporation | Method and apparatus for antenna mapping selection in MIMO-OFDM wireless networks |
TWI257218B (en) * | 2005-04-15 | 2006-06-21 | Univ Nat Chiao Tung | Scheduling method for supporting quality of service (QoS) in wireless local area network (WLAN) |
US7646712B2 (en) * | 2005-10-17 | 2010-01-12 | Searete Llc | Using a signal route dependent on a node speed change prediction |
US8125896B2 (en) * | 2005-10-17 | 2012-02-28 | The Invention Science Fund I, Llc | Individualizing a connectivity-indicative mapping |
US20070087695A1 (en) * | 2005-10-17 | 2007-04-19 | Searete Llc, A Limited Liability Corporation Of The State Of Delaware | Mobile directional antenna |
KR100736088B1 (en) * | 2005-11-22 | 2007-07-06 | 삼성전자주식회사 | Wireless network device and resource allot method for the same |
US9544602B2 (en) * | 2005-12-30 | 2017-01-10 | Sharp Laboratories Of America, Inc. | Wireless video transmission system |
US7652994B2 (en) * | 2006-03-31 | 2010-01-26 | Sharp Laboratories Of America, Inc. | Accelerated media coding for robust low-delay video streaming over time-varying and bandwidth limited channels |
US8743676B2 (en) * | 2006-05-10 | 2014-06-03 | Apple Inc. | Methods and systems for scheduling OFDM frames |
US9198084B2 (en) * | 2006-05-26 | 2015-11-24 | Qualcomm Incorporated | Wireless architecture for a traditional wire-based protocol |
US20080045149A1 (en) * | 2006-05-26 | 2008-02-21 | Dinesh Dharmaraju | Wireless architecture for a traditional wire-based protocol |
US20070281614A1 (en) * | 2006-06-01 | 2007-12-06 | Motorola, Inc. | Method and apparatus for dual mode communications |
US20080062957A1 (en) * | 2006-09-11 | 2008-03-13 | Motorola, Inc. | Method and apparatus for aligned transmissions in a wireless network |
US8861597B2 (en) * | 2006-09-18 | 2014-10-14 | Sharp Laboratories Of America, Inc. | Distributed channel time allocation for video streaming over wireless networks |
US7652993B2 (en) * | 2006-11-03 | 2010-01-26 | Sharp Laboratories Of America, Inc. | Multi-stream pro-active rate adaptation for robust video transmission |
US8379609B2 (en) * | 2007-03-29 | 2013-02-19 | Vixs Systems, Inc. | Multimedia client/server system with adjustable data link rate and range and methods for use therewith |
US8667144B2 (en) * | 2007-07-25 | 2014-03-04 | Qualcomm Incorporated | Wireless architecture for traditional wire based protocol |
WO2009061829A1 (en) | 2007-11-05 | 2009-05-14 | Limelight Networks, Inc. | End to end data transfer |
JP5076992B2 (en) * | 2008-03-18 | 2012-11-21 | 富士通株式会社 | UL radio resource allocation method, radio base station, and radio terminal in radio communication system |
US8811294B2 (en) * | 2008-04-04 | 2014-08-19 | Qualcomm Incorporated | Apparatus and methods for establishing client-host associations within a wireless network |
US20100004016A1 (en) * | 2008-07-07 | 2010-01-07 | Hujun Yin | Power control techniques |
EP2144462A1 (en) * | 2008-07-09 | 2010-01-13 | Nokia Siemens Networks OY | Reduced resource allocation parameter signalling |
US7860002B2 (en) * | 2008-07-15 | 2010-12-28 | Motorola, Inc. | Priority-based admission control in a network with variable channel data rates |
KR101507613B1 (en) * | 2008-08-11 | 2015-04-08 | 엘지전자 주식회사 | A method of operating a relay station in a wireless communication system |
US9398089B2 (en) | 2008-12-11 | 2016-07-19 | Qualcomm Incorporated | Dynamic resource sharing among multiple wireless devices |
US8102849B2 (en) | 2009-02-12 | 2012-01-24 | Qualcomm, Incorporated | Association procedure to enable multiple multicast streams |
US20100205321A1 (en) * | 2009-02-12 | 2010-08-12 | Qualcomm Incorporated | Negotiable and adaptable periodic link status monitoring |
EP2254380A1 (en) * | 2009-05-18 | 2010-11-24 | Nokia Siemens Networks OY | A method and apparatus |
US9264248B2 (en) * | 2009-07-02 | 2016-02-16 | Qualcomm Incorporated | System and method for avoiding and resolving conflicts in a wireless mobile display digital interface multicast environment |
US9582238B2 (en) * | 2009-12-14 | 2017-02-28 | Qualcomm Incorporated | Decomposed multi-stream (DMS) techniques for video display systems |
US9065876B2 (en) | 2011-01-21 | 2015-06-23 | Qualcomm Incorporated | User input back channel from a wireless sink device to a wireless source device for multi-touch gesture wireless displays |
US10135900B2 (en) | 2011-01-21 | 2018-11-20 | Qualcomm Incorporated | User input back channel for wireless displays |
US9582239B2 (en) | 2011-01-21 | 2017-02-28 | Qualcomm Incorporated | User input back channel for wireless displays |
US9413803B2 (en) | 2011-01-21 | 2016-08-09 | Qualcomm Incorporated | User input back channel for wireless displays |
US9787725B2 (en) | 2011-01-21 | 2017-10-10 | Qualcomm Incorporated | User input back channel for wireless displays |
US8964783B2 (en) | 2011-01-21 | 2015-02-24 | Qualcomm Incorporated | User input back channel for wireless displays |
US8674957B2 (en) | 2011-02-04 | 2014-03-18 | Qualcomm Incorporated | User input device for wireless back channel |
US9503771B2 (en) | 2011-02-04 | 2016-11-22 | Qualcomm Incorporated | Low latency wireless display for graphics |
US10108386B2 (en) | 2011-02-04 | 2018-10-23 | Qualcomm Incorporated | Content provisioning for wireless back channel |
US9338468B2 (en) * | 2011-12-29 | 2016-05-10 | Broadcom Corporation | Latency aware priority based multi-channel decoding |
US9525998B2 (en) | 2012-01-06 | 2016-12-20 | Qualcomm Incorporated | Wireless display with multiscreen service |
US9877285B2 (en) * | 2014-04-25 | 2018-01-23 | Aruba Networks, Inc. | Method and system for device aware power save |
US10827484B2 (en) | 2014-12-12 | 2020-11-03 | Qualcomm Incorporated | Traffic advertisement in neighbor aware network (NAN) data path |
US10820314B2 (en) | 2014-12-12 | 2020-10-27 | Qualcomm Incorporated | Traffic advertisement in neighbor aware network (NAN) data path |
US10880881B2 (en) | 2018-05-15 | 2020-12-29 | King Fahd University Of Petroleum And Minerals | Systems and methods for collision prevention and power conservation in wireless networks |
US11716784B2 (en) * | 2019-12-23 | 2023-08-01 | Sony Group Corporation | RTA interface between MAC and app layer |
CN116671220A (en) * | 2020-12-31 | 2023-08-29 | 华为技术有限公司 | Service scheduling method and device |
Family Cites Families (57)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3864521A (en) * | 1973-10-25 | 1975-02-04 | Rockwell International Corp | Frequency division multiplex telephone system |
US4404557A (en) * | 1982-03-05 | 1983-09-13 | Burroughs Corporation | Timed token ring with multiple priorities |
US4829297A (en) * | 1987-05-08 | 1989-05-09 | Allen-Bradley Company, Inc. | Communication network polling technique |
JPH0748739B2 (en) * | 1988-12-09 | 1995-05-24 | 富士通株式会社 | Multiple access control method and multiple access control system implementing the method |
JP2829733B2 (en) | 1989-01-31 | 1998-12-02 | 能美防災株式会社 | Disaster prevention equipment |
DE68916231T2 (en) | 1989-03-23 | 1995-02-02 | Ibm | Method and device for multiple access with distributed queues in a communication system. |
US5130983A (en) * | 1990-03-27 | 1992-07-14 | Heffner Iii Horace W | Method of polling to determine service needs and the like |
WO1991016775A1 (en) | 1990-04-25 | 1991-10-31 | Telxon Corporation | Communication system with adaptive media access control |
GB9019488D0 (en) * | 1990-09-06 | 1990-10-24 | Ncr Co | Local area network having a wireless transmission link |
GB9019490D0 (en) * | 1990-09-06 | 1990-10-24 | Ncr Co | Transmission control for a wireless local area network station |
GB9019489D0 (en) * | 1990-09-06 | 1990-10-24 | Ncr Co | Antenna control for a wireless local area network station |
US5371780A (en) * | 1990-10-01 | 1994-12-06 | At&T Corp. | Communications resource assignment in a wireless telecommunications system |
US5355520A (en) * | 1990-11-30 | 1994-10-11 | Motorola, Inc. | In-building microwave communication system permits frequency refuse with external point-to-point microwave systems |
US5297144A (en) * | 1991-01-22 | 1994-03-22 | Spectrix Corporation | Reservation-based polling protocol for a wireless data communications network |
US5416777A (en) * | 1991-04-10 | 1995-05-16 | California Institute Of Technology | High speed polling protocol for multiple node network |
US5457689A (en) * | 1991-04-10 | 1995-10-10 | California Institute Of Technology | High speed polling protocol for multiple node network with sequential flooding of a polling message and a poll-answering message |
CA2040234C (en) | 1991-04-11 | 2000-01-04 | Steven Messenger | Wireless coupling of devices to wired network |
US5241542A (en) * | 1991-08-23 | 1993-08-31 | International Business Machines Corporation | Battery efficient operation of scheduled access protocol |
US5410738A (en) * | 1991-09-03 | 1995-04-25 | Ncr Corporation | System and method for linking wireless local area networks |
CA2077061C (en) * | 1991-11-22 | 1998-04-21 | Mark J. Baugher | Scheduling system for distributed multimedia resources |
US5422887A (en) * | 1991-11-27 | 1995-06-06 | Ncr Corporation | Medium access protocol for wireless local area network |
US5231634B1 (en) * | 1991-12-18 | 1996-04-02 | Proxim Inc | Medium access protocol for wireless lans |
US5276703A (en) * | 1992-01-13 | 1994-01-04 | Windata, Inc. | Wireless local area network communications system |
US5349342A (en) * | 1992-01-30 | 1994-09-20 | Motorola, Inc. | Method for reclaiming unused system resources |
US5291475B1 (en) * | 1992-03-27 | 1995-06-27 | Motorola Inc | Slot hopped fd/td/cmda |
US5282222A (en) * | 1992-03-31 | 1994-01-25 | Michel Fattouche | Method and apparatus for multiple access between transceivers in wireless communications using OFDM spread spectrum |
US5422885A (en) * | 1992-06-01 | 1995-06-06 | Motorola, Inc. | Contention free local area network |
GB9217374D0 (en) * | 1992-08-14 | 1992-09-30 | Ncr Int Inc | Wireless local area network transmission system |
US5319711A (en) * | 1992-08-19 | 1994-06-07 | Gte Laboratories Incorporated | Wireless device for verifying identification |
GB9223890D0 (en) * | 1992-11-13 | 1993-01-06 | Ncr Int Inc | Wireless local area network system |
GB9226707D0 (en) * | 1992-12-22 | 1993-02-17 | Ncr Int Inc | Wireless local area network system with mobile station handover |
US5406261A (en) * | 1993-01-11 | 1995-04-11 | Glenn; James T. | Computer security apparatus and method |
US5371734A (en) * | 1993-01-29 | 1994-12-06 | Digital Ocean, Inc. | Medium access control protocol for wireless network |
JPH06261043A (en) * | 1993-03-05 | 1994-09-16 | Hitachi Ltd | Radio channel lan system and its control method |
US5384777A (en) * | 1993-04-19 | 1995-01-24 | International Business Machines Corporation | Adaptive medium access control scheme for wireless LAN |
EP0621704B1 (en) * | 1993-04-19 | 2001-06-20 | International Business Machines Corporation | System for network wide bandwidth allocation |
US5373503A (en) * | 1993-04-30 | 1994-12-13 | Information Technology, Inc. | Group randomly addressed polling method |
US5408465A (en) * | 1993-06-21 | 1995-04-18 | Hewlett-Packard Company | Flexible scheme for admission control of multimedia streams on integrated networks |
CA2124379C (en) * | 1993-06-25 | 1998-10-27 | Thomas F. La Porta | Distributed processing architecture for control of broadband and narrowband communications networks |
US5371794A (en) * | 1993-11-02 | 1994-12-06 | Sun Microsystems, Inc. | Method and apparatus for privacy and authentication in wireless networks |
US5436905A (en) * | 1994-05-16 | 1995-07-25 | Industrial Technology Research Institute | Group randomly addressed polling MAC protocol for wireless data |
US5563883A (en) * | 1994-07-18 | 1996-10-08 | Cheng; Alexander L. | Dynamic channel management and signalling method and apparatus |
US5768280A (en) | 1995-01-12 | 1998-06-16 | Way; Winston I. | Two-way broadband CATV communication network protocol and monitoring technology |
US5611730A (en) * | 1995-04-25 | 1997-03-18 | Casino Data Systems | Progressive gaming system tailored for use in multiple remote sites: apparatus and method |
US6006017A (en) | 1995-05-02 | 1999-12-21 | Motorola Inc. | System for determining the frequency of repetitions of polling active stations relative to the polling of inactive stations |
US5659787A (en) | 1995-05-26 | 1997-08-19 | Sensormatic Electronics Corporation | Data communication network with highly efficient polling procedure |
US5638371A (en) * | 1995-06-27 | 1997-06-10 | Nec Usa, Inc. | Multiservices medium access control protocol for wireless ATM system |
US5734646A (en) * | 1995-10-05 | 1998-03-31 | Lucent Technologies Inc. | Code division multiple access system providing load and interference based demand assignment service to users |
US5684800A (en) * | 1995-11-15 | 1997-11-04 | Cabletron Systems, Inc. | Method for establishing restricted broadcast groups in a switched network |
US5917822A (en) | 1995-11-15 | 1999-06-29 | Xerox Corporation | Method for providing integrated packet services over a shared-media network |
US5793747A (en) * | 1996-03-14 | 1998-08-11 | Motorola, Inc. | Event-driven cell scheduler and method for supporting multiple service categories in a communication network |
US5796732A (en) * | 1996-03-28 | 1998-08-18 | Cisco Technology, Inc. | Architecture for an expandable transaction-based switching bus |
US5926476A (en) | 1996-07-09 | 1999-07-20 | Ericsson, Inc. | Network architecture for broadband data communication over a shared medium |
US6198728B1 (en) * | 1996-12-19 | 2001-03-06 | Phillips Electronics North America Corp. | Medium access control (MAC) protocol for wireless ATM |
US5886993A (en) | 1997-05-30 | 1999-03-23 | Motorola, Inc. | System, device, and method for sharing contention mini-slots among multiple priority classes |
US6114968A (en) * | 1997-06-27 | 2000-09-05 | Motorola Inc. | Hybrid contention/polling access method |
US6049549A (en) | 1997-08-14 | 2000-04-11 | University Of Massachusetts | Adaptive media control |
-
1997
- 1997-08-14 US US08/907,812 patent/US6049549A/en not_active Expired - Lifetime
-
1998
- 1998-08-13 WO PCT/US1998/016836 patent/WO1999009691A1/en active IP Right Grant
- 1998-08-13 CA CA2300157A patent/CA2300157C/en not_active Expired - Fee Related
- 1998-08-13 AU AU87833/98A patent/AU742990B2/en not_active Expired
- 1998-08-13 EP EP98939396.2A patent/EP1004179B1/en not_active Expired - Lifetime
- 1998-08-13 JP JP2000510236A patent/JP2001516173A/en active Pending
- 1998-08-13 IL IL13450898A patent/IL134508A0/en not_active IP Right Cessation
-
2006
- 2006-07-25 US US11/492,735 patent/US7460514B2/en not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
WO1999009691A1 (en) | 1999-02-25 |
CA2300157A1 (en) | 1999-02-25 |
US7460514B2 (en) | 2008-12-02 |
IL134508A0 (en) | 2001-04-30 |
EP1004179A1 (en) | 2000-05-31 |
EP1004179A4 (en) | 2005-01-19 |
AU742990B2 (en) | 2002-01-17 |
AU8783398A (en) | 1999-03-08 |
JP2001516173A (en) | 2001-09-25 |
US6049549A (en) | 2000-04-11 |
US20060262769A1 (en) | 2006-11-23 |
EP1004179B1 (en) | 2015-01-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CA2300157C (en) | Adaptive media control | |
JP5095751B2 (en) | Adaptive time allocation in TDMAMAC layer | |
US6879579B1 (en) | Medium access control protocol for data communications | |
US6865609B1 (en) | Multimedia extensions for wireless local area network | |
US7136392B2 (en) | System and method for ordering data messages having differing levels of priority for transmission over a shared communication channel | |
US7453844B1 (en) | Dynamic allocation of channels in a wireless network | |
US20050276252A1 (en) | Medium access control for wireless networks | |
EP1433286A1 (en) | A class of computationally parsimonious schedulers for enforcing quality of service over packet based av-centric home networks | |
JPH11289340A (en) | Method for collision solution in multiple access system in communication network | |
JPH11289341A (en) | Method for allowing new connection based on utility priority in multiple access system for communication network | |
JPH11289351A (en) | Method for overload control in multiple access system for communication network | |
US6963534B1 (en) | Methodology for improving the performance of asynchronous data traffic over TDD/TDMA wireless networks | |
US8184541B2 (en) | Method and system for link layer scheduling in a multiple access communication system | |
EP3967100B1 (en) | Pre-packet arrival channel contention | |
US20040156350A1 (en) | Hybrid polling/contention MAC layer with multiple grades of service | |
JP7334847B2 (en) | RTA queue management in wireless local area network (WLAN) stations | |
WO2001071981A2 (en) | Multimedia extensions for wireless local area networks | |
WO2008012789A1 (en) | Method for reduced latency wireless communication having reduced latency and increased range and handoff performance between different transmitting stations | |
Parata et al. | Flex-WiFi: a mixed infrastructure and ad-hoc IEEE 802.11 network for data traffic in a home environment | |
Tian et al. | An MAC protocol supporting multiple traffic over mobile ad hoc networks | |
AU761936B2 (en) | Medium access control protocol for data communications | |
Hwang et al. | HomeMAC: QoS-based MAC protocol for the home network | |
Hwang et al. | Software implementation of the HomeMAC: QoS based MAC protocol for the home network | |
Rhee et al. | Full-duplex transmission on the unidirectional links of high-rate wireless PANs | |
Kalvala et al. | Differentiated Priority Scheduling and Adaptive Segmentation for Bluetooth Piconets |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
EEER | Examination request | ||
MKLA | Lapsed |
Effective date: 20180813 |