This application is related to co-pending patent application Ser. No. 10/187,089, filed on even date herewith, and entitled “METHOD AND APPARATUS FOR LOAD ESTIMATION IN A CALL PROCESSING ENVIRONMENT,” which is incorporated herein fully by reference.
This invention generally relates to communications infrastructure and techniques, and particularly concerned with load estimation, load balancing and call admission control in call processing systems including plural call processing units.
In light of recent tightening of the credit markets and general drop-off in demand, telecommunications carriers are increasingly pressured to maximize return on their existing infrastructure and/or make wise choices when purchasing and deploying new telecommunications gear. Due in part to their cost and potential performance bottlenecks, especially when stretched beyond nominal loads, call processing systems within the carrier's network have drawn heightened scrutiny.
Traditional time-domain switched, voice-oriented communications typically included a single call processing unit tightly coupled to and servicing a given switch fabric or a dedicated portion thereof. Smaller, enterprise class telecom solutions such as a digital key system or private branch exchange included one call processing unit, whereas carrier grade central office solutions involved a dedicated call processing unit servicing a dedicated portion of the central office switching fabric. TDM switching techniques assured an actual or virtual connection be established and maintained for the duration of a call, at the expense of resource efficiency and dynamism.
With the advent of packet voice and softswitch solutions, the call processing system has been decoupled from the actual or virtual switching fabric, and a number of multi call processor designs have been developed, since each call processing unit is now capable of handling almost any call originating from or terminating to the larger system.
A representative multiple processor call processing system 2500 is shown in
A well-known goal that multiple processor call processing systems (such as the system 2500 shown in
To illustrate, refer to a simplified capacity diagram of a 6 PMCi call processing system 105 shown in
The risk presented in
In order to load balance a multiple processor call processing system, it is important to be able to estimate the resource utilization (in terms of e.g. bandwidth or processor loading) on each call processing unit at any given time. Once the per PMCi estimated loading is determined, one can prospectively load balance by admitting new calls based on which PMCi has free resources to handle the call. A simple brute force approach is to assume that each call is taking up its peak resource requirement, and that the estimated load is based on this peak resource requirement multiplied by the number of calls being handled. This obviously results in inefficient resource under-utilization, and cuts against some of the perceived variable bandwidth advantages afforded by packet voice transmission.
Another known technique for estimating resource utilization is based on a relationship between peak and average resource requirements for a given call type, e.g.:
Once the estimated resource utilitization for the different call types being or expected to be handled within the call processing system is known, each PMCi's loading can be estimated by determining how many of each type of calls are being serviced and multiplying each by this estimated resource utilization. Resources can be reserved within each of the PMCi consistent with the estimated resource utilization and additional capacity can be determined based on remaining unreserved resources.
average<<peakestimate=2×average (2)
average≅peakestimate=average=peak (3)
Thus, using this estimated resource utilization technique results in a overly-conservative loading estimation for the PMCis (i.e. more resources are estimated being used than is actually the case) and can potentially result in a false determination that a given PMCi is at nominal loading or overloaded when it still in fact has capacity. The call processing system can refuse to provide additional calls to the so-overloaded PMCi which still in fact has capacity, and worse, may prematurely refuse to admit further calls to the system (assuming the remaining PMCis are estimated at nominal or greater loading). On the other hand, it is unlikely that any one PMCi will be overbooked or oversubscribed, thus this technique is perceived at least being QoS friendly.
Further, this estimated resource utilization technique does not take into account the number of calls of a given call type being handled by a given call processing unit. It is well-known that the greater the number of calls of a given type are being serviced by a given PMCi, the less is the chance that these behave all the same way or utilize the same amount of resources. For example, it is highly improbable that, in the case of packet voice with silence suppression, that all handled calls will be in the more resource demanding active, vs. silent state. To account for this, it is generally known that a provisionable reservation coefficient may be used to augment the above to permit the PMCis and the call processing system generally to accept more calls than the above-described conservative estimation technique calls for, and in the typical and aggressive cases, more than the PMCis and the call processing system as a whole can actually handle. This overbooking is justified, especially as the number of calls increases and the probabilistic nature of the calls with respect to actual resource utilization (the probabilistic nature of calls, as used herein, means that the resource utilization for each call varies by time and may have any of a finite or infinite number of values within known limits). However, in known systems, the reservation coefficient, although provisionable, is constant within different hours of a day or days of a week, unless a system operator manually alters or updates it.
Therefore, it would be advantageous in a multiple processor call processing system if critical resource utilization could be better predicted, and consequently more accurate call admission and load balancing decisions could be made without detracting from overall system performance.
The present invention is directed in part to techniques for determining the eagerness of a call processing unit within a multiple processor call processing system to accept a new call or call upgrade. The invention is also directed to call admission control and load balancing through query of such eagerness. In particular, fuzzy logic is used to determine the eagerness.
Accordingly, consistent with one embodiment of the invention, in a call processing unit capable of supporting a plurality of call classes, method and apparatus are provided which includes attainment of first and second load parameters for the call processing unit, fuzzification of the first and second load parameters according to respective first and second fuzzification functions, comparison of the fuzzified first and second load parameters against a defined set of eagerness rules, defuzzification the result of the comparing, and generation of an eagerness to admit a call based on this defuzzification result. The first and second load parameters may include actual and estimated load parameters for the call processing unit. The estimated load may be approximated using a probabilistic distribution function. Homogeneous may also be consulted in determining this eagerness.
Consistent with another embodiment of the invention, in system comprising plural call processing units, a call admission apparatus and method are provided which includes monitoring a call admission eagerness for each of the call processing units, perception of a call admission request, selection of a target call processing unit having a relative maximum call admission eagerness, confirmation of the call admission eagerness by this target call processing unit with respect to the call admission request, and admission of the call if the target call processing unit eagerness is confirmed. Predetermined or call class malleable thresholding may be utilized to help determine if a target call processing unit is available. Also, another target may be selected if the eagerness cannot be confirmed by the initial target, and may be recursively performed until either no target call processing units are available, the admission request is withdrawn, or the call is successfully admitted.
Additional aspects and advantages of this invention will be apparent from the following detailed description of embodiments thereof, which proceeds with reference to the accompanying drawings.
Unless otherwise noted, the listed terms below, including abbreviations and symbols, will have the following meaning ascribed to them:
For simplification purposes only, and not meant to limit the teachings of the present invention in any fashion, the disclosed embodiments presumes a single master call processing unit (PMC-M) coordinating several individual call processing units or PMCis (e.g. on the order of 50-60). See, e.g.
In determining whether to admit a new call, one should see if the necessary resource such as processing load or bandwidth for the new call is available. If the resources are available, the new call can be admitted. An important action in packet switching systems with QoS requirement is resource reservation. It means that by admitting each new call, the call processing system or constituent call processing unit should restrain its eagerness to accept more new calls.
Load Estimation Theory
As previously discussed, if the reservation is made based on the maximum possible resource utilization or a relationship that disregards or oversimplifies the number of actual calls and their probabilistic nature, the efficiency of the call processing system will be less than optimal. Hence, consistent with one aspect of the present invention, the disclosed embodiments of the present invention utilize a probabilistic estimation of the load, based on the mean and variance of the resource utilization for a given call type and experienced call distribution.
In particular, the call processing system according to a specific embodiment generates a probability distribution function (pdf) of the total resource usage. Then based on this pdf, this call processing system calculates the probability of exceeding a nominal load value on a per call processing unit basis. This probability should be kept lower than a given threshold, by rejecting some calls if they are coming at the time of heavy load. So, in CAC and load balancing consistent with the present invention, this probability gives this call processing system a measure to accept or reject the new call or, if sufficient capacity exists at the system level, to determine which PMCi should handle the call.
To ease understanding, one or more of the disclosed embodiments selectively perform “static” load balancing of the call processing system based at least in part on the aforementioned estimated load results. Such load balancing seeks to make load balancing decisions (which call processing unit, if any?) with respect to a call only during admission of the call. However, the teachings of the present invention are not intended to be so limiting, and, as will be appreciated by those ordinarily skilled in the art, can be easily applied to dynamic load balancing of calls where, in addition to balancing at admission, calls can be transferred from one call processing unit to another on fly. See, e.g. Willebeek-LeMair et al., “Strategies for Dynamic Load Balancing on Highly Parallel Computers”, IEEE Transactions on Parallel and Distributed Systems, Vol. 4, No. 9, Sep. 1993 incorporated herein fully by reference.
In the disclosed embodiments, assume that an individual call processing unit or PMCi can handle a limited number of call types or classes of service: θ1 . . . θN. Each class has a different set of QoS requirements.
For each call type or class, there is basically a different probabilistic pattern. The probabilistic pattern identifies the probability (or percentage) of being in a set of discrete states or modes (active/non active or silence/speech, for example). Assuming there is usually 1 to 3 discrete states and that the resource usage in each state individually is known through empirical data, predictive analysis, or otherwise. For example, in packet voice conversation, there are two basic states: silence and speech. The probabilities of being in each one of these two states is p1 and p2, where p1+p2=1.The resource utilization for each state is m1 and m2, respectively. The goal is to estimate the load (resource utilization) based on the a priori knowledge about these classes and the number of existing calls in each type or class. The probabilistic behavior of the calls is usually reflected in the active/silence mode of voice or the burstiness (of data).
For discussion purposes only, assume the call types or classes to be conversation (mainly voice), streaming, interactive (web data), and background (email), as listed below. In other embodiments, other call types such as fax, telecommands, etc may be considered as will be appreciated by those ordinarily skilled in the art.
For illustration purposes, bandwidth is presented in the above chart as the required resource. However, as will be discussed in more detail below, the processing load or CPU consumption of a PMCi will be also be used, as it can be the more the scarce type of call processing resource, especially in larger call processing environments.
As an example,
In the following subsections, we first show how to obtain the pdf of a number of calls in each class and then we obtain the pdf of the total load within a PMC. The mean and variance are calculated as follows:
μ=p1·m1+p2·m2=8.1 kbps. (4)
And the variance is:
σ2=p1·(m1−μ)2+p2·(m2−μ)2=25.21. (5)
Which yields a standard deviation of σ=5.02.
The well-known central limit Theorem states that “by summing up a sufficient number of independent stochastic variables, we get a new variable, which has a Gaussian distribution”. This approach has been already used for connection admission for satellites as described in Yeong Min Jang's “Central limit approximation approach for connection admission control in broadband satellite systems”, IEE Electronics Letters Vol. 36, No. 3, 3rd Feb. 2000 incorporated herein fully by reference. The mean and variance of this Gaussian distribution are easily calculated as follows:
Where μi and σ2i are respectively the mean and variance of one call. As a result, if we keep the example of the previous subsection, by adding N calls, the mean and variance will be: μ=8.1* N Kbps and σ2=25.21* N. For instance, N=100 gives μ=8100 Kbps and σ2=2521 Kbps.
The mean value calculated here for the total distribution is simply the sum of all the average values. The variance is also the sum of the variances attributed to all of the calls. When, for example, 100 calls of one type together, the mean value gets 100 times bigger; so does the variance; however, the standard deviation, σ, gets only 10 times bigger. This means that the more calls are added up in a PMCi, the bigger is the mean and the standard deviation, but the smaller would be their ratio μ/σ2. A generalized plot of the probability distribution function in accordance with this algorithm is shown in
It should be noted that this algorithm is an approximation that becomes more accurate for larger values of N. However, this approximation is believed good enough in providing an estimated load commensurate with the goals of the invention. In fact, a well known method to construct a random variable with Gaussian distribution is to add N (usually 12) random variables with uniform distribution (such as using rand( ) in the “C” programming language).
Alternatively, the exact form of the distribution can be obtained by applying N times convolution of the original pdf with itself. The more accurate calculation is that for this case, the distribution of the sum is a series of impulses at i*m2+(N−i)m1, where 0<=i<=N. The probability at each point is CNi·p21p1N−1, as shown in
Though not implemented in the embodiments disclosed below, there is another point here which applies to the classification of the calls in different classes. Some calls, for some reasons may have different resource usage than others, although they may be in the same class. For instance, a voice call may have “A” times processing power requirement than others, because of the special conditioning or additional processing to be applied to the call, such as silence suppression or ciphering. Therefore, provision may be made to count such a call A times more than “an ordinary call”.
The next step is to add the variables obtained in each class, to obtain the pdf of the whole resource usage in all of the classes for a given PMCi. Again, the central limit Theorem implies that “the sum of any number of variables with Gaussian distribution, is a new variable with a Gaussian distribution.” The mean and variance of the new variable can be simply obtained by summing up the mean and variances of the elements.
As discussed above, the total pdf has a mean and a variance that can be obtained from simple arithmetic. The pair of values (mean, standard deviation) are the only parameters we need when using the Gaussian distribution's error function. In
For each PMCi, based on the current number of the admitted calls in each class, we can calculate the probability of having the total resource usage exceeding the maximum allowable value set for the resource (say for example, 2 Gbps for bit rate or 99% of CPU usage). In other words, we can determine the probability of having the total resource utilization for a PMCi exceeding the nominal load specified for that PMCi.
Alternatively, having a provisioned tolerable probability for exceeding the nominal value, we can determine for each PMCi, whether the value corresponding to this probability is smaller or greater than the maximum allowable resource utilization.
A load estimation algorithm according to an embodiment of the invention, based on the statistical analysis and Gaussian distribution discussed above will now be disclosed. Unlike the above, however, the scarce resource is now processing load (in the unit of instruction cycles/sec or any other measure of processor utilization within a call processing unit)
In each one of the N classes (here N=4 for voice conversation, streaming, web data interactive and streaming), assume that there are two modes: active and non-active. The probability of being in each state is also considered to be known (p1, p2 , respectively). The ratio p1/p2 is a main characteristic of each class. It should be understood that this is a simplifying assumption to have only two modes (active and non-active) and that in reality, more than two modes might be possible. However, this does not affect the disclosed algorithm as long as one can translate these numbers to form a Gaussian distribution with a known μ,σ2.
The first action is to measure the number of instruction cycles/sec (processing resource utilization) corresponding to each of the two modes: active and non-active for given call class or type. These two parameters are known as m1 and m2. Note here that there are however a number of other parameters that affect the number of instruction cycles being used to support the call mode. These parameters may include some or all of the following parameters in an e.g. UMTS call processing environment, including:
The term PS here refers to Packet Switching and CS refers to Circuit Switching. The Boolean PS/CS indicates whether a UMTS call is either packet or circuit standard respectively. The CRC Boolean indicates whether Cyclic Redundancy Coding is used with a given UMTS Call. RLC_mode refers to the UMTS radio link mode associated with a call (TM: transparent mode; AM: acknowledged mode; and UM: unacknowledged mode). TTI refers to the Transmission Time Interval. The No_of_TB refers to the number of traffic bearers. Finally No_of_RL refers to the number of UMTS radio links available for the UMTS call.
A fast look at these parameters may suggest that the actual number of classes is more than what was assumed above (here N=4). However, despite the fact that based on the actual values of these parameters some of the statistical characteristics of the call varies, some others remain intact. The ratio p1/p2, for instance does not change and, that in most cases, both m1, m2 are assumed to change proportionally. Once more, as will be appreciated by those ordinarily skilled in the art, this is a simplifying hypothesis which may inject some inaccuracy in the modeled probability distribution function. However, as will be discussed below, fuzzy logic may be conveniently implemented to interpret this statistical model such that simplification inaccuracies will not deter from arriving as a correct result.
First, for each class of call (say voice conversation for example) consider a set of given call parameters such as:
Then, based on these parameters, m1 is obtained for the active mode and m2for the non-active mode. Next, a different set of parameters is assumed, which results in a new (
As a result, in accordance with the present embodiment, one can characterize a class with 2 states or modes, each with associated probabilities (p1, p2) and corresponding resource requirements (m1, m2) which can be obtained directly through empirical measurements. Several combinations of the call parameters discussed above are considered and for each set the load is measured. Then an algorithm may be used to fit a function to those parameters. The derived mode probability and resource requirements in turn give the representative pair of μ, σ2 as described above.
Consider the following table showing a restrained number of the combinations of the call parameters (ciphering Y/N, CRC enabled Y/N) in an UMTS multiple processor call processing system:
Although not presented herein, more columns in this table should be provided which represent other parameters having some influence on the values of μ, σ2, such as the bit rate, or the number of radio links in a wireless system (e.g. 1-6 links in a UMTS system). Additionally, other real world factors may be considered and the resource requirement algorithm made more complex to accommodate such factors. For example, in a wireless call processing system implementation, the number of radio links which has also a probabilistic character may be investigated. In such a case, the variances obtained will be substantially higher for conversation calls, and not necessarily zero for streaming calls.
When more extensive parameter combinations are considered, a neural network be may employed to make this function fitting, when more combinations are considered. See e.g. Bernard Widrow et al., “30 Years of Adaptive Neural Networks: Perceptron, Madaline, and Backpropagation”, Proceedings of the IEEE Vol. 78, No. 9, September 1990 which is incorporated herein fully by reference. The well known error backpropagation algorithm can be used to train the neural network and the resulted neural network will be optimized to have the smallest error for the set of empirical measurements. The generalization characteristic of the neural network acts so that it will have good performance for the sets of parameters out of its training set, as well. In case that one uses a neural network with no hidden layer, this solution simplifies to a linear combination but by having at least one hidden layer and nonlinearity in it, very complex nonlinear functions can also be approximated. A table outlining load estimation based on capacity measurement & Gaussian distribution with ciphering:
Though not considered above, it should be noted that a class of service (“CoS”) dependent parameter β can be multiplied to mean and variance for each call, which will reflect the importance of each class, or alternatively, call allocation or retention priority as contemplated within a UMTS communications system. For example, in “gold”, “silver” and “bronze” classes of service, we can have β=1.4, 1.2, 1 respectively. This will mean that there will be higher estimated resource requirements and consequently more resource reservation performed for calls in higher classes compared to the calls in lower classes.
In this embodiment, it is envisioned that each PMCi manages a table of its admitted calls including call type or class, μ, σ2 either within the admitted call table or as part of a separate resource knowledge base. Consider the following admitted table with class mean and variance individually specified:
The call type is simply the indicator of one of the N classes. For each class we make a summation over the μ, σ2 values, namely μ(conversational), μ(streaming), μ(interactive), μ(background). For instance, μ(conversational)=sum of μ's for all conversational calls in this PMC. The variance σ2 of each class is obtained in the same way. Finally, total μt, σ2t for the PMC are obtained by summing the μ, σ2 for all the classes. The values of μt, σ2t can be updated once a new call is admitted or an existing call is terminated (or modified) by simply adding or subtracting the corresponding μc, σ2c.
When the call's parameters are changed, new mean and variance are calculated and put in the table but before that the old values are subtracted from the sums. There is no need to rebuild the μt, σ2t values from scratch each time, though such processing is contemplated below with reference to
In this stage, for each class, c, we have the corresponding μ(c), σ2(c). We add these values over all the classes to obtain one μt, σ2t pair representing the whole load on a PMC.
By calculating μt, σ2t, we know all that we need to know about the distribution. Usually we want to calculate the probability, ζ, of exceeding a nominal value of the resource usage, ⊖.
where erfc(·) is the complementary error function of a normal distribution (a built-in function call in “C” and also implementable as a look-up table).
#include “math·h”
double y=erfc((Theta−mean)/(sqrt(2)*stdev))/2;
Where Theta, mean, stdev respectively stand for ⊖, μ, σ. This function can be kept in a table, for simplicity. The following table lists the value of error probabilities ζ for the various (⊖−μ)/σ. For example, we see that for having a ζ=1%, ⊖ should be equal to μ+2.33*σ. At μ+5*σ, ζ is practically zero.
Either value can serve as a guideline to decide either to accept or to reject a new call. The use of this estimate, along with some other estimates is the subject of the next section where we explain a fuzzy logic controller for this effect and we show how to use this parameter along with a couple of other ones to determine the eagerness of each PMC to receive a new call. It is also noteworthy that since ζ is an input to a fuzzifier, we can simply directly feed (⊖−μ)/σ to the fuzzifier.
What's our a priori estimation of the total σt/μt? The intervening parameters are multiple: first the number of calls in each class and second the characteristic that we consider for each class. For instance the more calls of streaming type we have, the narrower is the Gaussian distribution. Below we examine a few examples.
In the following examples, we give some numerical values to the different classes of calls and at the end verify the aggregated traffic.
Let's assume that we have only 150 voice calls.
μ=p1·m1+p2·m2=2.496MIPS (9)
σ2=p1·(m1−μ)2+p2(m2μ)2=864.36M, so σ=20.4KIPS (10)
Then μt=374.4 MIPS and σ2t=1.29654*1011 and σt=360KIPS. In other terms, in this scenario, we have a narrow Gaussian distribution, in part because of the big number of voice calls that we consider.
For streaming, the situation is simpler, because basically we have p1=1 and p2=0. So σ2=0 and the problem is not probabilistic anymore. Considering 5 streaming calls with m1=4.11 MIPS, we have μt=20.55 MIPS and σt=0.
Data, however, has usually a more probabilistic manner, as we may experience bigger σ2 values for data. Here, we just create an example for data:
p1=0.1, p2=0.9 (11)
m1=4.11MIPS, m2=1.07MIPS (12)
μ=p1·m1+p2·m2=1.374MIPS (13)
σ2=p1·(m1−μ)2+p2·(m2−μ)2=831744MIPS, so σ=0.912MIPS (14)
If we consider 20 data calls, it comes to μt=27.48 MIPS and σ2t=16.6312. and σt=4.078 MIPS.
By adding all the voice, streaming and data calls in the three previous examples, we calculate μt, σt as in the following table. In the table, we give also the mean and standard deviation values for some other numbers of different types of calls.
Consider that the total permitted instruction cycles on the board is ⊖=450 MIPS. This means that the probability of exceeding Θ from the above-mentioned formula is practically zero ζ=0. In fact, ζ can be reasonably assumed to be zero for μt=5σt=442.9 MIPS.
Call Admission Control (“CAC”) and Load Balancing
In this section, CAC decision and the load balancing according to several distinct embodiments are explained. The CAC decision is made in two steps: the initial step where the PMC-M makes a guess on the best PMCi able to handle the call based on reported eagerness. An early CAC algorithm can be included here for assisting the managing call protection unit to make the decision of either to accept or to reject a call, if none of the PMCis are eager enough to accept the new call. In the second step, the chosen PMCi itself reviews if it really is in the state of accepting the call or not. Consistent with these embodiments, fuzzy logic is used in parts of both processing to arrive at CAC and load balancing decisions.
The disclosed embodiments all try to even the load on the individual PMCis to reduce risk of overloading and underloading PMCi capacity, as well as enhance efficient use of scarce and expensive processing resources. In addition, several of the disclosed embodiments attempt to homogenize the load among the PMCis. Homogenizing herein means that the ratio between the effect of different types and service classes be approximately the same in all PMCis. In other words, if half of the total load (in all PMCis) in the call processing system is voice, the same ratio is maintained in all PMCis. By doing so one equalizes the chances of exceeding the nominal load in all PMCis.
The following arguments explain why a homogeneous load is advantageous: (1) various classes have different types of QoS requirement. For instance some are more sensitive to delay and some are more sensitive to discard. By having a homogeneous load, that is assurance that those natural differences can be handled by the PMCis. In contrast to this, if all delay sensitive calls are in one PMCi, and all non delay sensitive calls in another PMC, there will be little, if any, flexibility for any special case handling technique to operate successfully - for instance, the PMCi having all delay sensitive calls can not handle the situation by delaying some of the calls.
The disclosed models supporting these embodiments are based on a partial knowledge of the system; modeling for some classes is better than for others. By having a homogenous load, one avoids that most of the inexactitude because of the inaccurate modeling fails to gather in a single PMCi and increase estimate inaccuracies disproportionately.
Finally, as different classes of calls have different variances for their pdfs, if one forces an evenly distributed load but not necessarily load homogeneity, a call processing system may end up in a situation where for some of the PMCis, the probability of exceeding the nominal value is small but for some others, it is not. This would be the case, for instance when most voice calls go to one PMCi; most data to one and most streaming and background each to another PMCi. As streaming calls have insignificant variance, they show a very narrow pdf, while interactive calls show very large variances.
Though not disclosed as part of the specific embodiments, other criteria may be also important and should be considered as will become apparent to those ordinarily skilled in the art. For instance, consider the ability to maintain the QoS of existing calls (delay, BER, dropping). This means that there would be a feedback from the overload module to the CAC (and load balancing) functions. If a given PMCi experiences packet discard, or excessive delay (for delay sensitive calls), the PMCi should be marked as to be less eager to accept new calls. This concept introduces some kind of adaptability to the system.
Moreover, consider time of the day/week in which the call is or intended to take place. Also, the time span of a call: a voice call has an average duration of about 90 seconds while some interactive and streaming calls may have much longer durations. This fact may also be considered as an input to the CAC and load balancing decisions.
Consistent with one or more embodiments of the invention and based on the following parameters that are available about each PMCi, an initial guess on CAC and the optimum PMCi is selected based on: 1) the ensemble of calls which yield the pdf (μ2, σ2t) in each PMC; 2) the periodically updated measurement of the PMC loads; and 3) the QoS type and CoS (requirements of the new call).
In the disclosed embodiments, a resource knowledge base (e.g. knowledge base 1310 in PMCi 1300 shown in
Referring to
Load estimation performed by either the interested individual PMCi call processing unit (see e.g. load estimator 1330 in PMCi 1300 of
Turning now to
If, however, in step 602, a determination is made that the detected call event does not specify a new call admission request, control instead passes to 604. In step 604, a determination is made whether the detected call event specifies an admitted call termination request. If so, control passes to step 606, in which the new mean and variance values for the estimated load are calculated by subtracting the class load mean and variance values associated with the terminated call, as contained in the corresponding resource knowledge base, from current estimated load mean and variance values. Thereafter, control passes to step 610, where again the estimated load measure is determined based on the new mean and variance values for the estimated load as calculated in step 606.
If, however, in step 604, a determination is made that the detected call event in step 604 does not specify an admitted call termination event, control instead passes to step 612. In step 612, a determination is made whether the detected call event specifies an admitted call class modification request. Call class modifications, such as in-process call upgrades or downgrades, can be specified for an admitted call. Examples include requesting a call type modification (such as from voice to data) for an existing call, a call class modification within a common type (such as from interactive data type call to a streaming data call or requesting a transition in class-specific call parameter (such as the toggling the presence or absence of ciphering in voice calls or changing the bit rate for data calls). If the detected event specifies a call class modification event , control passes to step 614, in which the new estimated load mean and variance values are calculated by first subtracting the existing call class load mean and load variance values as specified in the resource knowledge base for the call currently undergoing modification and subsequently adding the new class mean and load variance values in the resource knowledge base specified for the call class the call of interest is evolving into. Control thereafter passes to step 610 in which again the estimated load measure based on the new estimated load mean and load variance for the entire processing unit is determined.
It should be noted that the estimated load measure may comprise any number of values suitable to quantatively represent the estimated load, including the aforementioned probability of exceeding a nominal load—ζ(p)—or a ratio between the nominal load and the estimated load mean, equation x2(p) mentioned above. Alternatively, other expressions of the estimated load measure may be used as would be understood by those ordinarily skilled in the art.
Once the estimated load measure has been determined, control thereafter passes to step 620 in which an estimated load parameter corresponding to, or at least based on, the estimated load measure is issued by the load estimator of interest. The estimated load parameter is used by the PMCp and/or by the managing call processing unit PMC-M to help undertake eagerness determination and ultimately load balancing and call admission control according to the disclosed embodiments. Thereafter event driven load estimation updating terminates naturally.
Load estimation according to another embodiment of the invention will now be detailed with reference to the flowchart of
Eagerness determination processing according to an embodiment of the invention will now be detailed with reference to
Turning to
In particular, the first fuzzifier 1342 acts on the actual load parameter x1(p). For each PMCi(p), x1(p) is compared to ⊖(p) which is the nominal load for the PMCp in terms of its information processing resources or CPU MIPS. A value of 0 for x1 means absolutely no load; x1=⊖ means fully loaded. Referring to the membership response curve employed by the first fuzzifier 1342 shown in
To simplify fuzzifier design in this embodiment, first fuzzifier 1342, along with the second fuzzifier 1344 and the third fuzzifier 1448 (
Thus, referring to
As shown in
In another example, if ζ(p) is very small (approaching 0), f2(p) is “vl”. In yet another example, if x2(p)=4.5,ζ(p)=3.39767 * 10−6 and then f2(p) is both “lo” and “vl”with a membership function of 0.5.
Returning to
Still referring to the flowchart of
where bi is the center of the membership function recommended by the consequent of rule i; γ(i) is the certainty of rule i; R is number of rules.
where f1(j) is the membership (fuzzified value) of the input j to the condition of rule i and L is the number of conditions to each rule (the same as the number of inputs of the fuzzy logic; 2 in our case). Because of our assumption that the sum of memberships for any given input is equal to one, this formula simplifies as:
As a result, we can simply calculate the center of gravity of all the rules:
Where activation(i) denotes the product of the membership functions of the inputs of the rule i. For instance,
activation(0)=(f1=vl)*(f2=vl)
activation(R−1)=(f1=vh)*(f2 vh)
In either case, the final output is also a fuzzy variable, as a result, the eagerness has always a value between 0 and 1.
Once φ(p) is obtained, eagerness determination processing according to the embodiment of
To illustrate further, consider the following example:
PMCp, where Θ=450 MIPS, μt=434.85 MIPS, σt2=56.11 MIPS
measured PMCp CPU load at time t=x1(p)=270 MIPS
x2(p) at time t=(Θ-μt)/σt=2.02
referring to
referring to
applying rule combinations of
(i.e., nonzero result):
(f1=me)*(f2=me)=0.6*0.022=0.013
(f1=me)*(f2=hi)=0.6*0.978=0.587
(f1=hi)*(f2=me)=0.4*0.022=0.009
(f1=hi)*(f2=hi)=0.4*0.978=0.391
It should be noted that in the embodiment of
Eagerness determination processing according to an alternative embodiment of the invention will now be detailed with reference to
In comparing the embodiment shown in
The homogeneousness parameter, x3(p), is determined in accordance with the following equation: balance target for the new or upgraded call class minus the (new or upgraded call class mean/new estimated load mean for the PMCp), or ω(θx)−μ(θx)/μt. The balance target is the ratio of the number of calls in class θx to the total number of calls in the call processing system managed by the master call processing unit, such as PMC-M 1600 shown in
Ideally, x3(p) should approach 0, so that the ratio of class θx to the total number of calls being handled by the PMCp matches the overall ratios experienced by the entire call processing system, from which ω(θx) is derived. If x3(p) <0, this means that the PMCp has more than the average number of admitted calls of class θx , and admission of the new or upgraded call of class θx should be rejected or at least disadvantaged. Conversely, if x3(p)>0, this means that the PMCp has less than the average number of admitted calls of class θx, and the admission of the new or upgraded call of class θx, should be encouraged.
Determination of homogeneousness as specified in step 918 may be conveniently implemented by a homogeneousness realization unit adapted to calculate x3(p) as discussed above. This homogeneousness realization unit may be situated onboard the PMCp for which eagerness is being determined, as is best shown in
As for further differences with the embodiment of
φ(p)=A*
where A=positive constant between 0 and 1, e.g. A=0.9
Eagerness determination for an individual call processing unit according to yet a further alternative embodiment will now be detailed with reference to
Thereafter in step 1022 the rules result to fuzzify to directly obtain the new eagerness value φ (p) for the individual call processing unit (step 1022). Thereafter, eagerness determination processing according to the embodiment of
It should be noted that the individual call processing unit arrangement shown in
Call admission processing according to an embodiment of the invention will now be detailed with respect to the flowchart of
Once these eagerness values are obtained, control thereafter passes to step 1212, in which the maximum relative eagerness value is determined based on the all the eagerness values (a.k.a. eagerness vector Φ) obtained in step 1210. Thereafter in step 1214, a determination is made whether the maximum eagerness value exceeds a threshold. This threshold can be a uniform threshold for any call or can be based on the type of call, its associated cost of service such as bronze, silver or gold, and or based on other factors such as originator status, intended recipient status, etc. For example, consider the threshold malleability chart of
Likewise, a silver CoS call will not be admitted if the reported eagerness for any of the PMCis fails to exceed εS, so in situations 2236 and 2238 the silver class call is rejected, and in situations 2230 and 2232 it is accepted. And, a gold class call will only fail to be accepted where the reported eagerness for each of the PMCis fails to exceed the gold threshold εg, such as in situation 2248.
Turning back to
At step 1224, the corresponding individual call processing unit's reported eagerness is disadvantaged such as by scaling its corresponding φ by a factor of 0.8-0.9 for at least one iteration. Control thereafter ends. It should be noted that this processing will restart with the disadvantaged φ replacing the previous maximum φ. In such way, a high probability that another PMCi will be selected, and it's eagerness will be self-confirmed, assuming that it's reported eagerness continues to exceed the threshold as performed in step 1214. As one can see, this process continues iteratively until the first of: (1) the maximum queried eagerness value fails to exceed a specified threshold; (2) eagerness to accept the call cannot be confirmed by any PMCi; or the CA request is withdrawn.
Though not shown in
Call event processing according to an embodiment of the invention undertaken by a PMCi such as the PMCi 1300 shown in
If however, in step 1116, it is determined that the new eagerness does in fact exceed the threshold, control instead passes to step 1122. At step 1122, the PMCi admits the call. Control then passes to step 1124, in which a determination is made whether the PMC-M should be apprised of the newly calculated eagerness value. There is a design goal in the present embodiment to reduce extraneous traffic between the PMC-M and the PMCis it manages, and one way to help achieve this goal is to reduce notification of reported eagerness changes when such changes are relatively small, particularly where the overall system is relatively insensitive to slight alterations in PMCi eagerness. Thus, in this embodiment, a determination is made in step 1124 whether the new eagerness value constitutes a big change from the previous eagerness value reported to the PMC-M. If so, control passes to step 1126 and the PMCi reports the new eagerness to the PMC-M and call admission event processing ends. However, if in step 1124 it is determined that the new eagerness does not represent a significant change from the previously reported eagerness for the current PMCi, call event processing ends without further reporting.
In determining whether the new eagerness constitutes a big change, a content-based messaging conservation algorithm may be used as depicted in
Returning to
If, however, in step 1132, it is determined that the call modification request specifies a call downgrade, control instead passes to step 1134 in which the new estimated load is determined based on the downgrade. Then, in step 1136, the new intermediate or final (depending on PMCi resource utilization capabilities) eagerness is re-determined taking into account the new estimated load obtained in step 1134. Thereafter, processing continues with the conditional publication or reporting steps 1124 and 1126 detailed above.
If, in step 1130, a determination is made that the intercepted call event does not comprise either a call admission request or an admitted call modification request, control passes to step 1140. At step 1140, a determination is made whether the call event includes an admitted call termination event. If so, control passes to step 1134 through 1126 detailed above, with the exception that the estimated load is recalculated without consideration of the terminated call. If, however, in step 1140, it is determined that the call event is not one of a call admission request, a call modification request, or a call termination request, the call event falls through to conventional call management processing (not shown in the FIG.), or in the alternative, is not recognized or acted upon at all by the PMCi of interest.
Turning briefly to
It will be obvious to those having skill in the art that many changes may be made to the details of the above-described embodiments of this invention without departing from the underlying principles thereof. For example, the processing described above may be conveniently implemented by one or more general (e.g. a microprocessor or microcontroller) or specific purpose information processors (e.g. a network processor or DSP) programmed to undertake one or more of the involved processing steps. That is, the present invention can be embodied as a computer program product comprising computer readable program code causing an information processor with a call processing unit to to perform the previously described the method. In the alternative, or in combination such information processing resources, one or more steps of the above-described processing may be undertaken by a discrete logic and/or circuitry, including application specific integrated circuits and/or analogous devices. The scope of the present invention should, therefore, be determined only by the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5521971 | Key et al. | May 1996 | A |
5751691 | Soumiya et al. | May 1998 | A |
5787161 | Rayes et al. | Jul 1998 | A |
5812526 | Chang et al. | Sep 1998 | A |
6067287 | Chung-Ju et al. | May 2000 | A |
6084955 | Key et al. | Jul 2000 | A |
20030198203 | Antonio et al. | Oct 2003 | A1 |
20040042455 | Wallenius | Mar 2004 | A1 |
20040047289 | Azami et al. | Mar 2004 | A1 |
Number | Date | Country | |
---|---|---|---|
20040047289 A1 | Mar 2004 | US |