Adaptive network traffic shaper
First Claim
1. A method for transmitting packets of data from a source network to a destination network, said method comprising the steps of:
- classifying each packet accordingly to its ability to match a series of filters, and marking each packet with the classification;
applying each packet to a queue of a set of queues in dependence upon the packet'"'"'s classification;
reading said packets from each queue in accordance with a predetermined queue reading policy;
observing a volume of traffic arriving at each queue during N−
2n previous time intervals to thereby define traffic load history for each queue, where n is a system parameter and N is a current time step;
from said traffic load history, constructing a matrix Xj[N] for each queue j={0, . . . , M} that captures a state of the traffic entering that queue;
performing an eigen analysis of the matrix Rj[N]=(Xj[N])T(XJ[N]) to produce a set of vectors Uj[N] that capture a spectral basis of the traffic state;
comparing a current traffic state to the traffic state at time k by projection Xj[N] onto the spectral bases Uj[k] according to the relation
1 Assignment
0 Petitions
Accused Products
Abstract
A network traffic shaper adjusts the rate of data flowing from a packet source to a packet sink responsive to priority assigned to the packets pursuant to their ability to match a series of filters. Each packet is applied to a queue depending on its classification. The packets are read from each queue in accordance with a queue reading policy. Singular spectrum analysis of the traffic load produces a set of vectors that capture the spectral bases of the traffic state. These vectors are associated with the bandwidth demanded by the traffic, a relationship that is recorded in a queue/time/eigenvector/bandwidth/control table. Samples of the current network load are compared with previously recorded vector bases to reveal how similar the current traffic state is to previous traffic states, which in turn predicts the traffic'"'"'s bandwidth needs for the immediate future. The queue reading regime is updated in response to this prediction.
-
Citations
18 Claims
-
1. A method for transmitting packets of data from a source network to a destination network, said method comprising the steps of:
-
classifying each packet accordingly to its ability to match a series of filters, and marking each packet with the classification; applying each packet to a queue of a set of queues in dependence upon the packet'"'"'s classification; reading said packets from each queue in accordance with a predetermined queue reading policy; observing a volume of traffic arriving at each queue during N−
2n previous time intervals to thereby define traffic load history for each queue, where n is a system parameter and N is a current time step;from said traffic load history, constructing a matrix Xj[N] for each queue j={0, . . . , M} that captures a state of the traffic entering that queue; performing an eigen analysis of the matrix Rj[N]=(Xj[N])T(XJ[N]) to produce a set of vectors Uj[N] that capture a spectral basis of the traffic state; comparing a current traffic state to the traffic state at time k by projection Xj[N] onto the spectral bases Uj[k] according to the relation
-
-
2. A method for prioritizing network traffic to control quality-of-service where each of a plurality of packets carries information relating to its priority relative to other messages, said method comprising the steps of:
-
observing at least packet sizes and data each of the packets contain; determining each of the packet'"'"'s priority based on the data it contains; routing each of the packets to one of a plurality of queues allocated to a relevant priority; temporarily storing said packet sizes and their destination queue numbers; determining and storing a volume of data arriving at each of the queues over a time window using the temporarily stored packet sizes and destination queue numbers; determining a load spectrum of incoming network traffic by singular spectrum analysis using the determined volume of data from each of the queues; associating the load spectrum with a rate of data arriving at each of the queues over a time window; and applying the packets of said network traffic to a traffic shaper, which allocates a portion of an available transmission bandwidth to each of the queues according to a stored policy. - View Dependent Claims (3, 4, 5, 16, 17, 18)
-
-
6. A method for transmitting packets of information from a source network, said method comprising the steps of:
-
classifying a priority of each of the packets based on data it contains; marking each of the packets with the classification; applying each of the packets to one of a plurality of queues depending upon its marked priority; reading each of the queues according to a queue reading policy; while said packets are traversing said queues, calculating a traffic spectral basis and associated network bandwidth to generate a queue/time/eigenvector/bandwidth/control table; finding a similarity of a current traffic state to a traffic state at time k by calculating a distance from the spectral basis at time k; searching the queue/time/eigenvector/bandwidth/control table for a previously observed traffic state that is similar to the current traffic state to determine an expected network bandwidth demand; and updating the queue reading policy to meet the expected network bandwidth demand.
-
-
7. A system for prioritizing network traffic including a plurality of packets, where each of the packets of said network traffic carries information relating to its priority relative to other messages, said system comprising:
a processor executing instructions to perform the steps of; observing at least packet sizes and data each of the packets contain; determining each of the packet'"'"'s priority based on the data it contains; routing each of the packets to one of a plurality of queues allocated to a relevant priority; temporarily storing said packet sizes and their destination queue numbers using the temporarily stored packet sizes and destination queue numbers; determining and storing a volume of data arriving at each of the queues over a time window using the determined volume of data from each of the queues; determining a load spectrum of incoming network traffic by singular spectrum analysis; associating the load spectrum with a rate of data arriving at each of the queues over a time window; and applying the packets of said network traffic to a traffic shaper, which allocates a portion of an available transmission bandwidth to each of the queues according to a stored policy. - View Dependent Claims (8, 9, 10, 11, 12, 13, 14, 15)
Specification