Efficient allocation of bandwidth across a communication network is an important contributor to the network's quality of service (QoS) to its users. Intermittent bursts in network traffic poses a challenge to efficient bandwidth allocation, as communication channels experiencing such bursts have fluctuating bandwidth requirements. Allocating too little bandwidth to a channel results in sluggish data transmission when bursts occur. Allocating the channel sufficient bandwidth to accommodate bursts is inefficient, as the channel does not utilize its full bandwidth during relatively low data-rate periods occurring between bursts.
In a first aspect, a method for predicting network-traffic bursts is disclosed. The method includes identifying, in data received by a networking device, a plurality of network-traffic bursts, each of the plurality of network-traffic bursts occurring at a respective one of plurality of burst-times {tN, tN-1, . . . , t0}, N≥3. The method also includes determining a time-interval x of a next burst occurring at x after burst-time t1 by determining respective values of predicted time-interval τn, a parameter ξ, and a parameter η. Time-interval τn, parameter ξ, and parameter η minimize, to within a tolerance, a quantity (fk (ξ,η,k)−(τn−tk)) for at least three values of a positive integer k≤N. Parameters and η are, respectively, a real part and an imaginary part of a power-law exponent of a power law relating predicted time-interval x to any of the plurality of burst-times. The method also includes determining, from a cumulative distribution function of a normal distribution of previously-identified network-traffic bursts associated with a previously-predicted burst-time τp, a time-duration during which the networking device may reallocate bandwidth according to at least one of traffic type, a subnet mask, and IP address. Previously-predicted burst-time τp differs from predicted time-interval τn by less than a predetermined tolerance.
In a second aspect, network-traffic burst predictor is disclosed. The network-traffic burst predictor includes a processor communicatively coupled to both a networking device and a memory. The memory stores non-transitory computer-readable instructions that, when executed by the processor, control the processor to execute the method of the first aspect.
Embodiments disclosed herein employ a quantitative method for predicting the timing of bursts in communication network traffic, e.g. wireline communication network traffic or wireless communication network traffic. The predictions may be used to reallocate bandwidth in more optimal ways. For example, if the next burst is predicted to occur no earlier than the minutes from now with a certain probability, then these ten minutes of underutilized bandwidth may be reallocated to other uses.
In embodiments, a burst prediction model relies a power law distribution for the cumulative bytes that flow between bursts. Equation (1) is of simple power-law distribution:
Σbytes=C(τn−t)β, (1)
where τn is a predicted time-interval before the next burst, τn>t, and β is an index that, in embodiments, is positive and less than unity, such as β=0.84.
The flow of bytes per unit time is given by the derivative of the equation (1), equation (2), where α=β−1<0.
Flow=C(τn−t)α (2)
In general, exponent a can be written as complex number α=ξ+iη, which enables equation (2) to be expressed as equation (3), where (τn−t)iη is replaced by Re{cos(η ln(τn−t))+i sin(η ln(τn−t))}=cos(η ln(τn−t)), which ensures a non-complex value for data rate.
Flow=C(τn−t)ξ cos[η ln(τn−t)] (3)
Bursts by their very nature are local maxima of equation (3), such that they can be found by taking the first derivative of equation (3) and setting it equal to zero, as shown in equation (4).
Eliminating common factors and dividing by the cosine term yields equation (5).
ξ tan [η ln(τn−tk)±kπ]=ξ/η(5)
In equation (5), the kit term denotes the kth maximum at time tk. Applying the inverse tangent function to equation (5) and exponentiating both sides yields:
η ln(τn−t)±kπ=arctan(ξ/η) (6)
Solving equation (6) for τn and choosing the +kπ yields equation (7), which relates the time to the next burst as measured from the kth previous burst:
τn=tk exp [η−1 arctan(ξ/η)+kπ/η]. (7)
In general, the time of the burst at predicted burst-interval τn can be found given η and any two prior bursts p1 and p2, from the following equation:
τn=(tp
Line 202 is a best-fit line to scatter plot 200 generated by applying N=6 measured burst times to equation (7), where ={m5, m4, m3, m2, m1, m0} denote the N measured burst times. In burst-time set , burst-time mk+1 occurs before burst-time mk. The measured burst times were applied to equation (7) as shown in equations (9a)-(9e), hereinafter equations (9), to determine best-fit values of values of ξ and η, denoted herein as ξfit and τfit, via a Levenberg-Marquardt method. In embodiments, other curve-fitting, minimization, and/or optimization methods may be used to determine ξfit and ηfit.
m
0
=m
1+exp[η−1 arctan(ξ/η)+π/η] (9a)
m
0
=m
2+exp[η−1 arctan(ξ/η)+2π/η] (9b)
m
0
=m
3+exp[η−1 arctan(ξ/η)+3π/η] (9c)
m
0
=m
4+exp[r7−1 arctan(ξ/η)+4π/η] (9d)
m
0
=m
5+exp[η−1 arctan(ξ/η)+5π/η] (9e)
The values for ξfit and ηfit determined from equations (9), were applied again to equation (7) to predict next-burst estimates τ1-5, as shown in equations (10a)-(10e).
τ1=m0+exp[ηfit−1 arctan(ξfit/ηfit)+π/ηfit] (10a)
τ2=m1+exp[ηfit−1 arctan(ξfit/ηfit)+2π/ηfit] (10b)
τ3=m2+exp[ηfit−1 arctan(ξfit/ηfit)+3π/ηfit] (10c)
τ4=m3+exp[ηfit−1 arctan(ξfit/ηfit)+4π/ηfit] (10d)
τ5=m4+exp[ηfit−1 arctan(ξfit/ηfit)+5π/ηfit] (10e)
The predicted next-burst estimates τ1-5 were averaged to yield a mean-predicted next-burst
The computations associated in equations (9) and (10) were repeated several times, each with a respective N-element set of measured burst times, to generate scatter plot 200,
In the examples of
For a given interval of predicted bursts, the distributions of measured bursts in
The normal distribution of measured bursts with respect to predicted burst-intervals τn enables use the cumulative distribution function (CDF) of the normal distribution to pick a QoS value. For example, in a use scenario, the predicted time-interval until the next burst (predicted burst-interval τn) is close to a previously-predicted interval τp. In embodiments, previously-predicted interval τp is determined to be the one of P previously-predicted intervals τ that is closest to predicted burst-interval τn. In embodiments, predicted burst-interval τn differs from a previously-predicted interval τp by less than a predetermined difference δτ.
The normal distribution associated with previously-predicted interval τp is characterized by a mean-value μp and a standard deviation σp. In such a case, channel resources such as bandwidth may be freed for a time interval τfree related to the CDF of the normal distribution:
CDF=½+½+erf[(τfree−μp)/√{square root over (2)}σp] (11)
In embodiments, mean-value μp and a standard deviation σp are averages of normal distributions associated with a quantity Q<P previously-predicted intervals τ that, among the P previously predicted intervals τ, are closest to predicted burst-interval τn. In embodiments, the Q previously-predicted intervals represent a top quantile of the P previously-predicted intervals in terms of their proximity to predicted burst-interval τn. The top quantile is, for example, a top decile or smaller group, such as a top two percent.
The value of CDF evaluated at time interval τfree is the probability that the next burst will occur before predicted burst-interval τn. If a network device reallocates bandwidth during a next-burst interval τfree, bursts occurring within next-burst interval τfree decreases QoS for lack of sufficient bandwidth to accommodate the bursts. Quality of service QoS may be defined as the probability of having sufficient bandwidth during next-burst interval τn, or QoS=(1−CDF). When CDF equals zero and one, the probability of bandwidth being insufficient during next-burst interval τfree is zero and one, respectively. Replacing CDF with QoS in equation (11) and solving for τfree yields equation (12). That is, for a given τn and contracted CDF=(1−QoS) the resources are freed up for a time given by:
τfree=√{square root over (2)}σp erf−1(1−2QoS)+μp, (12)
where erf−1 denotes the inverse error function.
In embodiments, the functional relationship between CDF and QoS differs from CDF=(1−QoS). For example, the quality-of-service metric may be a decreasing function of the cumulative distribution function.
Network device 520 is communicatively connected to network nodes 530(1-M0) via a plurality of communication channels 535(1-M5). Network device 520 is communicatively connected to network nodes 550(1-N0) via a plurality of network channels 545(1-N5). Traffic on any one of communication channels 535 and 555 may include network traffic bursts, of which network-traffic bursts 110 are an example. Traffic on any of communication channels 535 and 555 may be en route either to or from any one of network nodes 530 and 550. In embodiments, integer M5 may be less than or equal to integer M0, and integer N5 is less than or equal to integer N0.
In some embodiments, network 500 includes part or all of a wireline communication network and/or a wireless communication network. Some examples of possible wireline communication networks include networks operating according to one or more of a data over cable services interface specification (DOCSIS) protocols, digital subscriber line (DSL) protocols, ethernet passive optical network (EPON) protocols, gigabit passive optical network (GPON) protocols, and radio frequency over glass (RFOG) protocols. Some examples of possible wireless networks include networks operating according to one or more of long term evolution (LTE) protocols, fifth generation (5G) new radio (NR) protocols, sixth generation (6G) protocols, Wi-Fi protocols, microwave communication protocols, and Satellite communication protocols.
Burst predictor 510 includes a memory 514 communicatively coupled to a processor 512. Memory 514 may be transitory and/or non-transitory and may include one or both of volatile memory (e.g., SRAM, DRAM, computational RAM, other volatile memory, or any combination thereof) and non-volatile memory (e.g., FLASH, ROM, magnetic media, optical media, other non-volatile memory, or any combination thereof). Part or all of memory 514 may be integrated into processor 512. Memory 514 includes machine-readable instructions. Processor 512 is adapted to execute the machine-readable instructions to perform functions of burst predictor 510 described herein.
Step 610 includes identifying, in data received by a networking device, a plurality of network-traffic bursts, each of the plurality of network-traffic bursts occurring at a respective one of plurality of burst-times {tN, tN-1, . . . , t0}, N≥3. In an example of step 610, one of network device 520 and burst predictor 510 detects network-traffic bursts in network channel 535(1) of network 500.
Step 620 includes determining a time-interval τn of a next burst occurring at τn after burst-time t1 by determining respective values of predicted time-interval τn, a parameter ξ, and a parameter η. Time-interval parameter ξ, and parameter η minimize, to within a tolerance, a quantity (fk(ξ,η,k)−(τn−tk)) for at least three values of a positive integer k≤N. Parameters ξ and η are, respectively, a real part and an imaginary part of a power-law exponent of a power law relating predicted time-interval τn to any of the plurality of burst-times. In an example of step 620, burst predictor 510 determines mean-predicted next-burst f from next-burst estimates τ1-5 of equations (10).
In embodiments, step 620 includes at least one of steps 622 and 624. Step 622 includes determining values ξmin and ηmin of parameters ξ and η as those that minimize, within a predetermined tolerance a combination of (fk(ξ,η,k)−(tn−tk)) for k=1, 2, . . . , N. Step 624 includes determining τn as an average of burst intervals τk=tk+fk (ξmin,ηmin,k), for k=1, 2, . . . , N. In an example of step 622, burst predictor 510 determines parameters ξ and η that minimize equations (9) to within a predetermined tolerance. In an example of step 620, burst predictor 624 determines mean-predicted next-burst f from next-burst estimates τ1-5 of equations (10).
Step 630 includes determining, from a cumulative distribution function of a normal distribution of previously-identified network-traffic bursts associated with a previously-predicted burst-time τp, a time-duration during which the networking device may reallocate bandwidth according to at least one of traffic type, a subnet mask, and IP address. Previously-predicted burst-time τp differs from predicted time-interval τn by less than a predetermined tolerance. In an example of step 630, burst predictor 510 determines next-burst interval τfree per equations (11) and (12).
In embodiments, step 630 includes at least one of steps 632, 634, and 636. Step 632 includes determining the time-duration from a mean burst-time μp and a standard deviation σp of the normal distribution. In an example of step 632, burst predictor 510 determines next-burst interval τfree in part from equations (11) and (12), which include mean burst-time μp and standard deviation σp.
Step 634 includes determining the time-duration as √{square root over (2)}p erf−1(1−2QoS)+μp, where QoS is a predetermined metric related to a probability of having sufficient bandwidth during the time-duration. In an example of step 634, burst predictor 510 determines next-burst interval τfree using equation (12).
Step 636 includes determining the mean burst-time μp and the standard deviation σp by curve-fitting the previously-identified network-traffic bursts. In a first example of step 636, burst predictor 510 fits normal distribution 212 to measured traffic bursts occurring in time-interval 210,
Step 640 includes reallocating bandwidth during the time-duration and according to at least one of traffic type, a subnet mask, and IP address during the time-duration. In an example of step 640, burst predictor 510 reallocated bandwidth from communication channel 535(1) to one or more communication channels 535(2-M5) during next-burst interval τfree.
Changes may be made in the above methods and systems without departing from the scope hereof. It should thus be noted that the matter contained in the above description or shown in the accompanying drawings should be interpreted as illustrative and not in a limiting sense. Herein, and unless otherwise indicated, the adjective “exemplary” means serving as an example, instance, or illustration. The following claims are intended to cover all generic and specific features described herein, as well as all statements of the scope of the present method and system, which, as a matter of language, might be said to fall therebetween.
This application is a continuation of U.S. patent application Ser. No. 16/375,782, filed Apr. 4, 2019, which application claims benefit of priority to U.S. Provisional Patent Application Ser. No. 62/652,786, filed on Apr. 4, 2018, which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
62652786 | Apr 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16375782 | Apr 2019 | US |
Child | 17020286 | US |