CA2320709A1 - Method for controlling data flow associated with a communications node - Google Patents

Method for controlling data flow associated with a communications node Download PDF

Info

Publication number
CA2320709A1
CA2320709A1 CA002320709A CA2320709A CA2320709A1 CA 2320709 A1 CA2320709 A1 CA 2320709A1 CA 002320709 A CA002320709 A CA 002320709A CA 2320709 A CA2320709 A CA 2320709A CA 2320709 A1 CA2320709 A1 CA 2320709A1
Authority
CA
Canada
Prior art keywords
buffer memory
data message
receive data
communications node
class
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.)
Abandoned
Application number
CA002320709A
Other languages
French (fr)
Inventor
Ming-Hsu Tu
Steven A. Falco
Stephen Gregory Strickland
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nokia of America Corp
Original Assignee
Lucent Technologies Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Lucent Technologies Inc filed Critical Lucent Technologies Inc
Publication of CA2320709A1 publication Critical patent/CA2320709A1/en
Abandoned legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/29Flow control; Congestion control using a combination of thresholds
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/24Traffic characterised by specific attributes, e.g. priority or QoS
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/30Flow control; Congestion control in combination with information about buffer occupancy at either end or at transit nodes

Abstract

A communications node admits the receive data message to the buffer memory if the receive arriving message falls within the capacity range of a class of the receive data messages and if the buffer memory is not congested. A state detector detects if the buffer memory is congested by evaluating the occupancy rate of the buffer memory, or otherwise. The capacity range determines the utilization of buffer memory by a particular class of data messages, which may be defined in accordance with an estimated economic value rating of the data messages.

Description

Falco 5-3-3 1 METHOD FOR CONTROLLING DATA FLOW ASSOCIATED WITH A
COMMUNICATIONS NODE
Field Of The Invention This invention relates to a method for controlling data flow associated with a communications node; more specifically a communications node that services a wireless communications system.
Back4round A communications node is a computer or another network element that communicates with a communications network. A communications node may be configured to control store-and-forward operations between an input and an output of the communications node. In particular, the communications node may manage buffer memory to control store-and-forward operations. The management of the buffer memory may include an admission control approach for admitting data messages with time-out constraints. A time-out constraint provides an indication of the freshness or staleness of a data message stored in the communications node. A time-out constraint defines a maximum desired time difference between admittance of the data message to buffer memory and the transmittance of the data message from the buffer memory.
Some admission control approaches waste buffer memory resources.
For example, if data messages are admitted whenever storage space is available in the buffer memory, the communications node will sometimes waste storage space by admitting a data message which cannot be forwarded within its time-out constraint. Further, the storage space occupied by the held data message blocks prevents other messages from entering the buffer memory for a duration exceeding the time-out constraint of the held data message, reducing space available for other data messages which could meet their time-out constraints.

Falco 5-3-3 Some communication nodes may be fortified with supplemental buffer memory in an attempt to compensate for the foregoing inefficiencies in the management of the buffer memory. However, the cost of a communications node generally increases with the complexity and quantity of buffer memory.
The communications nodes may suffer reduced throughput because their memory capacity can not be expanded beyond a limit. Thus, a need exists for managing admission priority of data messages to reduce buffer memory requirements or to enhance throughput performance.
Summary Of The Invention In accordance with the invention, a method for controlling data flow in a store-and-forward communication node includes deciding whether to grant or deny admission of data messages to the communications node.
A communications node assigns priority value ratings for determining whether to admit a receive data message to a buffer memory of the communications node. A state detector detects if the buffer memory is congested by evaluating the occupancy rate of the buffer memory, or the occupancy rate of at least one queue within the buffer memory. The communications node defines a storage capacity range for each class of priority value ratings of the receive data messages. The communications node admits the receive data message to the buffer memory if the receive arriving message falls within the capacity range of its class of priority value ratings and if the buffer memory is not congested. If the receive arriving message falls within the capacity range, and if the buffer memory is congested, the communications node may delete a lower priority data message to make room for the arriving data message. The foregoing enhancement to a communications node is well-suited for reducing handling time per data message and total memory capacity required to service an anticipated load of data messages at the communications node.

Falco 5-3-3 3 Brief Description Of The Drawin4s FIG. 1 is a block diagram of a wireless communications system that includes a communication node in accordance with the invention.
FIG. 2 is a flow chart of a dynamic method for controlling admission of data messages to a communications node in accordance with the invention.
Detailed Description In accordance with the invention, FIG. 1 shows a store-and-forward communications node 14 that receives receive data messages from a mobile switching center 10, or another network element, at an input 12. If the receive data messages are accepted in accordance with an admission priority scheme, the store-and-forward communications node 14 stores the receive data messages in a buffer memory 36. The buffer memory 36 is logically organized into a group of queues, ranging from a first queue 22 to an nth queue 24. The communications node 14 selects receive data messages from one or more queues to be transmitted as transmit data messages in accordance with a transmission priority scheme. In a preferred embodiment, the output 16 of the store-and-forv~rard communications node 14 is coupled to a base station transmitter for a downlink transmission to one or more mobile stations 20. Although the communications node 14 is shown coupled between the mobile switching center 10 and the base station 18, in an alternate embodiment the communications node may be integrated with a mobile switching center or a base station system.
The communications node 14 includes a processing system 34 coupled to a holding memory 23, a buffer memory 36, and a state detector 26. The processing system 34 hosts a scheduler 28 for managing the transmission priority scheme and an overload controller 33 for handling an admission priority scheme. In practice, a store-and-forward communications node 14 may comprise a router, such as an enhanced digital radio unit (EDRU) for a digital wireless communications system with a priority-based Falco 5-3-3 4 admission and scheduling scheme. The state detector 26 monitors, or otherwise detects, occupancy rate states of the buffer memory 36 or at least one queue within the buffer memory 36. For example, the state detector 26 may measure an occupancy state rate of each active (i.e., partially or completely filled) queue on a regular or periodic basis. The state detector 26 is configured to communicate occupancy rate states with the processing system 34.
The overload controller 33 may include an gatekeeper 30 , a memory manager 32, or both. The gatekeeper 30 controls the admittance of a receive data message to the buffer memory 36 of the store-and-forward communications node 14 from the holding memory 23 based on a status of the buffer memory 36. For example, if the buffer memory 36 is full, the gatekeeper 30 may refuse to admit a receive data message to the buffer memory 36 for processing. If the buffer memory 36 is not full, the gatekeeper 30 may admit the receive data message for processing or storage by the communications node 14. Further, the gatekeeper 30 executes additional conditions, imposed by the processing system 34, for admittance into the buffer memory 36.
The memory manager 32 may delete an existing message in the buffer memory 36 to make room for a more recent receive data message currently at the input 12 or in the holding memory 23 of the communications node 14. Ideally, the average arrival rate of receive data messages at the input 12 of the communications node 14 is less than or equal to the average output 16 rate of corresponding transmit data messages associated with the receive data messages such that deletion of data messages is not necessary. However, the transient or average arrival rate may be greater than the average output rate of the data messages such that the deletion of one or more data messages may become a practical necessity.
In an alternate embodiment, the buffer memory manager 32 makes preemptive deletions of data messages where existing data messages in the buffer memory 36 are deleted before a queue fills. For example, the buffer Falco 5-3-3 5 memory manager 32 may establish preemptive deletions to preserve space for "important" messages and/or simplify processing. The preservation of such space can be configured to meet anticipated demand during peak busy periods. Although the queues may have static maximum sizes, dynamic maximum sizes are preferable to enhance the flexibility of the memory management. The communications node 14 may configure dynamic maximum queue lengths on demand to cover the ongoing traffic patterns of data messages through the communications node 14, rather than fixing static maximum queue lengths based on a potentially arbitrary prediction of actual traffic patterns.
Depending on the performance measures of interest and constraints on complexity, the overload controller 33 may entail a wide variety of admission control algorithms, overload control algorithms, or both. The gatekeeper 30 or the overload controller 33 includes a dynamic admission control algorithm, as will be described in greater detail below. Under the direction of an admission control algorithm or an overload control algorithm of the invention, the overload controller 33 facilitates the efficient use of the buffer memory 36. Further, the overload controller 33 manages the allocation of the existing buffer memory 36 to satisfy throughput demands under specified time constraints.
The store-and-forward communications node 14 may transmit the stored data messages from the buffer memory 36 as transmit data messages on the downlink channel to a mobile station 20. Because the receive data message may have different characteristics than the transmit data message and because of transmission limitations of the air interface, the communications node 14 may store, buffer, or otherwise process the receive data message before transmitting the receive data message over the airlink as a transmit data message.
The processing system 34 may format or structure the receive or stored data message. into a format as a transmit data message that is compatible for transmission over a downlink channel to the mobile stations Falco 5-3-3 6 20. The data messages may be transmitted over any type of communications channel, including a voice, data, or control channel. For example, in the context of a time division multiple access system (TDMA), the processing system 34 may facilitate the transmission of transmit data messages over a downlink digital control channel (DCCH ) and a subchannel (e.g., short messaging servicel paging channel (SPACH)) of the digital control channel. The SPACH provides channel assignments over a downlink signal and may support one-way or two-way short messaging service. The DCCH airlink protocol over a TDMA system provides a maximum number of time slots (e.g., 21 ) in each superframe interval (e.g., 640 millisecond interval) for transmitting a data message.
Although the communications node 14 can readily predict a transmission departure time for a receive data message where the communications node 14 communicates to a downstream TDMA wireless system, other wireless communication systems (e.g., Global System for Mobile Communications (GSM) or code-division, multiple-access systems) may use the system and method for controlling data flow; hence, fall within the scope of the invention.
The scheduler 28 assigns transmit priorities to receive data messages waiting in the buffer memory 36 for transmission as transmit data messages. Although the scheduler 28 may use any type of priority scheme for the data messages, in one example the scheduler 28 assigns receive data messages transmission priorities based on graduated priority rules that vary with different occupancy rates of the queues (22, 24). The occupancy rates of the queues (22, 24) are provided by the state detector 26.
Graduated priority rules encompass schemes, for example, where as the occupancy rates of queues in the buffer memory 36 increase, the assignment of transmission priorities for newly received messages may vary from the previously received messages. Transmission priorities could be assigned such that only critical data messages receive high transmission priorities, while all other data messages receive artificially low transmission Falco 5-3-3 7 priorities by comparison to previously or historically received messages.
Critical data messages may be data messages related to public safety, emergency operations, "911" systems, or the like.
A transmission priority scheme refers to a fixed ranking of the queues associated with the time slot. Each queue may represent a certain overall transmission priority level that is consistent with the contributing transmission priority levels of one or more time slots serving the queue. The processing system 34 examines the queues in their order of their overall transmission priority and the scheduler 28 selects the first message in the first non-empty queue. Thereafter, the second message in the first non-empty queue is selected until all the messages in the first-non-empty queue have been sent. Subsequently, the scheduler 28 examines the second non-empty queue and selects the first message in the second non-empty queue and so on.
The scheduler 28 only assigns transmit priorities to data messages where more than one message is waiting in the buffer memory 36 or a given queue. If only one receive data message is waiting in a buffer memory 36 or an active queue, no judgment on transmit priority needs to be made and the single receive data message may be transmitted immediately or when the next transmit opportunity arises. A superframe for transmission from the communications node may contain special-purpose time slots and all purpose time-slots. The special service time-slots are restricted to serving some subset of the queues, whereas the general purpose time slots serve any of the queues.
For TDMA applications of the communications node 14, a precise understanding of transmit opportunities for the transmit data messages requires knowledge of the DCCH downlink operation. Under current TDMA
standards, for example, during every superframe interval duration (e.g., 640 millisecond interval), the communications node 14 has a maximum number (e.g., 21 ) of time slots in which it can send messages. For reasons of battery conservation, mobiles typically "sleep" (power down) during all but one of Falco 5-3-3 8 these slots; this "listening" time slot for each mobile is randomly assigned among a group of time slots (.e.g., 19) within the superframe interval so as to evenly distribute the mobiles. The initial communication with a mobile to set up a voice or data transmission must occur in this slot. In many cases, when a mobile receives one of these messages, it remains awake and listens to all time slots within the superframe interval.
The method of FIG. 2 addresses dynamically controlling admittance of data messages to the buffer memory 36. An overload controller 33 or a gatekeeper 30 determines whether or not to admit a receive data message to buffer memory 36 of the communications node 14 In step S100, the communications node first assigns or establishes an admission value rating associated with each receive data message.
Secondly, a communications node 14 defines priority classes for the receive data messages. having the assigned admission value ratings. Data messages with comparable admission value ratings are grouped into the same priority class between or among different priority classes. Comparable admission value ratings refers to value ratings which fall within a defined range of each other.
Each priority class may contain one or more data messages with comparable admission value ratings. Within each priority class, each message has an intra-class admission rank to establish a priority ranking for the receive data messages allocated to an individual priority class. For example, the intra-class admission rank may represent an arrival time of arrival of each receive data message relative to the other data messages within the individual priority class.
Although an admission value rating can be assessed in various ways, the primary technique is the potential of a particular receive data message to generate revenue for a service provider. For example, the overload controller 33 may assign a higher value rating to a first receive message representing a channel assignment than a second receive data message representing a paging request, regardless of the order of arrival of the first Falco 5-3-3 9 receive message and the second receive message at the communications node 14. In practice, the channel assignment nearly always results in a billable call-completion, whereas only a fractional, successful number out of the total attempted number of paging messages to mobile stations 20 result in a completed call. Mobile stations may be turned-off or out of range which leads to the lack of call completions originating from paging requests. Thus, channel assignments are considered more valuable than paging messages.
Accordingly, the overload controller 33 may recognize a low priority class for paging data messages and one or more higher priority classes for channel assignment data messages.
Besides revenue generation potential, the admission value rating may be based upon a first-come, first-serve time priority technique, a waiting-time limit of the receive data message, a data packing constraint associated with transmission of the receive data message as a transmit data message, size of the receive data message, or by any other suitable technique. In one example, a data packing constraint may consider allocations of time slots in a superframe to certain corresponding queues within the buffer memory 36. The foregoing allocations can impact data messages awaiting delivery in the queues. In another example, receive data messages of smaller size may be assigned a higher value rating than receive data messages of a larger size or longer length.
After step S100 or simultaneously with step S100, in step S102 the communications node defines a storage capacity range for each priority class of receive data messages. Each priority class is associated with a corresponding storage capacity range. The overload controller 33 allocates a storage capacity range for the receive data messages upon receipt of the receive data messages at the holding memory 23. The capacity range determines the utilization of buffer memory 36 by a particular class of data messages.
In step S102, the capacity range may be defined by an upper boundary , a lower boundary, or both. An upper boundary of the range limits Falco 5-3-3 10 a maximum number of receive data messages per admission priority class.
The upper boundary prevents any single admission class from dominating the buffer memory 36 at the expense of other admission classes.
In contrast, a lower boundary of the range reserves a minimum buffer storage space for data messages of at least one hierarchical class. . The upper boundary prevents any group of admission classes from dominating the buffer memory 36 at the expense of other admission classes. The lower boundary allows minority classes to coexist with higher level or majority classes such that any essential operations represented by the minority classes are not overlooked in a manner that negatively impacts communications system operation.
Although the upper boundary and the lower boundary are defined in terms of the number of messages per class in one illustrative embodiment, in other embodiments the upper boundary and lower boundary may be defined in terms of an overall size of the data messages in a class or by a maximum usable portion of the buffer memory 36. For example, a priority class may have an upper boundary within a range from one-third to two-thirds of the entire buffer memory 36.
After step S102 in step S104, the communications node determines if the arriving data message would fit within the storage capacity range associated with the priority class of the arriving data message. The overload controller 33 enforces upper bound rules on the number of messages of each class which are allowed in the buffer memory 36. The upper-bound rule provides that an arriving message is dropped whenever the number of messages of its class in the buffer memory 36 is equal or exceeds an upper boundary. For example, based on simulation studies, the dynamic algorithm may be initially tuned to set an upper boundary of a particular priority class to one third of the overall buffer memory 36 capacity.
The storage capacity range prevents a sustained overload of a particular class of data messages. Without the intervention and proper operation of the storage capacity range determination in step S104, the Falco 5-3-3 11 overload class could displace the other message classes and "capture" the entire buffer. While the upper-bound rules prevent one class from capturing the buffer, the upper-bound rules do not prevent a class from being excluded due to an overload over a group of classes. In accordance with the reservation rules, the overload controller 33 reserves a nominal number of buffers for each class by using the following reservation rule to determine admissibility of a data message. Although a buffer may be defined as the memory size that may be transmitted in a single time-division multiplex frame or superframe, a buffer preferably represents any unit of memory size (e.g., number of bits, bytes, words, or blocks) or a defined portion of the entire buffer memory 36. The overload controller 33 defines b; as the buffer reserve for priority class j , distinct from priority class i, n ; as the current number of buffers used by class i, n; as the current number of buffers used by class j, and K as the total buffer capacity of the entire buffer memory 36.
The gatekeeper 30 admit a priority class i message only if n; + ~ max(b~ , n~ ) < K
)XJ
That is, the total number of buffers in-use or reserved is less than the overall supply. Note that n; term is pulled out of the sum to avoid counting its reserve as in-use when a class i message arrives.
If the arriving data message would not fit within the storage capacity range, the arriving data message is deleted or redirected as indicated in step S 106.
If the arriving data message would fit within the storage capacity range associated with the priority class of the arriving data message, the method continues with step S108. In step S108, the communications node 14 determines if a buffer memory 36 for storing data messages is congested. Congested means filled to a certain threshold capacity. Although several congestion evaluation techniques may be used, in a preferred example a state detector determines whether the buffer memory 36 is congested based upon an analysis of the occupancy rate of the entire buffer Falco 5-3-3 12 memory 36, rather than any particular priority class. For example, if the actual occupancy rate of the buffer memory 36 exceeds a buffer threshold occupancy rate, the buffer memory 36 is considered to be congested. The storage capacity range and the congestion buffer memory 36 are preferably defined in a distinct manner such that the congestion evaluation facilitates the overall throughput performance of the entire buffer memory 36, whereas the storage capacity range facilitates the throughput performance of individual classes of data messages.
In an alternate embodiment, other suitable techniques for evaluating congestion include determining if an actual occupancy rate of one queue exceeds a queue threshold occupancy rate or determining if an actual occupancy rate of a group of queues exceeds a combination threshold occupancy rate. During the congestion evaluation, the queue or the group of queues is associated with a priority class that is suitable for accepting a particular receive data message under evaluation for admission to that queue or that group of queues.
The buffer threshold occupancy rate represents some workable capacity less than a maximum physical capacity of the entire buffer memory 36. The occupancy rate is evaluated over a series of sequential sampling periods, wherein each sampling period may be associated with a corresponding occupancy rate that ordinarily remains valid for an arriving message until updated with another occupancy rate from the next sampling period.
The buffer threshold occupancy rate is consistent with an overflow target probability. The overload controller 33 can substantially reduce the provisioned storage to a workable capacity of the threshold occupancy rate if the service provider or user is willing to tolerate some probability of overflow. The buffer threshold occupancy rate may be selected based upon empirical data consistent with realistically minimizing deletions of receive data messages. For example, with an overflow probability of one-tenth of Falco 5-3-3 13 one percent, the overload controller 33 reduce the storage requirement by perhaps a factor of five or ten.
For a communications node 14 operating in conjunction with a wireless communications system, no simple analytic expression relates storage size to the overflow probability. Thus, the dynamic based admission control algorithm operates with some simplifying assumptions to manage or minimize data loss.
In an alternate embodiment, the congestion may be defined in terms of the workload durations of one or more of the queues. The workload duration a queue of the buffer memory 36 represent the transmission time required to transmit all data messages in the queue at any particular time from the buffer memory 36, consistent with reliable communication over the air interface of the base station system. For example, if the workload duration of all of the queues together exceeded a threshold time, the buffer memory 36 could be regarded as congested. In yet another embodiment, the congestion may be defined in terms of queue length exceeding threshold queue length.
If the buffer memory 36 for storing data messages is not congested, the communications node admits the arriving data message to the buffer memory 36 as indicated in step S110.
However, if the buffer memory 36, or under other approaches at least one queue, is congested, the method continues in step S112. In step S112, the communications node determines if a held value rating of a held or arriving data message has a greater value rating than an existing priority class of an existing stored data message in the buffer memory 36. The determination of step S112 may be defined in terms of a push-out or displacement rule. The push-out rule admits a data message if the receive data message complies with a hierarchical evaluation of the priority classes.
Although a preferred embodiment features one value rating per priority class, in an alternate embodiment, multiple value ratings per a single priority class are supported.

Falco 5-3-3 14 In general, the push-out rules define an admission hierarchy among admission value ratings, the priority classes, or both. The push-out rules alter the distribution of overflow losses among the various message priority classes. For example, push-out rules typically allow more "valuable"
messages to displace (or push-out) lower value messages when the buffer memory 36 is full. If an arriving message encounters a full buffer memory 36, the overload controller 33 attempts to displace a lower admission priority message. The overload controller 33 looks first at the lowest priority stored message, then works up the hierarchy until a stored data message of the same priority or higher than the arriving data message is reached, to find the lower priority stored message for deletion or displacement.
After step 5112, if the arriving priority class is lower than the existing priority class, the communications node deletes or redirects the data messages as indicated in step S114. If a rejected data message is redirected from the communications node with congested buffer memory 36, the rejected data message may be redirected to an additional communications node acting in cooperation with the communications node to enhance throughput of the communications node 14 or provide redundancy for rejected data messages of having a sufficient or minimum admission value rating.
If the held value rating of a held data message in the holding memory 23 is greater in priority than a stored value rating of an existing stored data message in the buffer memory 36, the method continues with step S116. In step S116, the communications node 14 displaces the existing data message from the buffer memory 36 with the arriving data message. A held data message with the higher priority value rating is allowed to push out a lower priority message, even if the higher priority message arrived after the lower priority message at the input 12 of the communications node 14.
The displacement of step S116 may be accomplished by first deleting a lower priority data message from the buffer memory 36, or by merely overwriting a lower priority data message with a higher priority data Falco 5-3-3 15 message. For example, the gatekeeper 30 admits a first receive data message at the input 12 with a first assigned value rating by displacing a second receive data message with a second assigned rating value lower than the first assigned value rating according to the hierarchical admission rules.
In one example, the low priority messages may be divided among X
different queues in the buffer memory 36; the processing system 34 may use a rotating pointer to distribute push outs among these X queues, wherein X is any whole number. Whenever a push-out is attempted, the pointer is incremented (e.g., mod X in a round-robin manner). If an arriving message does not belong to the high-priority group of classes, or the push-out queue is empty, the message is dropped when the buffer is full.
In sum, the gatekeeper 30 accepts a receive data message from the holding memory 23 if the receive data message falls within the capacity range associated with the class of the data message and if the buffer memory 36 is not congested. If the buffer memory 36 is congested, a push-out evaluation is completed to determine whether or not to displace a stored data message in the buffer memory 36 with an arriving receive data message. The arriving receive data message may remain in the holding memory 23 until the receive data message is admitted to the buffer memory 36, deleted, or redirected.
This specification describes various embodiments of the method of the present invention. The scope of the claims is intended to cover various modifications and equivalent arrangements of the illustrative embodiments disclosed in the specification. Therefore, the following claims should be accorded the reasonable broadest interpretation to cover the modifications, equivalent structures, and features which are consistent with the spirit and the scope of the invention disclosed herein.

Claims (28)

Claims:
1. A method for controlling data flow in a store-and-forward communications node, the method comprising the steps of:
assigning priority value ratings for determining whether to admit a receive data message to a buffer memory of a communications node;
detecting if the buffer memory is congested;
defining a storage capacity range for each class of priority value ratings of the receive data messages; and admitting the receive data message to the buffer memory if the receive arriving message falls within the capacity range and if the buffer memory is not congested.
2. The method according to claim 1 wherein the assigning step comprises assigning intra-class priority ranks to establish an admission hierarchy of receive data messages within a particular class.
3. The method according to claim 1 wherein the detecting step comprises:
determining that the buffer memory is congested if an actual occupancy rate of the buffer memory exceeds a threshold occupancy rate.
4. The method according to claim 1 wherein the detecting step comprises:
determining that the buffer memory is congested if an actual occupancy rate of a queue exceeds a queue threshold occupancy rate, the queue being suitable for accepting the receive data message based on its priority class.
5. The method according to claim 1 wherein the detecting step comprises:
determining that the buffer memory is congested if an actual occupancy rate of a combination of queue occupancy rates exceeds a threshold combination occupancy rate, each queue of the combination being suitable for accepting the receive data message based on its priority class.
6. The method according to claim 1 further comprising the step of:
displacing a stored data message in the buffer memory with an arriving receive data message if the arriving receive data message has a first assigned rating value higher than a second assigned value rating of the stored data message and if at least one queue within the buffer memory is congested.
7. The method according to claim 1 further comprising the step of:
displacing a stored data message in the buffer memory with an arriving receive data message if the arriving receive data message has a first assigned rating value higher than a second assigned value rating of the stored data message and if the buffer memory is congested.
8. The method according to claim 1 further comprising the step of:
assigning the priority value rating to the receive data message based on a revenue generating factor associated with the receive data message
9. The method according to claim 1 further comprising the step of:
assigning a higher value rating to a first receive data message representing a channel assignment than a second receive data message representing a paging request.
10. The method according to claim 9 wherein the admitting step further comprises:
displacing the second receive data message from the buffer memory upon arrival of the first receive data message at the input, if the detection step determines the buffer memory is congested.
11. The method according to claim 1 wherein the admitting step further comprises:
distributing displacement of receive data messages from the buffer memory among a plurality of queues within the buffer memory when receive data messages with higher value ratings displace data messages with lower value ratings.
12. The method according to claim 1 wherein the defining step comprises:
limiting a maximum number of receive data messages per priority class to be admitted to the buffer memory to comply with an upper boundary of the storage capacity range.
13. The method according to claim 12 further comprising the step of:
not admitting a data message into the buffer memory if the number of stored data messages in the buffer memory for the priority class associated with the held data message exceeds the maximum number.
14. The method according to claim 1 wherein the defining step further comprises:
limiting a maximum storage capacity size for receive data messages per priority class to be admitted to the buffer memory to comply with an upper boundary of the storage capacity range.
15. The method according to claim 14 further comprising the step of:
setting the maximum storage capacity size as one third of the overall memory buffer capacity.
16. The method according to claim 1 wherein the defining step comprises:
reserving a minimum number of messages for data messages of at least one priority class as a lower boundary of the range.
17. The method according to claim 1 wherein the defining step further comprises:
reserving a minimum class storage capacity size for data messages of at least one priority class as a lower boundary of the range.
18. The method according to claim 17 wherein the minimum class storage capacity size is defined as a number of buffers reserved in accordance with the following formula: n i ~ max(b j, n j) < K, wherein b j is a buffer reserve for priority class j distinct from priority class i, n i is the current number of buffers used by class i, , n; is the current number of buffers used by class j and K is the total buffer capacity of the buffer memory.
19. The method according to claim 1 wherein the admitting step further comprises:
displacing a stored data message from the buffer memory upon arrival of a later receive data message at the input, where the stored data message has an oldest arrival time within the priority class.
20. The method according to claim 1 wherein the admitting step further comprises:
displacing a stored data message from the buffer memory upon arrival of a later receive data message at the input, where the stored data message has an oldest arrival time within a queue in the buffer memory.
21. The method according to claim 1 wherein the admitting step further comprises:
displacing a stored data message from the buffer memory upon arrival of a later receive data message at the input, where the stored data message has an oldest arrival time in the entire buffer memory.
22. The method according to claim 1 further comprising the step of:
displacing a stored data message in a buffer memory with an arriving receive data message if the arriving receive data message has a more recent arrival time than that of the stored data message and if the buffer memory is congested.
23. A communications node comprising:
an overload controller for assigning priority value ratings for determining whether to admit a receive data message to a buffer memory of a communications node, the overload controller defining a storage capacity range for each class of priority value ratings of the receive data messages;
a detector for detecting if the buffer memory is congested; and a gatekeeper for admitting the receive data message to the buffer memory if the receive arriving message falls within the capacity range and if the buffer memory is not congested.
24. The communications node of claim 23 further comprising:
a holding memory for holding the receive data message prior to admittance to the buffer memory.
25. The communications node of claim 24 further comprising:
a memory manager for deleting an existing data message in the buffer memory to make room for a more recent receive data message in the holding memory of the communications node.
26. The communications node of claim 23 further comprising:
a memory manager for deleting an existing data message in the buffer memory to make room for a more recent receive data message at an input of the communications node.
27. The communications node of claim 23 where in the detector is adapted to detect the occupancy rate of the buffer memory.
28. The communications node of claim 23 where in the detector is adapted to detect the occupancy rate of a group of queues within the buffer memory.
CA002320709A 1999-10-01 2000-09-26 Method for controlling data flow associated with a communications node Abandoned CA2320709A1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/410,615 1999-10-01
US09/410,615 US6700869B1 (en) 1999-10-01 1999-10-01 Method for controlling data flow associated with a communications node

Publications (1)

Publication Number Publication Date
CA2320709A1 true CA2320709A1 (en) 2001-04-01

Family

ID=23625497

Family Applications (1)

Application Number Title Priority Date Filing Date
CA002320709A Abandoned CA2320709A1 (en) 1999-10-01 2000-09-26 Method for controlling data flow associated with a communications node

Country Status (5)

Country Link
US (1) US6700869B1 (en)
EP (1) EP1093259B1 (en)
JP (1) JP4712951B2 (en)
BR (1) BR0004545A (en)
CA (1) CA2320709A1 (en)

Families Citing this family (50)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0825506B1 (en) * 1996-08-20 2013-03-06 Invensys Systems, Inc. Methods and apparatus for remote process control
US6047284A (en) 1997-05-14 2000-04-04 Portal Software, Inc. Method and apparatus for object oriented storage and retrieval of data from a relational database
US7089530B1 (en) 1999-05-17 2006-08-08 Invensys Systems, Inc. Process control configuration system with connection validation and configuration
WO2000070531A2 (en) 1999-05-17 2000-11-23 The Foxboro Company Methods and apparatus for control configuration
US6788980B1 (en) 1999-06-11 2004-09-07 Invensys Systems, Inc. Methods and apparatus for control using control devices that provide a virtual machine environment and that communicate via an IP network
AU2000275416A1 (en) * 2000-10-03 2002-04-15 U4Ea Technologies Limited Allocating priority levels in a data flow
JP2002156777A (en) * 2000-11-21 2002-05-31 Fujitsu Ltd Toner for photofixing
US6990114B1 (en) * 2001-03-26 2006-01-24 Advanced Micro Devices, Inc. System and method for deciding outgoing priority for data frames
US7464180B1 (en) 2001-10-16 2008-12-09 Cisco Technology, Inc. Prioritization and preemption of data frames over a switching fabric
US8145787B1 (en) * 2001-10-16 2012-03-27 Cisco Technology, Inc. Adaptive bandwidth utilization over fabric links
US8099393B2 (en) 2002-03-22 2012-01-17 Oracle International Corporation Transaction in memory object store
JP3761486B2 (en) * 2002-03-29 2006-03-29 Necインフロンティア株式会社 Wireless LAN system, main device and program
US6901063B2 (en) * 2002-05-13 2005-05-31 Qualcomm, Incorporated Data delivery in conjunction with a hybrid automatic retransmission mechanism in CDMA communication systems
US7436769B2 (en) * 2002-05-23 2008-10-14 Lucent Technologies Inc. Method of throttling data flow through a router
US20040249917A1 (en) * 2003-06-05 2004-12-09 Cheng Yung Lin Data flow management method
US9325998B2 (en) * 2003-09-30 2016-04-26 Sharp Laboratories Of America, Inc. Wireless video transmission system
US8018850B2 (en) * 2004-02-23 2011-09-13 Sharp Laboratories Of America, Inc. Wireless video transmission system
US8356327B2 (en) 2004-10-30 2013-01-15 Sharp Laboratories Of America, Inc. Wireless video transmission system
US7797723B2 (en) * 2004-10-30 2010-09-14 Sharp Laboratories Of America, Inc. Packet scheduling for video transmission with sender queue control
US7784076B2 (en) * 2004-10-30 2010-08-24 Sharp Laboratories Of America, Inc. Sender-side bandwidth estimation for video transmission with receiver packet buffer
ATE481920T1 (en) * 2004-11-02 2010-10-15 Medtronic Inc METHOD FOR DATA RETENTION IN AN IMPLANTABLE MEDICAL DEVICE
US7616664B2 (en) 2005-02-18 2009-11-10 Hewlett-Packard Development Company, L.P. System and method of sending video and audio data over a network
JP2006262143A (en) * 2005-03-17 2006-09-28 Ibm Japan Ltd Communication relay device, information management system, control method and program
US8223935B2 (en) * 2005-04-30 2012-07-17 Oracle International Corporation Revenue management systems and methods
CA2613701C (en) 2005-06-28 2016-04-12 Alexander Rockel Revenue management system and method
AU2006275665A1 (en) * 2005-07-28 2007-02-08 Oracle International Corporation Revenue management system and method
US7577133B1 (en) * 2005-09-09 2009-08-18 Juniper Networks, Inc. Scalable central memory switching fabric
US20070067480A1 (en) * 2005-09-19 2007-03-22 Sharp Laboratories Of America, Inc. Adaptive media playout by server media processing for robust streaming
US8223777B2 (en) 2005-11-15 2012-07-17 Oracle International Corporation Gateway for achieving low latency and high availability in a real time event processing system
US9544602B2 (en) * 2005-12-30 2017-01-10 Sharp Laboratories Of America, Inc. Wireless video transmission system
US7593330B1 (en) 2006-01-30 2009-09-22 Juniper Networks, Inc. Processing of partial frames and partial superframes
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
CA2547310C (en) 2006-04-06 2013-04-09 Dragonwave, Inc. Apparatus and methods for controlling effective communication traffic rates
US7769038B2 (en) * 2006-05-01 2010-08-03 Agere Systems Inc. Wireless network scheduling methods and apparatus based on both waiting time and occupancy
US8861597B2 (en) * 2006-09-18 2014-10-14 Sharp Laboratories Of America, Inc. Distributed channel time allocation for video streaming over wireless networks
US9349114B2 (en) * 2006-10-31 2016-05-24 Hewlett Packard Enterprise Development Lp Systems and methods for managing event messages
US7652993B2 (en) * 2006-11-03 2010-01-26 Sharp Laboratories Of America, Inc. Multi-stream pro-active rate adaptation for robust video transmission
US8089970B2 (en) * 2006-12-14 2012-01-03 Ntt Docomo, Inc. Method and apparatus for managing admission and routing in multi-hop 802.11 networks taking into consideration traffic shaping at intermediate hops
US7830918B2 (en) * 2007-08-10 2010-11-09 Eaton Corporation Method of network communication, and node and system employing the same
CN102124432B (en) 2008-06-20 2014-11-26 因文西斯系统公司 Systems and methods for immersive interaction with actual and/or simulated facilities for process, environmental and industrial control
US8463964B2 (en) 2009-05-29 2013-06-11 Invensys Systems, Inc. Methods and apparatus for control configuration with enhanced change-tracking
US8127060B2 (en) 2009-05-29 2012-02-28 Invensys Systems, Inc Methods and apparatus for control configuration with control objects that are fieldbus protocol-aware
JP5191059B2 (en) * 2009-06-23 2013-04-24 日本電信電話株式会社 Buffer circuit and buffer circuit control method
CN103036794A (en) * 2011-10-10 2013-04-10 华为技术有限公司 Learning method, device and system of message
WO2014022492A1 (en) * 2012-07-31 2014-02-06 Huawei Technologies Co., Ltd. A method to allocate packet buffers in a packet transferring system
WO2014057596A1 (en) * 2012-10-09 2014-04-17 パナソニック株式会社 Wireless communication device, wireless communication method, and wireless communication control program
US9794141B2 (en) 2013-03-14 2017-10-17 Arista Networks, Inc. System and method for determining a cause of network congestion
US9800485B2 (en) * 2013-03-14 2017-10-24 Arista Networks, Inc. System and method for determining an effect of network congestion
US10360267B2 (en) * 2015-06-10 2019-07-23 Futurewei Technologies, Inc. Query plan and operation-aware communication buffer management
JP2017027196A (en) * 2015-07-17 2017-02-02 株式会社リコー Communication device, power control method, and power control program

Family Cites Families (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4146839A (en) * 1977-02-04 1979-03-27 Troy Stephen R Channel traffic monitoring radio transceiver
JP2869080B2 (en) * 1989-01-19 1999-03-10 沖電気工業株式会社 Buffer control device
US5097499A (en) 1990-08-22 1992-03-17 At&T Bell Laboratories Autonomous registration overload control for cellular mobile radio systems
JP2889936B2 (en) * 1990-11-06 1999-05-10 日本電信電話株式会社 Communication class setting method
US5528513A (en) 1993-11-04 1996-06-18 Digital Equipment Corp. Scheduling and admission control policy for a continuous media server
JPH07135512A (en) * 1993-11-11 1995-05-23 Hitachi Ltd Router
US5553061A (en) * 1994-06-27 1996-09-03 Loral Fairchild Corporation Packet processor having service priority and loss priority features
EP0748087A1 (en) * 1995-06-09 1996-12-11 International Business Machines Corporation Access control system for a shared buffer
JPH1084386A (en) * 1996-09-10 1998-03-31 Toshiba Corp Control input computer in congestion control of packet communication system, control input calculation method, communication quality computer and communication quality calculation method
US6081505A (en) * 1997-03-20 2000-06-27 Nokia Telecommunications, Oy Cell scheduling system and method for networks nodes
KR100247022B1 (en) * 1997-06-11 2000-04-01 윤종용 A single switch element of atm switching system and buffer thresholds value decision method
JPH1132055A (en) * 1997-07-14 1999-02-02 Fujitsu Ltd Buffer controller and buffer control method
US6018515A (en) * 1997-08-19 2000-01-25 Ericsson Messaging Systems Inc. Message buffering for prioritized message transmission and congestion management
JP2959539B2 (en) * 1997-10-01 1999-10-06 日本電気株式会社 Buffer control method and device
US6112101A (en) * 1997-10-09 2000-08-29 Ericsson Inc. Load based priority for the mobile subscriber
US6091709A (en) * 1997-11-25 2000-07-18 International Business Machines Corporation Quality of service management for packet switched networks
JP3000990B2 (en) * 1997-12-18 2000-01-17 日本電気株式会社 Discard priority control method and method
US6246691B1 (en) * 1998-08-14 2001-06-12 Siemens Aktiengesellschaft Method and circuit configuration for the transmission of message units in message streams of different priority

Also Published As

Publication number Publication date
BR0004545A (en) 2001-05-29
EP1093259A3 (en) 2004-03-17
US6700869B1 (en) 2004-03-02
EP1093259A2 (en) 2001-04-18
JP4712951B2 (en) 2011-06-29
JP2001136193A (en) 2001-05-18
EP1093259B1 (en) 2014-01-29

Similar Documents

Publication Publication Date Title
US6700869B1 (en) Method for controlling data flow associated with a communications node
US6501733B1 (en) Method for controlling data flow associated with a communications node
US7599321B2 (en) Prioritization of connection identifiers for an uplink scheduler in a broadband wireless access communication system
US20020052205A1 (en) Quality of service scheduling scheme for a broadband wireless access system
EP0706297A1 (en) Method for operating traffic congestion control in a data communication network and system for implementing said method
CN110808920B (en) Satellite communication flow control method with coexistence of CCSDS frame and IP message
CN109618375B (en) UAV ad hoc network time slot scheduling method based on service priority and channel interruption probability
CN101310483B (en) Method and base station for scheduling HSDPA
CN100369524C (en) CDMA system up-bag dispatching method
US20010036194A1 (en) Radio telecommunications system with improved use of timeslots
EP1478133B1 (en) Preemptive precedence scheduler for communications link bandwidth
Jacquet et al. Data transfer for hiperlan
JP2000069548A (en) Communication band assignment method
Moorman et al. Multiclass priority fair queuing for hybrid wired/wireless quality of service support
Koutsakis et al. Highly efficient voice—data integration over medium and high capacity wireless TDMA channels
KR100446794B1 (en) A traffic control technology in home network through adaptive priority control
Thilakawardana et al. Efficient call admission control and scheduling technique for GPRS using genetic algorithms
Ajib et al. Service disciplines performance for best-effort policies in packet-switching wireless cellular networks
Mishra et al. Congestion control and fairness with dynamic priority for ad hoc networks
Ajib et al. Service disciplines performance for WWW traffic in GPRS system
Liang et al. A novel bandwidth allocation algorithm for IEEE 802.16 TDD mode wireless access networks
Ferng et al. Channel allocation and performance study for the integrated GSM/GPRS system
Khan Performance of a multipriority resource allocation technique for a packet switched wireless multimedia network
Chen et al. An efficient QoS guaranteed MAC protocol in wireless ATM networks
Thng et al. A robust M/M/1/k scheme for providing handoff dropping QoS in multi-service mobile networks

Legal Events

Date Code Title Description
EEER Examination request
FZDE Discontinued