The present invention relates to internet telephony techniques, and more particular, to a method for determining voice quality in a voice call over a packet network and rerouting the voice call accordingly.
With the widespread of broadband Internet connections and the development of Internet telephony techniques, more and more calls are made over the Internet to take advantage of low prices. Though the users understand that they may have to sacrifice some voice quality, voice quality still needs to be kept at an acceptable level.
Currently, the objective methods for measuring voice quality of a voice call over a packet network such as the Internet using a protocol such as VOIP or SIP are mainly categorized into three types: 1) intrusive method: in this method, a reference signal is injected on one side of the network and collected on the other. An assessment of the quality of the network can be made by comparing any differences between the original and transmitted signals. This method gives a true end-to-end quality assessment, however, it is intrusive, requires a receiver to collect the transmitted signal, and does not account for network latency; 2) signal-based non-intrusive method: in this method, the voice quality is assessed by “listening” to ordinary phone calls and applying complex speech pattern recognition. This method is non-intrusive, and gives true end-to-end measurements. However, it does not account for network delay either. Moreover, it is impractical for a large-size fully-meshed network; and 3) parameter-based non-intrusive method: this method assesses voice quality by collecting impairment information from ordinary phone calls on the packet network. It uses the known E-model formula to derive the quality of a call. This method does not give true end-to-end results but only gives the voice quality of the packet network portion of the phone call.
The present invention is directed to the method of the third type as explained above, i.e., the parameter-based non-intrusive method.
It is an object of the present invention to provide a method for managing a voice call over a packet switched network based on voice quality of the call.
It is another object of the present invention to provide a convenient and effective method in determining voice quality in a voice call over a packet switched network, which is a parameter-based and non-intrusive method.
It is further object of the present invention to provide a method in monitoring the voice quality of a voice call over a packet switched network.
It is another object of the present invention to provide a method of rerouting the voice call when the voice quality is below a predetermined level.
According to the present invention, a method for managing a voice call over a packet switched network is provided, in which the voice call is rerouted when voice quality is below a predetermined level. In particular, the voice quality is determined by calculating a parameter representing the voice quality based on information regarding a codec, network delay and packet loss.
In a preferred embodiment, the information regarding codec, network delay and packet loss is obtained from one or more gateways. Preferably, the gateways comprise at least one Cisco gateway, and the information is obtained from Call Detail Records available in the Cisco gateway.
In a preferred embodiment, the parameter representing the voice quality comprises a Mean Opinion Score (MOS), which is calculated from an R-factor using Equation 1 as below:
MOS=1+0.035R+R(R−60)(100−R)7*10−6 (Equation 1)
In a preferred embodiment, the R-factor is determined based on the information regarding codec, network delay and packet loss from the following equations, wherein dcdr and the PL are the network delay and the packet loss provided by Cisco CDR, and:
for G.711
R=93.2−0.024d−40ln(1+10PL) if d=<177.3 (Equation 2a)
R=112.7−0.134d−40ln(1+10PL) if d>177.3 (Equation 2b)
and d=dcdr/2+94
for G.729
R=82.2−0.024d−44ln(1+9PL) if d=<177.3 (Equation 3a)
R=101.7−0.134d−44ln(1+9PL) if d>177.3 (Equation 3b)
and d=dcdr/2+114
for G.723
R=97.7−0.134d−50ln(1+8PL) (Equation 4)
and d=dcdr/2+186
In another preferred embodiment, the R-factor is determined from the following equations:
for G.711
R=100−25{(1+X6)1/6−3(1+[X/3]6)1/6+2}−[0+40ln(1+10PL)] (Equation 5)
where X=log(d/100)/log2 and d=dcdr/2+94
for G.729
R=100−25{(1+X6)1/6−3(1+[X/3]6)1/6+2}−[11+44ln(1+9PL)] (Equation 6)
where X=log(d/100)/log2 and d=dcdr/2+114
for G.723
R=100−25{(1+X6)1/6−3(1+[X/3]6)1/6+2}−[15+50ln(1+8PL)] (Equation 7)
where X=log(d/100)/log2 and d=dcdr/2+186
The above and other features and advantages will be clearer after reading the detailed description of the preferred embodiments of the present invention with reference to the accompanying drawings, in which:
Mean Optical Score (MOS) is a standard published by the ITU to evaluate a voice call. In addition, the ITU has published other standards to objectively measure call quality, including a non-intrusive, parameter-based objective method called “E-model”. The preferred embodiments of the present invention are described with E-model applied to calculate the MOS score to measure the quality for a call through a VOIP network.
As known in the art, MOS can be calculated as a function of the R-factor as follows:
MOS=1+0.035R+R(R−60)(100−R)7*10−6 (Equation 1)
Alternatively, the MOS can be obtained from R-factor according to Table 1:
Mathematically, the E-model is defined as:
R=Ro−Is−Id−Ie+A (Equation 8)
According to the teaching of the present invention, the R-factor is preferably calculated based on information regarding the codec, network delay and packet loss obtained from the network, preferably from one or more gateways in the network.
In a preferred embodiment, the codec, network and packet loss information is obtained from Call Detail Records (CDRs) available in one or more Cisco gateways in the network.
Preferably, the information is obtained during the call session. The R-factor and the MOS score are calculated immediately with the obtained information so as to dynamically monitor the call quality during the call. The calculation results are fed back to a management unit for back-end processing, and are used to update routing tables.
Preferably, as soon as the R-factor or MOS score is below a predetermined threshold, a routing engine immediately reroutes the call according to the updated routing tables. Thus, the call can be rerouted in real time during the call session.
The call starts at block 100. After the call is established, information regarding the codec, network delay and packet loss is obtained from the network during the call, at block 101. In a preferred embodiment, such information is obtained from Call Detail Records (CDRs) available in one or more Cisco gateways. A Cisco gateway can either be an originating gateway or a terminating gateway, or both.
R-factor is then calculated based on the obtained information regarding the codec, network delay and packet loss according to a proper formula (examples given in detail below), at block 102. Preferably, MOS is calculated from R-factor according the Equation 1 or Table 1, as explained above.
The calculation results are compared with a predetermined reference value which represents an acceptable voice quality threshold level, at block 103. If R or the MOS is above the threshold, the call is kept in the path without being rerouted, and periodically the steps 101-103 are repeated so as to monitor the call quality. If R or the MOS falls below the threshold, as decided in block 103, the routing table is updated and the call is rerouted, at block 105.
After the call is rerouted, steps 101-104 are repeated to keep monitoring the call, until the call ends at block 105.
A first exemplary embodiment of the method according to the present invention for calculating the R-factor in Equation 8 is now described in detail below. In this embodiment, the information regarding codec, network delay and packet loss is obtained from Cisco CDRs.
Determining A:
The Expectancy Factor A is used to increase the MOS score for destinations with inherent poor quality such as cell phones, hard to reach areas and developing countries. Since customers have come to expect lower quality to these destinations, what might otherwise sound poorly to a “normal” destination is acceptable in these cases. Therefore, in this embodiment according to the present invention, is assumed to be zero “0”.
Determining Ro−Is:
Ro−Is are constants throughout the conversation in the call session, regardless of the transmission medium. In this embodiment, the Ro−Is is set as follows:
Ro−Is=93.2 (Constant 1)
Calculating Id:
The impairment factor Id, is a function of the mouth to ear one-way delay d. Id is calculated from the following equations:
Id=0.024d if d=<177.3 (Equation 9)
Id=0.024+0.11(d−177.3) if d>177.3 (Equation 10)
In this embodiment, the one-way delay d will be an additive delay that includes the codec delay (dc) the network delay (dn) and the jitter buffer delay (dj):
d=dc+dn+dj (Equation 11)
In this embodiment, since dn can be obtained from Cisco CDRs, the challenge becomes to derive default values for dc & dj that are gateway specfic. In the lab we set dn to 0 and assumed dc and dj to be a combined constant that does not depend on network conditions.
In a preferred embodiment, we assume the following constants for a network where Cisco gateways are adopted. Although we must make this assumption for simplicity, we need to acknowledge that: 1) dj varies with network conditions. Models that account for jitter and bursty packet loss are still being researched by the academic community—a few that have been proposed are very complex, given their use of statistical theory; 2)These constants may not be accurate when a non-Cisco device is present in the call flow.
dc+dj=94 ms, for G.711 (Constant 2)
dc+dj=114 ms, for G.729 (Constant 3)
dc+dj=186 ms, , for G.723 (Constant 4)
Since dn is the network delay as provided by Cisco CDRs, let us rename it as dcdr and Id now becomes a function of the codec, and network delay. In this embodiment, since the CDR delay is round-trip, it must be halved. Id can then be shown to be:
where: d=dcdr/2+94 for G.711 codec (Equation 12)
d=dcdr/2+114 for G.729 codec (Equation 13)
d=dcdr/2+186 for G.723 codec (Equation 14)
It is worth noting two points: 1) The delay introduced by Cisco seems to be excessive but we did verify that the results obtained by Radcom are accurate. This Cisco issue had already been identified in earlier works and has been verified again; 2) The measurements indicate that the delay increases as a function of packet loss as depicted below. This may be a result of varying jitter buffers or other Cisco-specific algorithms.
The impact on delay can be approximated as functions of packet loss (PL), and codec as follows:
dc+dj=15pl+94 for G.711 and PL<2% (Equation 15)
dc+dj=2pl+125 for G.711 and PL>=2% (Equation 16)
dc+dj=10pl+114 for G.729 and PL<2% (Equation 17)
dc+dj=1.25pl+132.5 for G.729 and PL>=2% (Equation 18)
dc+dj=40pl+186 for G.723 (Equation 19)
For simplicity, we have assumed the delay introduced by Cisco to be constant (constant 2, 3 and 4) but this can be modified later if needed.
Calculating Ie:
Ie is calculated from the following equations:
Ie=40ln(1+10PL) for G.711 (Equation 20)
Ie=11+44ln(1+9PL) for G.729 (Equation 21)
Ie=15+50ln(1+8PL) for G.723 (Equation 22)
Equations 20, 21 and 22 are derived from curves generated from the G.113 Ie data as listed in Table 2:
Calculating R:
From the above derivations, following equations can be concluded from Equation 8 for calculating R:
for G.711
R=93.2−0.024d−40ln(1+10PL) if d=<177.3 (Equation 2a)
R=112.7−0.134d−40ln(1+10PL) if d>177.3 (Equation 2b)
and d=dcdr/2+94
for G.729
R=82.2−0.024d−44ln(1+9PL) if d=<177.3 (Equation 3a)
R=101.7−0.134d−44ln(1+9PL) if d>177.3 (Equation 3b)
and d=dcdr/2+114
for G.723
R=97.7−0.134d−50ln(1+8PL) (Equation 4)
and d=dcdr/2+186
Following is a second exemplary embodiment of the method according to the present invention for calculating the R-factor in Equation 8 is now described in detail below. In this embodiment, again the information regarding codec, network delay and packet loss is obtained from Cisco CDRs.
Determining Expectancy Factor A:
Expectancy Factor A is still assumed as “0” in this second embodiment.
Determing Ro−Is:
In this embodiment, Ro−Is is revised as follows:
Ro−Is=100 (Constant 1—revised)
This is because we realize that is more realistic and practical to assume that under perfect network conditions, where packet loss and delay are non-factors, a “perfect” MOS score of 4.5 will be obtained. If we set MOS equal to 4.5 in Equation 1, then:
4.5=1+0.035R+R(R−60)(100−R)7×10−6 (Equation 23)
In order to satisfy equation 23, the R factor must equal 100. Therefore, by setting Id and Ie equal to 0 (perfect network conditions where the delay impairment and the codec/packet loss impairments are non-existent) and by setting R to 100 in equation 1, we come up with the revised Constant 1 as above: Ro−Is=100.
Calculating Id:
In the art, the G.107 recommendations define Id as the delay impairment factor that is in turn subdivided into three factors:
Id=Idte+Idle+Idd (Equation 24)
We must assume that echo chancellors are present in the voice path and that their affects on delay are negligible. Therefore, let us assume Idte and Idle to be 0 and Id becomes a function of Idd only, which is in turn a function of one-way delay:
Id=0 for d<100 ms
Id=25{(1+X6)1/6−3(1+[X/3]6)1/6+2} for d>100 ms (Equation 25)
where X=log(d/100)/log2
Because dc+dj is equal to 94 ms (for G.711) or 114 ms (for G.729) or 186 ms (for G.723) (see Constants 2, 3 and 4), we can therefore assume d to always be greater than 100 ms (even for G.711 codec, where the native codec delay is 94 ms, we can safely assume that network delay dcdr will be greater than 12 ms) and Equation 25 applies for all codecs and network conditions.
Calculating Ie:
Same as in the first exemplary embodiment, Ie is calculated from the following equations:
Ie=40ln(1+10PL) for G.711 (Equation 20)
Ie=11+44ln(1+9PL) for G.729 (Equation 21)
Ie=15+50ln(1+8PL) for G.723 (Equation 22)
Calculating R:
From the above derivations, following equations can be concluded from Equation 8 for calculating R:
for G.711
R=100−25{(1+X6)1/6−3(1+[X/3]6)1/6+2}[0−40ln(1+10PL)] (Equation 5)
where X=log(d/100)/log2 and d=dcdr/2+94
for G.729
R=100−25{(1+X6)1/6−3(1+[X/3]6)1/6+2}−[11+44ln(1+9PL)] (Equation 6)
where X=log(d/100)/log2 and d=dcdr/2+114
for G.723
R=100−25{(1+X6)1/6−3(1+[X/3]6)1/6+2}−[15+50ln(1+8PL)] (Equation 7)
where X=log(d/100)/log2 and d=dcdr/2+186
Though the above has described the preferred embodiment of the present invention, it shall be understood that numerous adaptations, modifications and variations are possible to those skilled in the art without departing the gist of the present invention. For example, the information regarding the codec, network delay and packet loss can be periodically and/or dynamically obtained from the network. In stead from a Cisco CDRs, the information may be obtained from other types of gateways or devices in the network. Moreover, the present invention may be applied to voice calls over packet network using other protocols as well, such as SIP protocol. Therefore, the scope of the present invention is solely intended to be defined by the accompanying claims.