1. Field of the Invention
The present invention relates to a routing method for determining a destination in a computer network having multiple interconnected nodes, and more particularly, to a method for measuring packet delays among remotely located gateways and processing routing in application layers of the gateways using the packet delays.
2. Description of the Related Art
In general, factors affecting the quality of service (QoS) of the Internet are packet delay, packet loss, jitter and the like. In a phone-to-phone Internet telephony system, a gateway of a calling party transfers a voice call to a gateway of a called party. In transferring the voice call, the best way for ensuring the generally accepted quality is to utilize packet traffic flow control among routers. However, in consideration of characteristics of the Internet, guaranteed QoS cannot be offered by the Internet Protocol (IP) service.
As is known well, a computer network includes connection of various nodes, each having a layered protocol structure, for example, a model known as the Open Systems Internconnect (OSI) Seven-layer model. The Internet, which is the most widely being used as the computer network, includes a plurality of routers.
These routers perform routing functions according to various algorithms such as a Shortest Path First (SPF) algorithm, a Shortest Available Path First (SAPF) algorithm, a Widest Available Path First (WAPF) algorithm, a Dynamic Random Routing (DRR) algorithm and so on.
Here, the SPF algorithm is used to transfer a voice call between IP end terminals along the shortest path. However, a problem with the SPF algorithm is that a call may be blocked when the capability of the shortest path is insufficient. To overcome this problem, the SAPF or WAPF algorithm employs alternative paths in the case where the shortest path is blocked. The DRR algorithm employs both a direct path and an alternative path. That is to say, if there is a new incoming voice call, a direct path is tried first and then an alternative path is used when the direct path is not available.
However, these known routing algorithms are simply based on the number of hops or possible bands, leaving characteristics of packets for real-time traffic in an IP network out of consideration. Thus, in such Internet telephony systems requiring real-time services, QoS guarantees cannot be rendered. Also, remotely located routers constituting the Internet are owned and managed by different operators. Thus, even if an improved algorithm for real-time traffic is developed, it cannot be suited to all routers from the viewpoints of specific interest parties, for example, Internet phone service providers.
To solve the above-described problems, it is an object of the present invention to provide a packet delay based routing method in a gateway, which can improve quality of service by performing routing based on a packet delay in application layers of a gateway for specific services.
To solve the above object of the present invention, there is provided a routing method based on packet delay including the steps of setting a re-routing interval and measuring one-way delays among gateways, exchanging the measured delays among the respective gateways and forming delay time tables, calculating an average one-way delay during the re-routing interval, and if a packet is received, applying the calculated average one-way delay to a predetermined algorithm and determining a path from a source gateway to a destination gateway, the path having the minimum delay.
The above objects and advantages of the present invention will become more apparent by describing in detail preferred embodiments thereof with reference to the attached drawings in which:
The present invention will now be described more fully hereinafter with reference to the accompanying drawings, in which a preferred embodiment of the invention is shown.
First, various nodes that can perform a routing function in application layers according to the present invention are referred to as gateways, and the gateways are remotely located, as shown in
Referring to
As shown in
Referring to
Here, a voice call packet transmitted from a gateway to a PSTN is called a direct packet, and a packet transmitted to another gateway is called a re-routed packet, which is then re-routed in the RTP layer via the physical layer, MAC/ARP layers, IPv4 and UDP layers and is then transmitted to another gateway via the UDP, IPv4, MAC/ARP and physical layers.
The direct packet is converted into a voice signal in a gateway conversion/translating module, while the re-routed packet is straight transmitted without passing through the conversion/translating module.
In other words, in a VoIP model for phone-to-phone service, a voice signal transmitted from a PSTN to a VoIP gateway is a G.711 Pulse Code Modulation (PCM) signal. For transmission of a voice signal over the Internet, a source VoIP gateway converts a PCM signal into a G.723.1, G.729A or low-bit scream to make packets and then transmits the packets to a destination gateway near from a receiver. Then, the destination gateway disintegrates or reassembles the packets converted into G.723.1, G729A or low-bit scream to be converted into the PCM signal for transmission to the PSTN.
In an IP network, a packet is generally directly routed to a gateway of a destination IP address of the packet by a router. However, it is known that the use of an optimum alternative path can improve QoS rather than the use of a direct path.
For example, when a voice signal is transmitted from the 0th gateway 102 to the 3rd gateway 108, as shown in
According to the present invention, a delay time for transmission through the direct path is compared with a delay time for transmission through the alternative path, based on the information on measured packet delay, and a better path is determined. In particular, the feature of the present invention is that routing is performed on gateways level, that is, application layers, unlike in the prior art in which routing is performed on the network level.
First, concepts of important terms used in the present invention will now be defined. In the present invention, each gateway utilizes a real time protocol (RTP) widely used for packet transmission in real-time media. In a H.323 gateway, since a call signaling packet is not greatly affected by a packet loss or delay, a Transmission Control Protocol (TCP) is used in the call signaling packet. However, according to the present invention, since the target packet for gateway level routing is a media packet, rather than a call signaling packet, an RTP protocol is used.
In each gateway, re-routing is performed with a constant time interval, called a re-routing interval (τ). A packet delay used to determine a path in a next re-routing time is obtained from a packet delay time (DT) in the current re-routing time.
The thus-obtained packet delay data is exchanged among all gateways in a real-time basis to be used for selecting a shortest path by a Dijkstra algorithm.
In other words, each gateway includes a DT information table, as shown in
Referring to
Now, a routing method according to the present invention will be described on the basis of the above definitions. Referring to
In step S1, a re-routing interval for determining a new routing path is set and information for all gateways is prepared. In other words, in step S1, the re-routing interval (τ) may be set to 1, 5, 10, 20, 30 or 60 seconds. For example, if τ=5, re-routing is performed every 5 seconds.
In step S2, one-way DT between one gateway and each of the other gateways is measured. If the DT is measured every second, RTP ping packets are transmitted to each gateway at a time interval of one second to measure the DT.
In step S3, the DTs obtained in step S2 are exchanged among the respective gateways and the DT information is tabulated by gateway.
In step S4, an average one-way DT during a set re-routing interval is calculated by the following formula 1:
where l represents a re-routing sequence. In formula 1, if l=1, the pertinent routing is the first routing, which means that there is no previous delay data. Thus, the average round-trip delay is zero. If l=2 and the re-routing interval (τ) is set to 30 seconds, k=(l−1)τ+1=(2−1)30+1 and lτ=30×2=60. Thus, when l=2, the average routing delay is obtained by the following formula 2:
The obtained average one-way delay is used to determine a routing path by the Dijkstra algorithm.
Then, if a voice packet with an actual payload is received, a next gateway to which the voice packet is to be transmitted is determined by the information contained in the header of the packet and the calculated average one-way delay. Here, as the algorithm for determining the next gateway, various algorithms are employed, including 1) a Dijkstra minimum delay algorithm for average one-way delay without estimation, 2) a minimum delay algorithm for average one-way delay with estimation, 3) an improved corrected trend direction (CTD) algorithm for error correction with estimation, and the like. This will now be described in more detail.
1) In the case of using only the average one-way delay without estimation, the average one-way delay for the next gateway, that is, davgl+1(i,j), is not previously estimated and the next gateway is determined using only the current average one-way delay, that is, davgl(i,j).
It is assumed that reference symbol s denotes a source gateway for generating a voice packet, and reference symbol d denotes a destination gateway near from a receiver. These pieces of information are contained in the header of the packet.
The source gateway s determines whether the voice packet is to be transmitted through a direct path or an alternative path. The determination is made by the Dijkstra minimum delay algorithm. The gateway s determines the next gateway Ψl+1(s,d) by the following formula 3:
Ψl+1(s,d)=D(αl[i][j],βl[i][j],s,d)
where i and j are integers from 0 to N representing the number of total gateways.
The Dijkstra function D outputs the minimum average one-way delay αl[i][j] and the next gateway number. βl[i][j] is an average one-way delay input to the Dijkstra function D and is represented by the following formula 4:
βl[i][j]=davgl(i,j)
where i and j are integers from 0 to N representing the number of total gateways.
2) In the case of using the minimum delay algorithm as the average one-way delay with estimation, a next path is determined with estimation using an exponential smoothing average (EXMA) as follows. The EXMA a can be arbitrarily selected. In this embodiment, α is set to 0.99802, for example. Even if the EXMA α is set to different values, e.g., 0.8 or 0.95, determination of the next path is made in a similar manner.
In this case, the current average one-way delay is not straight used in determining the next gateway, but an average one-way delay estimated during the next re-routing interval by the following formula 5 is used.
{circumflex over (d)}avgl+1(i,j)={circumflex over (d)}lτ(i,j) where {circumflex over (d)}lτ(i,j)=(1−α)dlτ(i,j)α{circumflex over (d)}lτ−1(i,j)
For example, if l=2 and the re-routing interval (τ) is set to 30 seconds, lτ=2×30=60 and lτ−1=2×(30−1)=59. Here, the estimated average one-way delay for the next third re-routing, i.e., l=3, is expressed by the following formula 6:
{circumflex over (d)}avg3(i,j)={circumflex over (d)}60(i,j) where {circumflex over (d)}60(i,j) =(0.00198)d60(i,j)=(0.99802){circumflex over (d)}59(i,j)
The relationship between the number of re-routing interval and the average one-way delay obtained using the above-described EXMA estimation, is shown in
3) An improved corrected trend direction (CTD) algorithm for error correction with estimation can be used.
A CTD algorithm is proposed for making up for the EXMA estimation, that is, for reducing the estimation errors due to wrong EXMA estimation of an average one-way delay for a next re-routing interval.
According to mathematical experimentation, the EXMA estimation has a shortcoming that in the case where the one-way delay of a direct path is shorter than that of an alternative path or a difference in the slope between two cases is small, too slow a response is resulted.
Here, the case of occurrence of wrong re-routing, that is, Γl(s,d), is obtained by the following formula 7:
where if Γl(s,d) is 1, meaning that wrong path determination is made, the one-way delay of a direct path is shorter than that of an alternative path. If Γl(s,d) is 0, correct path determination is made.
Thus, assuming that the number of accumulated wrong path determinations is denoted by f, the path for a next gateway is corrected using the CTD algorithm in the following manner as shown in
Referring to
In the case of performing routing using the above-described CTD algorithm, the relationship between the number of re-routing interval and the average one-way delay is shown in
As described above, according to the present invention, an improved routing performance can be achieved in real time transmitting a packet by determining the minimum delay path to a destination by measuring packet delays among remotely located nodes in application layers thereof.
The present invention can be effectively applied to the public Internet network system in which there is a great difference in network traffic by time.
In particular, the routing method according to the present invention can provide improved QoS of the Internet phone service when applied to VoIP gateways. In fact, users of the conventional Internet phone system have been dissatisfied with the poor quality of service even with its cost efficiency. However, the routing method according to the present invention can improve the quality of the Internet phone service when applied to remotely located gateways.
Number | Date | Country | Kind |
---|---|---|---|
2001-70343 | Nov 2001 | KR | national |
Number | Name | Date | Kind |
---|---|---|---|
6260072 | Rodriguez-Moral | Jul 2001 | B1 |
6426955 | Gossett Dalton et al. | Jul 2002 | B1 |
6584110 | Mizuta et al. | Jun 2003 | B1 |
6671261 | Cheung | Dec 2003 | B1 |
Number | Date | Country | |
---|---|---|---|
20030091029 A1 | May 2003 | US |