The present embodiments generally relate to congestion control, and in particular to such congestion control for multimedia sessions.
A real-time communication session can consist of one or several independent or related media streams. It can be a point-to-point session where end-points are directly connected to each other with a transport network providing the connectivity or a point-to-multipoint session where two or more participants actively join a session. Real-time media applications, especially video applications, require high bit rate streams and low latency to provide acceptable user experience. This possesses great demands on the transport network.
Congestion is a state of the sustained network overload when the demand for the network resources exceeds current capacity of the link between any two network nodes. From media application point of view, congestion control is a mechanism that enables overcoming the congestion in the network by adapting media rate, such as bit rate, frame rate, resolution or any combination of them, transmitted into the network.
In a point-to-point session the media adaptation is usually done at the end-points. The procedure of detecting congestion and taking adaptation decision could be implemented in the sender of the media or the receiver of the media or the responsibly can be distributed over both the end-points. Irrespective of the implementation, the end-points usually look at different Quality of Service (QoS) parameters like packet loss information, delay in the media delivery and explicit congestion notifications from the network, for example, Explicit Congestion Notification (ECN), to detect the congestion.
The commonly used protocol to establish point-to-point session is Real-time Transport Protocol (RTP). For a RTP session, Real-time Transport Control Protocol (RTCP) reports and some extensions of RTCP feedback messages, such as Temporary Maximum Media Stream Bit Rate Request (TMMBR), is used by the adaptation algorithms as adaptation signaling between end-points. When the sender sends more than one stream to the receiver then the receiver will have to report impairment metrics on each flow individually or send rate requests for each flow. It is possible that the sender can aggregate different estimations reported for different flows and generate a total view of the available session bandwidth for all of the current media flows. This will help the sender to efficiently distribute the current available bandwidth among all the flows based on some criteria, for example media priority. This will allow the sender to maximize the user experience by providing more important information with high quality.
Now-a-days, adapting media streams to address congestion in the transport link between network nodes is becoming a common feature in the communication suits. This has become important since it allows continuation of the communication session in a congested network situation; otherwise the communication would have been dropped. However, in a multimedia communication session it is still difficult to detect a common congested bottleneck and adapt the affected streams in an efficient way. Thus, a main problem with current solutions is that they have no indication where the bottleneck resides and how many of flows an ongoing communication are sharing the same bottleneck.
Jesup and Mozilla, Congestion control requirements for real time media, Network Working Group, Internet-Draft, Mar. 4, 2012, discusses the unique requirements with regard to congestion control for interactive, point-to-point real time multimedia. The congestion control requirements for multimedia are different from the requirements for bulk transfer like File Transfer Protocol (FTP) and bursty transfers like Web pages. The document concludes that Transmission Control Protocol (TCP) congestion algorithms are not suitable for such multimedia traffic.
It is a general objective to provide an efficient congestion control for a multimedia session.
It is a particular objective to enable selection of a suitable media flow to adapt to combat a congestion state.
These and other objectives are met by embodiments disclosed herein.
An aspect of the embodiments relates to a method of congestion control for a multimedia session. The method comprises assigning a respective flow identifier to each media flow of multiple media flows having a same source address and a same destination address. The method also comprises performing two-way network performance measurements between a sender of the multiple media flows and at least one of a receiver of the multiple media flows and routers present in a transport network and configured to route the multiple media flows from the sender through the transport network to the receiver. The method further comprises detecting, based on at least a portion of the two-way network performance measurements, a congestion state for a flow route in the transport network affecting at least one media flow of the multiple media flows. The method additionally comprises identifying a media flow of the multiple media flows, a media rate of which is to be adapted to combat the congestion state for the flow route based on at least a portion of the flow identifiers and mapping information defining a mapping between flow routes through the transport network and flow identifiers for the multiple media flows.
Another aspect of the embodiments relates to a device for congestion control of a multimedia session. The device is operable to assign a respective flow identifier to each media flow of multiple media flows having a same source address and a same destination address. The device is also operable to perform two-way network performance measurements between a sender of the multiple media flows and at least one of a receiver of the multiple media flows and routers present in a transport network and configured to route the multiple media flows from the sender through the transport network to the receiver. The device is further operable to detect a congestion state in the transport network affecting at least one media flow of the multiple media flows in the transport network based on at least a portion of the two-way network performance measurements. The device is additionally operable to identify a media flow of the multiple media flows, a media rate of which is to be adapted to combat the congestion state, based on at least a portion of the flow identifiers and mapping information defining a mapping between flow routes through the transport network and flow identifiers for the multiple media flows.
A further aspect of the embodiment relates to a device for congestion control of a multimedia session. The device comprises an identifier assigning module for assigning a respective flow identifier to each media flow of multiple media flows having a same source address and a same destination address. The device also comprises a measuring module for performing two-way network performance measurements between a sender of the multiple media flows and at least one of a receiver of the multiple media flows and routers present in a transport network and configured to route the multiple media flows from the sender through the transport network to the receiver. The device further comprises a detecting module for detecting a congestion state in the transport network affecting at least one media flow of the multiple media flows in the transport network based on at least a portion of the two-way network performance measurements. The device additionally comprises an identifying module for identifying a media flow of the multiple media flows, a media rate of which is to be adapted to combat the congestion state, based on at least a portion of the flow identifiers and mapping information defining a mapping between flow routes through the transport networks and flow identifiers for the multiple media flows.
Yet another aspect of the embodiments relates to a user terminal comprising a device for congestion control according to above.
A further aspect of the embodiments, relates to a computer program comprising program code which when executed by a processor causes the processor to assign a respective flow identifier to each media flow of multiple media flows having a same source address and a same destination address. The program code also causes the processor to perform two-way network performance measurements between a sender of the multiple media flows and at least one of a receiver of the multiple media flows and routers present in a transport network and configured to route the multiple media flows from the sender through the transport network to the receiver. The program code further causes the processor to detect a congestion state in the transport network affecting at least one media flow of the multiple media flows in the transport network based on at least a portion of the two-way network performance measurements. The program code additionally causes the processor to identify a media flow of the multiple media flows, a media rate of which is to be adapted to combat the congestion state, based on at least a portion of the flow identifiers and mapping information defining a mapping between flow routes through the transport networks and flow identifiers for the multiple media flows.
A related aspect of the embodiments defines a computer program product comprising computer readable code mans and a computer program as defined above stored on the computer readable code means.
The present embodiments provide an efficient congestion control for multimedia sessions by not blindly adapting all media flows but rather make a deliberate decision on which media flow to adapt to combat a congestion state.
The embodiments, together with further objects and advantages thereof, may best be understood by making reference to the following description taken together with the accompanying drawings, in which:
Throughout the drawings, the same reference numbers are used for similar or corresponding elements.
The present embodiments generally relate to congestion control, and in particular such congestion control for multimedia sessions. Multimedia sessions, and in particular real-time multimedia sessions, have requirements that differentiate from other types of communication sessions, such as bulk transfer, e.g. FTP-based sessions, and bursty transfer, e.g. Web pages. The multimedia sessions are often characterized by requirements for low latency and delay, high bitrate and semi-reliable data delivery in order to achieve acceptable user experience. This further implies that prior art congestion control solutions adapted to other types of communication sessions, such as TCP-based congestion control algorithms, are generally not available or suitable for multimedia sessions, and in particular real-time multimedia sessions. In clear contrast, the TCP congestion control algorithms were developed for reliable bulk transfer of non-time-critical data.
A main problem with current prior art solutions is that they have no indication where the bottleneck residues and how many flows of an ongoing communication are sharing the same bottleneck.
In another example, as shown in
At least some of the disadvantages mentioned above is solved by the provided embodiments. The embodiments provide a way to discover shared bottleneck in the transport network to help adaptation algorithms to smartly handle media adaptation of an ongoing real-time communication session.
An aspect of the embodiments relates to a method of congestion control for a multimedia session.
The embodiments thereby assign unique so-called flow identifiers to each media flow 40, 42 having a same source address and a same destination address. These addresses are preferably source Internet Protocol (IP) address and destination IP address. The source IP address identifies the sender 20 of the media flows 40, 42, i.e. A in
The flow identifiers assigned to the media flows 40, 42 are preferably dedicated for use during congestion monitoring and combatting any detected congestion state. Thus, the flow identifiers are preferably assigned to the respective media flows 40, 42 by an entity, preferably in the sender 20, that is configured or operable to perform congestion control on behalf of the sender 20.
In a particular embodiment, address information of a media flow is used together with information of traffic characteristics of the media as assigned flow identifier for a media flow. The address information preferably comprises the source and destination address of the media flow and more preferably the source IP address and the destination IP address of the media flow. This data is generally available from the IP headers of the data packets carrying the media data of the media flow. Thus, the address data can be read or retrieved from the IP headers of the data packets for the media flow.
Information of the traffic characteristics is preferably in the form of a Differentiated Services Code Point (DSCP) value assigned to the media flow. Differentiated services (DiffServ) is a computer networking architecture that specifies a simple, scalable and coarse-grained mechanism for classifying and managing network traffic and providing quality of service (QoS) on modern IP networks. DiffSery can, for example, be used to provide low-latency to critical network traffic such as voice or streaming media while providing simple best-effort service to non-critical services such as web traffic or file transfers. DiffSery uses the 6-bit Differentiated services Field (DS field) in the IP header for packet classification purposes. This DS field contains a 6-bit DSCP value. Hence, in theory, a network could have up to 26=64 different traffic classes using different DSCPs values. More information of DSCP can be found in Nichols et al., Definition of the Differentiated Services Fiedl (DS Field) in the IPv4 and IPv6 Headers, Network Working Group, Request for Comments: 2474, December 1998.
Thus, in a particular embodiment the flow identifier for a media flow are determined based on the source IP address, destination IP address and DSCP value of that media flow.
For instance, the flow identifier of a media flow can comprise the source IP address, destination IP address and DSCP value of that media flow. The flow identifier may optionally also comprise additional data that can be used to identify the particular media flow. Such additional data could be a salt to create a unique flow identifier. A further alternative is to have a flow identifier that additionally comprises information of port numbers for the media port, such as source port and/or destination port. Hence, in an example the flow identifier comprises or is equal to the source IP address, destination IP address, source port, destination port, DSCP value and optionally a salt.
The flow identifiers are, in an embodiment, assigned to each outgoing media flow that could be adapted. Hence, a respective flow identifier is, in such an embodiment, assigned to each media flow even if the media flows may have different destination addresses.
The two-way network performance measurements in step S2 are performed between the sender 20 and the receiver 30 and/or between the sender 20 and the routers 10, 12 present in the transport network 1 for routing the media flows 40, 42 from the sender 20 to the receiver 30. The measurements could be any two-way measurements that reflect or at least provide an indication of network performance between the sender 20 and the receiver 30 and/or routers 10, 12. Non-limiting examples of such network performance characteristics that could be monitored and estimated during the measurements include latency, jitter, packet loss and/or delay variations.
The measurements are two-way measurements. This indicates that each measurement session involves two entities: an entity that sends data to another entity, which in turn returns data to the sending entity.
A non-limiting but preferred embodiment of such two-way network performance measurements is based on Two Way Active Measurement Protocol (TWAMP). Hence, a preferred embodiment of step S2 comprises performing TWAMP measurements between the sender 20 and at least one of the receiver 30 and the routers 10, 12.
TWAMP is a two-way active performance measurement protocol containing a sender and a reflector. The sender is responsible for initiating the test sessions and sending test packets to the reflector, which receives the packets, time stamps and put relevant information in the TWAMP test packets. Then, the reflector sends back the packets toward the sender. By doing this TWAMP is able to measure end-to-end latency, packet loss, delay-variation, etc. between two end-point IP-addresses and can help realizing the network overload at a certain point of time. It can run multiple test sessions between two IP end-points. In such a case, each test session can be identified by a set of parameters including source IP address, destination IP address, source port, destination port, and transport protocol, i.e. <ip-src, ip-dst, src-port, dst-port, protocol>. The test session can further be characterized by the same DSCP value as in the traffic. This will be further described herein.
In the media application scenario, TWAMP can be used to gauge the congestion in the network by creating multiple sessions to different media destinations and intermediary network nodes and also assigning the TWAMP packets with same IP traffic characteristics, such as DSCP.
Measuring the performance of the link and taking the data to do congestion control by identifying network bottleneck are the primary principles of this work.
More information about TWAMP can be found in Hedayat et al., A Two-Way Active Measurement Protocol (TWAMP), Network Working Group, Request for Comments: 5357, October 2008 (denoted RFC 5357 herein).
In such a case, the sender 20 preferably acts as TWAMP sender, also referred to as session-sender, with the receiver 30 as TWAMP reflector, also referred to as session-reflector, and/or the routers 10, 12 as TWAMP reflectors. The TWAMP sender then sends TWAMP test packets to the respective TWAMP reflectors. The TWAMP test packets are received and time stamped by the TWAMP reflectors. The TWAMP reflector preferably copy the packet sequence number into a corresponding reflected packet destined to the TWAMP sender. The TWAMP reflector sends a TWAMP test packet back to the TWAMP sender in response to the received packet. The TWAMP reflector also adds information about the actual sending time as its time stamp in the packet. This permits the determination of the elapsed time between the reception of the packet and its transmission.
The two-way network performance measurements, preferably TWAMP measurements, performed in step S2 could be performed periodically between the sender 20 and the receiver 30 and/or the routers 10, 12. Alternatively, they can be performed at scheduled time instances or upon selected triggering events, such as reception of a request for monitoring current network performance in the transport network 1.
The two-way network performance measurements, such as TWAMP measurements, performed in step S2 are then used in step S3 to detect a congestion state for a flow route in the transport network 1. In this detection all the TWAMP measurement results obtained from step S2 could be used or at least a portion thereof. The detection in step S3 is therefore preferably performed based on at least one network performance metric or parameter obtained or derived from the TWAMP measurements, such as two-way latency, packet loss and/or delay variation.
In the case of TWAMP measurements, information of the sent TWAMP test packets and information of the received time stamped TWAMP packets can be used in the sender 20 in order to derive the particular network performance metric or parameter. For instance, the estimate time between transmission of a TWAMP test packet and reception of the TWAMP test packet can be used in order to calculate a latency or delay parameter value. Correspondingly, information of the number of lost TWAMP test packets can be used in order to calculate a packet loss parameter value.
The flow identifiers, or at least a portion thereof, assigned in step S1 are then used in step S4 together with the mapping information in order to identify at least media flow to adapt in order to combat the congestion state. Hence, the flow route that is causing the congestion is detected based on the two-way network performance measurements and the detected flow route is mapped into at least one media flow using the mapping information and the flow identifiers. Hence, the mapping information translates the detected flow route into at least one flow identifier of respective media flows that travels along the detected flow route. The at least one flow identifier is then used in order to determine which media flow(s) that travel(s) along the detected flow route. Hence, it is among the determined media flow(s) that a suitable media flow, the media rate of which is to be adapted, is selected.
Adaptation of media rate can be performed according to various embodiments. For instance, the bit rate of the media flow could be adapted, such as reduced; the frame rate could be adapted, such as reduced; the resolution of the media data carried in the media stream can be adapted, such as reduced; or any combination of them.
In a particular embodiment, a congestion control module (CCM) is provided at the sender 20 and preferably also at the receiver 30. In such a case, the assignment of flow identifiers in step S1 could be performed according to the embodiment as shown in
The sender 20 comprises an application, which is a general entity or function responsible for providing or generating the media flows 40, 42. The application could, for instance, be a media engine generating media or video data to be transmitted through the transport network to the receiver 30. Alternatively, the application could represent a video camera filming a scene to generate video data of the media flows 40, 42. Further examples include a media server having access to multiple video or media channels that can be distributed to the receiver 30 as media flows. Actually, any application that generates or otherwise provides, such as fetches from a memory, media data to form media flows 40, 42 could register media flows 40, 42 at the CCM in step S10. The CCM then assigns each registered media flow a unique flow identifier that is used in the congestion control method.
In the case of, flow identifiers representing at least source and destination IP address together with DSCP values, the CCM could retrieve this data from the IP headers of the data packets of the registered media flows. Alternatively, the application explicitly communicates this data to the CCM.
In an embodiment as shown in
Thus, in a particular embodiment, the congestion control method involves not only the previously mentioned CCM but also a BDM. This BDM is preferably also provided in the sender 20 and optionally but preferably also at the receiver 30. Real-time multimedia sessions are usually bi-directional, i.e. full duplex. In such a case, a CCM and a BDM is preferably provided both in the sender 20 and in the receiver 30. However, for a particular session from the sender 20 to the receiver 30 it could be sufficient with a CCM and a BDM at the sender 20.
The CCM and the BDM are able to communicate with each other using an API. The API then defines how the CCM and BDM communicates with each other and share relevant information with each other. Thus, the CCM forwards information of the assigned flow identifiers to the BDM. The BDM is then the module that performs the two-way network performance measurements, preferably the TWAMP measurements, with the receiver 30 and/or the routers 10, 12, such as with a respective BDM in the receiver 30 and/or the routers 10, 12. The BDM preferably also detects the congestion state based on the two-way network performance measurements, preferably the TWAMP measurements.
Hence, once the BDM has detected a congestion state for a flow route it preferably uses the mapping information in order to determine which media flow or flows that are transported through the transport network along the congested flow route. The BDM thereby uses the mapping information in order to retrieve flow identifier of any affected media flow and uses the API to communicate the flow identifier or identifiers to the CCM. The CCM can then take actions in order to control the adaptation of the media rate of the media flow or flows to combat the congestion state.
A multimedia session can have multiple streams and they can follow different network paths between communication peers. It is expected that streams having same 5 tuples (protocol, src_address, dst_address, src_port, dst_port) are routed via same network path. However, there are reasons like load balancing, node failures etc. which can lead to assign different network path to flows even if they share same 5 tuples. Also, to have 5 tuples for all RTP streams it is required that applications use port multiplexing. That is not always the situation.
In an embodiment, a first media flow 40 of the multiple media flows 40, 42 is routed through a first flow route in the transport network 1 between the sender 20 and the receiver 30. Correspondingly, a second media flow 42 of the multiple media flows 40, 42 is routed through a second, different flow route in the transport network 1 between the sender and the receiver 30.
Thus, the first and second media flows 40, 42 preferably have same source address (src_address) and destination address (dst_adress) but are routed between different flow routes in the transport network 1.
In a particular embodiment, the first and second media flows 40, 42 have the same source and destination IP address but different DSCP values. The first and second media flows 40, 42 typically also have different ports, i.e. different combinations of source and destination ports.
Thus, the present embodiments provide a way of detecting shared bottleneck and give a way to the applications to do proper congestion control by using, in an embodiment, the CCM and the BDM and by assigning a unique identifier (FID) for each flow, by e.g. doing the following:
In an embodiment, the Congestion Control Module (CCM) is responsible for adapting the flows 40, 42 between sender 20 and receiver 30. The CCM communicates with the BDM via a set of APIs to get indication on which flow to adapt and then communicate with the media entity, i.e. encoder, to enforce the adaptation on a particular flow. Whenever the application instantiate a media flow 40, 42 between a source and a destination, for example A 20 and C 30 in
A BDM is preferably a TWAMP-based controller or sender which resides at the origin of the application. The BDM could be integrated with the host of the application or can be in implemented inside the application or even can be placed at the transport network 1. In all cases there will be APIs so that the CMM and the BDM can communicate with each other.
The BDM assumes, in a particular embodiment, that all the Bottleneck (BN) routers 10, 12, 14 implement TWAMP light reflectors or RFC 5357 standard reflectors. The BDM preferably creates TWAMP sessions with all the routers 10, 12, 14 that are involved in the communication path between sender 20 of the media and receiver 30 of the media, see
In an embodiment as further shown in
In this particular embodiment, the BDM preferably is involved in TWAMP test sessions (TS1, TS2) with at least each router 10, 12 of the transport network 1 that is involved in forwarding the media flows 40, 42 from the sender 20 to the receiver 30. The respective TWAMP test session and measurements result in at least one respective performance parameter value (M1, M2). This performance parameter value could, for instance, represent latency, delay, jitter or packet loss. The performance parameter value could represent a single value obtained in the respective TWAMP test session, such as a most recent determined value of the particular performance characteristic (latency, delay, jitter or packet loss). Alternatively, the performance value could be calculated in step S41 as an average, median or variation of values obtained from multiple TWAMP test occasions.
The values obtained from the TWAMP measurements and test sessions TS1, TS2 typically represent the performance parameter for the transport link between the sender 20 and each respective router 10, 12. Hence, in order to obtain performance parameter values for each transport link, such as between sender 20 and first router 10 and between first router 10 and second router 12, the BDM preferably uses at least some of the values obtained from the TWAMP measurements performed in step S40. For instance, the performance parameter value M1 for the link between the sender 20 and the first router 10 is typically obtained directly from the TWAMP measurements performed for the TWAMP test session TS1. The performance parameter value for the link between the first router 10 and the second router 12 could, however, be calculated based on the performance parameter value M1 and the performance parameter value M2 for the link between the sender 20 and the second router 12 and obtained from the TWAMP measurements performed for the TWAMP test session TS2. For instance, the performance parameter value for this router-to-router link could be calculated as a difference between M2 and M1 (M2−M1).
Each calculated performance parameter value (M1, M2−M1) is then preferably compared to the performance threshold in step S42. If the performance parameter value represents a worse network performance than what is represented by the performance threshold then there is a significant risk for congestion. For instance, if the performance parameter represents delay then there is no congestion if the respective performance parameter value is below the performance threshold. However, if any of the performance parameter values exceeds, in this particular embodiment, the threshold value the BDM detects a congested router.
For instance, assume that M1 is below the threshold value but (M2−M1) is not. The BDM can then conclude that the first router 10 is working correctly but detect that the second router 12 is in a congestion state.
The particular media flow to adapt can then be identified based on information of this detected router 12, which can be used in order to identify which media flows 40 that go through this router 12 using the mapping information. In an embodiment, this is possible since the TWAMP measurements involving the detected router 12 and the media flows 40 routed through this router 12 use a same DSCP value as previously described herein. This means that by detecting the router 12 the BDM is able to provide the relevant DSCP value that was assigned to the TWAMP test session TS2 performed by the BDM between the sender 20 and the router 12. The DSCP value can then provide the flow identifier of any media flow 40 routed by the detected router 12 since, in an embodiment, the flow identifier preferably represents the source and destination (IP) address of the media flow together with the DSCP value for the media flow 40. Thus, the BDM is able to provide a list of flow identifiers of the media flows 40 routed by the congested router 12. In this embodiment, the mapping information therefore preferably lists, for each router 10, 12, flow identifiers of the media flows routed by the particular router 10, 12 from the sender 20 towards the receiver 30 in the transport network 1.
Thus, in this embodiment, when a congestion state is detected and a shared bottleneck is detected, i.e. router 12, the BDM sends the flow identifiers of the media flows 42 sharing this bottleneck to the CCM. The CCM then groups them together and does rate adaptation in order to combat the congestion state.
The provision of flow identifiers as performed by the BDM in step S50 is preferably performed based on the DSCP values of the media flows and the DSCP values of the two-way network performance measurements (TWAMP measurements) conducted by the BDM for the sender 20 and the routers 10, 12.
Here below a particular implementation example will be provided denoted Shared Bottleneck Detection Function (Method 1).
Method 1 uses measurements towards TWAMP to determine the bottleneck points in the communication path and based on their results it chooses one of the flows to do the rate adaptation.
In method 1, the BDM assumes
In the example scenario, see
M2=Measurement from A (TWAMP sender) 20 to BN2 (reflector) 12, for instance one-way-delay.
M1=Measurement from A (TWAMP sender) 20 to BN1 (reflector) 10, for instance one-way-delay.
Hence, (M2−M1)=indicates the delay between BN1 10 and BN2 12.
Now, if M1<TM and (M2−M1)>TM, then we can assume that BN1 10 is fine and there is problem in the path between BN1 10 and BN2 12 or in BN2 12 itself. This way we can isolate the bottleneck in the network 1 and select proper flows 42 to be adapted. Hence, BDMA indicates to the CCM to start adaption on flows 42 that pass through BN2 12. This means that A 20 only has to adapt flow A2 42 and does not need to adapt A1 40 at all.
In another embodiment as further shown in
In this particular embodiment, the BDM preferably is involved in TWAMP test sessions (TSA1, TSA2) with receiver 30 for each media flow 40, 42 from the sender 20 to the receiver 30, see
This step S61 is basically performed as described in the foregoing in connection with step S41 of
In a particular embodiment, the source and destination IP address together with DSCP value can be used as flow identifiers for the media flows 40, 42. In such a case, the TWAMP measurement packets transmitted between the sender 20 and the receiver 30 in step S60 preferably also use the same flow identifier, i.e. source and destination IP address together with DSCP value, so that both media packets of each media flow 40, 42 and the respective TWAMP measurement packets are routed in the same flow route in the transport network 1. In such a case, the BDM preferably sends the flow identifier of any media flow affected by the congestion state for the flow route detected in step S63 to the CCM. The CCM can then use this flow identifier in order to determine which media flow(s) to adapt in order to combat the congestion state.
Thus, the BDM communicates the flow identifier of the media flow routed along the flow route that is detected to be in a congestion state in step S63 of
The BDM can then calculate, in step S61 of
Here below a particular implementation example will be provided denoted Shared Bottleneck Detection Function by flow path (Method 2).
In this method, the TWAMP measurements indicate the performance of the end to end flow path.
In method 2, the BDM assumes:
In the example, if MA1 or MA2 exceeds the threshold value, then the BDMA detects congestion for the respective flow 40, 42 and indicates the CCM to adapt the correct flow. If flow A1 40 and flow A2 42 is following same route then congestion will be visible on both MA1 and MA2 as they will follow the same flow path and shared resources and the CCM will have to adapt both of the media flows 40, 42.
In an embodiment, the BDMA has knowledge of the media flows 40, 42 and their flow routes. The BDMA preferably uses TWAMP measurements between itself and routers 10, 12, i.e. potential bottleneck points, TS1, TS2, and between itself and BDMc in the receiver 30, TSA1, TSA2. The sender 20 preferably keeps a database that maps the flow routes and routers 10, 12 and application policies on that flow route. The sender 20 preferably also keeps a performance measurement table based on the TWAMP measurements involving the routers 10, 12 and the BDMc. In an embodiment, DSCP values may be used as flow identifiers, preferably together with IP source and destination addresses, and identifiers of flow types, such as voice, video, etc. The DSCP values used for the respective media flows 40, 42 are copied into TWAMP test packets in order to direct the TWAMP test packets along the same respective flow routes as the media flows 40, 42.
An example of a database or table in the sender 20 could be as defined below:
An example of a performance measurement table in the sender 20 could be as defined below:
<A, BN1> delay=30 ms, jitter=5 ms/s
<A, BN2> delay=50 ms, jitter=1 ms/s
<A, BN3> delay=25 ms, jitter=5 ms/s
<A, BN1, C> delay=35 ms, jitter=2 ms/s
<A, BN2, C> delay=52 ms, jitter=5 ms/s
<A, BN3, C> delay=30 ms, jitter=2 ms/s
An implementation and deployment example of these tables can have many variations depending on the configuration, implementation and policies. However, based on the information provided in these tables, the sender 20 can intelligently make decision to adapt of the media flows passing BN2, i.e. media flows identified by flow identifiers FID4 and/or FID5.
The performance threshold discussed in the foregoing and compared to the calculated performance parameters values could be a single performance threshold. Alternatively, different performance thresholds can be used for different transport links or different flow routes.
Hence, embodiments of the present technology provide a way to discover shared bottleneck in the transport network to help adaption algorithms to smartly handle media adaption of an ongoing real-time communication session. Thus, the application does not need to blindly adapt all the media flows. Instead, it can make an efficient and easy decision on which flow to adapt.
In a particular embodiment, the application can enforce media priority as intended as it has specific knowledge about a particular flow.
In a fixed setup scenario, such as video conference call between different enterprise sites, the BDM can be active all the time in the application and help the application select a suitable start up rate for the current video conference.
Hence, this solution adds a new dimension to the end to end adaptation and completely different from the way it is done today.
Another aspect of the embodiments relates to a device for congestion control of a multimedia session. The device is operable to assign a respective flow identifier to each media flow of multiple media flows having a same source address and a same destination address. The device is also operable to perform two-way network performance measurements between a sender of the multiple media flows and at least one of a receiver of the multiple media flows and routers present in a transport network and configured to route the multiple media flows from the sender through the transport network to the receiver. The device is further operable to detect a congestion state in the transport network affecting at least one media flow of the multiple media flows in the transport network based on at least a portion of the two-way network performance measurements. The device is additionally operable to identify a media flow of the multiple media flows, a media rate of which is to be adapted to combat the congestion state, based on at least a portion of the flow identifiers and mapping information defining a mapping between flow routes through the transport network and flow identifiers for the multiple media flows.
The device for congestion control 100 may, in an embodiment, be implemented as comprising a processor 110 and a memory 120, see
The processor 110 and the memory 120 of the device 100 are preferably are interconnected to each other to enable normal software execution. In
In an embodiment, the processor 110 is preferably operable to perform TWAMP measurements between the sender and at least one of the receiver and the routers.
The processor 110 is, in an embodiment, preferably operable to register the multiple media flows originating from an application in the sender. The processor 110 is preferably also operable to assign a respective flow identifier to each registered media flow.
In an embodiment, the processor 110 is operable to perform two-way network performance measurements between the sender and each router of the routers present in the transport network and configured to route the multiple media flows. The processor 110 is preferably also operable to calculate, based on the two-way network performance measurements, a respective performance parameter value for each transport link over which the multiple media flows are transported in the transport network. The processor 110 is further operable to compare the respective performance parameter value to a performance threshold and detect, based on the comparison, a router of the routers present in the transport network and configured to route the multiple media flows, wherein this router is in the congestion state. The processor 110 is, in this embodiment, additionally operable to identify the media flow based on the information of the detected router, the mapping information and at least a portion of the flow identifiers.
In another embodiment, the processor 110 is operable to perform two-way network performance measurements between the sender and the receiver and for each media flow of the multiple media flows having a respective DSCP value. The processor 110 is preferably also operable to calculate, based on the two-way network performance measurements, a respective performance parameter value for each media flow of the multiple media flows. In this embodiment, the processor 110 is further operable to compare the respective performance parameter values to a performance threshold and detect, based on the comparison, a flow route that is in the congestion state. The processor 110 is additionally operable to identify the media flow based on information of the detected flow route, at least a portion of the flow identifiers and the mapping information.
In a particular implementation embodiment, the processor 110 is operable to transmit, for each media flow of the multiple media flows and to the receiver, TWAMP test packets having a same source address, a same destination address and a same DSCP value as the media flow. The processor 110 is also operable to receive, from the receiver, TWAMP test packets time stamped by the receiver.
In another particular embodiment, the processor 110 is operable to perform two-way network performance measurements between the sender and each router of the routers present in the transport network and configured to route media flows through the detected flow route. The processor 110 is also operable to calculate, based on the two-way network performance measurements, a respective performance parameter value for each transport link for the detected flow route in the transport network. The processor 110 is preferably also operable to compare the respective performance parameter values to a performance threshold and detect, based on this comparison, a router that is in the congestion state of the routers present in the transport network and configured to route media flows through the detected flow route. In this embodiment, the processor 110 is additionally operable to identify the media flow, a media rate of which to adapt, based on information of the detected router, at least a portion of the flow identifiers and the mapping information.
In an embodiment, the device for congestion control 200 is implemented as comprising a CCM 210 and a BDM 220 as illustrated in
In an embodiment, the CCM 210 preferably comprises an input/output (I/O) interface 212 operable to communicate with the BDM as shown in
The processors 214, 224 of the CCM 210 and the BDM 220 then basically correspond to and performs the operations of the processor 110 as shown in
The processor 214 of the CCM 210 is preferably operable to assign the respective flow identifier to each media flow of the multiple media flows. The processor 214 is also operable to control adaptation of a media rate of a media flow of the multiple media flows that is identified based on at least a portion of the flow identifiers and the mapping information.
The processor 224 of the BDM 220 is preferably operable to perform the two-way network performance measurements between the sender and at least one of the receiver and the routers. The processor 224 is also operable to detect the congestion state in the transport network based on at least a portion of the two-way network performance measurements.
It will be appreciated that the methods and devices described herein can be combined and re-arranged in a variety of ways.
For example, embodiments may be implemented in hardware, or in software for execution by suitable processing circuitry, or a combination thereof.
The steps, functions, procedures, modules and/or blocks described herein may be implemented in hardware using any conventional technology, such as discrete circuit or integrated circuit technology, including both general-purpose electronic circuitry and application-specific circuitry.
Particular examples include one or more suitably configured digital signal processors and other known electronic circuits, e.g. discrete logic gates interconnected to perform a specialized function, or Application Specific Integrated Circuits (ASICs).
The measurement unit 320 is preferably connected to the identifier assigning unit 310 in order to access the flow identifiers assigned to the media flows and in particular, in an embodiment, DSCP values from the flow identifiers. In such a case, the DSCP values of the media flows can be re-used in the two-way network performance measurements, preferably TWAMP measurements, as previously discussed herein. The results of the two-way network performance measurements are preferably forwarded from the measurement unit 320 to the detecting unit 330 to be used therein to detect any congestion state. If such a congestion state is detected, the detecting unit 330 informs the identifying unit 340 to identify one or more media flows, the media rate of which to be adapted in order to combat the congestion state.
Alternatively, at least some of the steps, functions, procedures, modules and/or blocks described herein may be implemented in software such as a computer program for execution by suitable processing circuitry such as one or more processors or processing units.
The flow diagram or diagrams presented herein may therefore be regarded as a computer flow diagram or diagrams, when performed by one or more processors. A corresponding device may be defined as a group of function modules, where each step performed by the processor corresponds to a function module. In this case, the function modules are implemented as a computer program running on the processor.
Examples of processing circuitry includes, but is not limited to, one or more microprocessors, one or more Digital Signal Processors (DSPs), one or more Central Processing Units (CPUs), video acceleration hardware, and/or any suitable programmable logic circuitry such as one or more Field Programmable Gate Arrays (FPGAs), or one or more Programmable Logic Controllers (PLCs).
It should also be understood that it may be possible to re-use the general processing capabilities of any conventional device or unit in which the proposed technology is implemented. It may also be possible to re-use existing software, e.g. by reprogramming of the existing software or by adding new software components.
In the following, an example of a computer implementation will be described with reference to
The term ‘user equipment’ should be interpreted in a general sense as any system, apparatus or device capable of executing program code or computer program instructions to perform a particular processing, determining or computing task.
In a particular embodiment, the computer program 740 comprises program code or code means which when executed by the processor 710 causes the processor 710 to assign a respective flow identifier to each media flow of multiple media flows having a same source address and a same destination address. The program code also causes the processor 710 to perform two-way network performance measurements between a sender of the multiple media flows and at least one of a receiver of the multiple media flows and routers present in a transport network and configured to route the multiple media flows from the sender through the transport network to the receiver. The program code further causes the processor 710 to detect a congestion state in the transport network affecting at least one media flow of the multiple media flows in the transport network based on at least a portion of the two-way network performance measurements. The program code additionally causes the processor to identify a media flow of the multiple media flows, a media rate of which is to be adapted to combat the congestion state, based on at least a portion of the flow identifiers and mapping information defining a mapping between flow routes through the transport networks and flow identifiers for the multiple media flows.
The software or computer program 740 may be realized as a computer program product 730, which is normally carried or stored on a computer-readable medium. The computer-readable medium may include one or more removable or non-removable memory devices including, but not limited to a Read-Only Memory (ROM), a Random Access Memory (RAM), a Compact Disc (CD), a Digital Versatile Disc (DVD), a Universal Serial Bus (USB) memory, a Hard Disk Drive (HDD) storage device, a flash memory, or any other conventional memory device. The computer program 740 may thus be loaded into the operating memory of a computer or equivalent user equipment for execution by the processor 710 thereof.
Hence, an aspect of the embodiments relates to a computer program product 730 comprising computer readable code mans and a computer program 740 as defined above stored on the computer readable code means.
As indicated herein, the device for congestion control may alternatively be defined as a group of function modules, where the function modules are implemented as a computer program running on a processor.
The computer program residing in memory may thus be organized as appropriate function modules configured to perform, when executed by the processor, at least part of the steps and/or tasks described herein. An example of such function modules is illustrated in
The user terminal 500, 600 preferably also comprises a transmitter (TX) and a receiver (RX), exemplifies as a common transceiver 510, 610 in the figures. The transceiver 510, 610 is then employed for transmitting data packets of media data of the multiple media flows from the user terminal 500, 600 through routers in the transport network towards the receiver. The transceiver 510, 610 is preferably also operable to conduct the two-way network performance measurements, such as transmitting and receiving TWAMP test packets.
The figures also illustrate the multimedia application 520, 620 that generates or at least provides the media flows to be transmitted by the transceiver 510, 620. In
The user terminal 500, 600, 700 of
The embodiments described above are to be understood as a few illustrative examples of the present technology. It will be understood by those skilled in the art that various modifications, combinations and changes may be made to the embodiments without departing from the scope of the present technology. In particular, different part solutions in the different embodiments can be combined in other configurations, where technically possible. The scope of the present technology is, however, defined by the appended claims.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/SE2014/050089 | 1/24/2014 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
61834629 | Jun 2013 | US |