Multipath policy decisions for encrypted video streams
11533546 · 2022-12-20
Assignee
Inventors
- Rodrigo Alvarez Dominguez (Madrid, ES)
- Carlos Jimenez Cordon (Madrid, ES)
- Marc Molla (Madrid, ES)
- Miguel Angel Muñoz De La Torre Alonso (Madrid, ES)
- Miguel Angel Puente Pestaña (Madrid, ES)
- Carlota Villasante (Madrid, ES)
Cpc classification
H04N21/8456
ELECTRICITY
H04N21/64746
ELECTRICITY
International classification
H04N21/647
ELECTRICITY
H04L45/00
ELECTRICITY
Abstract
The invention relates to a method, for controlling at least one path in a multipath environment by a path control entity, wherein the at least one one path is used for transmitting an encrypted video stream comprising a sequence of video segments. The method comprises the following steps: estimating a resolution used in the video stream based on the video segments, and determining that the resolution used in the video stream has changed during the transmission. When it is determined that the resolution used in the video stream has changed, an adaptation of a number of the at least one path used for transmitting the video stream in the multipath configuration is initiated based on the determined change of the resolution.
Claims
1. A method for controlling, by a path control entity, at least one path in a multipath environment, the at least one path being used for transmitting an encrypted video stream comprising a sequence of video segments, the sequence of video segments including a first video segment and a second video segment, the method comprising: receiving a content request using a multipath Transmission Control Protocol (TCP), wherein the request was transmitted by a user device; transmitting the content request towards a first server using a non-multipath TCP; receiving a first video segment using the non-multipath TCP, wherein the first video segment was transmitted by the first server; based at least on receiving the first video segment, obtaining first path information indicating a first path which is selected from a plurality of paths; transmitting towards the user device the first video segment using the multipath TCP and the selected first path; after transmitting the first video segment, receiving a second video segment using the non-multipath TCP, wherein the second video segment was transmitted by the first server; analyzing the second video segment, thereby obtaining a target video quality; estimating a quality used in the video stream; determining that the quality used in the video stream has changed; after determining that the quality used in the video stream has changed, obtaining second path information indicating the first path and a second path which are selected from the plurality of paths; and initiating transmission of the video stream via the first and second paths.
2. The method according to claim 1, further comprising: determining a change in a size of one or more video segments in the video stream over time, wherein the quality used in the video stream is estimated based on the determined change of the size.
3. The method according to claim 1, comprising: informing a policy controller configured to control a transmission policy of the video stream in the multipath environment of the determined change in the quality; and determining which one or more of the plurality of paths to use for transmission of the video stream based on a feedback received from the policy controller.
4. The method according to claim 1, wherein determining that the quality used in the video stream has changed comprises determining that the quality used in the video stream during the transmission has decreased.
5. The method according to claim 2, wherein determining the change of the size comprises determining an average size of a defined number of a group of video segments in the video stream and determining a mean value of the average size of the defined number of the group of video segments, and determining which one or more of the plurality of paths to use for transmission of the video stream based on whether a deviation of the mean value is larger than a threshold value.
6. The method according to claim 1, wherein the video segments comprise payload data transmitted over at least one path in a first transmission direction, the payload data is transmitted between two consecutive requests requesting to receive the video stream, and the two consecutive requests are transmitted in a direction opposite to the first transmission direction.
7. The method according to claim 1, wherein, when it is determined that the quality used in the video stream during the transmission remains substantially the same, it is determined that the quality is in a lower quality range of a known possible quality range, and wherein, when it is determined that the quality changes by more than a defined threshold, it is determined that the quality is in a higher quality range of the known possible quality range.
8. The method according to claim 1, wherein the encrypted video stream is identified as being a video stream based on a name indication present in a message exchanged between a video streaming entity and a video receiving entity, the name indication allowing the video streaming entity to be identified.
9. The method according to claim 1, wherein the quality is estimated based on a Machine Learning algorithm embedded in a Deep Packet Inspection module which comprises a first clustering part in which different possible qualities of the video stream are determined based on test data and comprises a second classification part in which the video stream is classified in one of the possible qualities.
10. The method of claim 1, wherein the target video quality is associated with a first value, the estimated quality is associated with a second value, and determining whether the quality used in the video stream has changed comprises determining whether the difference between the first and second values is greater than a threshold value.
11. The method of claim 1, wherein in case a constant bit rate scheme is used for transmitting the encrypted video stream, the quality used in the video stream is estimated based on a first size of a first video segment included in the video stream and a second size of a second video segment included in the video stream, and in case a variable bit rate scheme is used for transmitting the encrypted video stream, the quality used in the video stream is estimated based on a deviation of the first video segment with respect to other video segments included in the video stream.
12. A path control entity configured to control at least one path in a multipath environment, the at least one path being used for transmitting an encrypted video stream comprising a sequence of video segments, the sequence of video segments including a first video segment and a second video segment, the path control entity comprising a memory and at least one processing unit, the memory containing instructions executable by said at least one processing unit, wherein the path control entity is operative to: receive a content request using a multipath Transmission Control Protocol (TCP), wherein the request was transmitted by a user device; transmit the content request towards a first server using a non-multipath TCP; receive a first video segment using the non-multipath TCP, wherein the first video segment was transmitted by the first server; based at least on receiving the first video segment, obtain first path information indicating a first path which is selected from a plurality of paths; transmit towards the user device the first video segment using the multipath TCP and the selected first path; after transmitting the first video segment, receive a second video segment using the non-multipath TCP, wherein the second video segment was transmitted by the first server; analyzing the second video segment, thereby obtaining a target video quality; estimate a quality used in the video stream; determine that the quality used in the video stream has changed; after determining that the quality used in the video stream has changed, obtain second path information indicating the first path and a second path which are selected from the plurality of paths; and initiate transmission of the video stream via the first and second paths.
13. The path control entity according to claim 12, further being operative to: determine a change in a size of one or more video segments in the video stream over time, wherein the quality used in the video stream is estimated based on the determined change of the size.
14. The path control entity according to claim 12, wherein the path control entity is configured to: inform a policy controller configured to control a transmission policy of the video stream in the multipath environment of the determined change in the quality; and determine which one or more of the plurality of paths to use for transmission of the video stream based on a feedback received from the policy controller.
15. The path control entity according to claim 12, wherein determining that the quality used in the video stream has changed comprises determining that the quality used in the video stream during the transmission has decreased.
16. The path control entity according to claim 13, wherein determining the change of the size comprises determining an average size of a defined number of a group of video segments in the video stream and to determine a mean value of the average size of the defined number of the group of video segments, and determining which one or more of the plurality of paths to use for transmission of the video stream based on whether a deviation of the mean value is larger than a threshold value.
17. The path control entity according to claim 12, wherein the path control entity is operative, when the quality used in the video stream during the transmission remains substantially the same, to determine that the quality is in a lower quality range of a known possible quality range, and when the quality changes by more than a defined threshold, the path control entity is operative to determine that the quality is in a higher quality range of the known possible quality range.
18. The path control entity according to claim 12, wherein the path control entity is operative to estimate the quality based on a Machine Learning algorithm embedded in a Deep Packet Inspection module which comprises a first clustering part in which different possible qualities of the video stream are determined based on test data and comprises a second classification part in which the video stream is classified in one of the possible qualities.
19. The path control entity according to claim 12, wherein the path control entity is a hybrid access gateway or a policy controller located in a hybrid access broadband network.
20. A computer program product comprising a non-transitory computer readable medium storing a computer program comprising program code to be executed by at least one processing unit of a path control entity, wherein execution of the program code causes the at least one processor to execute a method for controlling, by a path control entity, at least one path in a multipath environment, the at least one path being used for transmitting an encrypted video stream comprising a sequence of video segments, the sequence of video segments including a first video segment and a second video segment, the method comprising: receiving a content request using a multipath Transmission Control Protocol (TCP), wherein the request was transmitted by a user device; transmitting the content request towards a first server using a non-multipath TCP; receiving a first video segment using the non-multipath TCP, wherein the first video segment was transmitted by the first server; based at least on receiving the first video segment, obtaining first path information indicating a first path which is selected from a plurality of paths; transmitting towards the user device the first video segment using the multipath TCP and the selected first path; after transmitting the first video segment, receiving a second video segment using the non-multipath TCP, wherein the second video segment was transmitted by the first server; analyzing the second video segment, thereby obtaining a target video quality; estimating a quality used in the video stream; determining that the quality used in the video stream has changed; after determining that the quality used in the video stream has changed, obtaining second path information indicating the first path and a second path which are selected from the plurality of paths; and initiating transmission of the video stream via the first and second paths.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
(1) The foregoing and additional features and effects of the application will become apparent from the following detailed description when read in conjunction with the accompanying drawings in which like reference numerals refer to like elements.
(2)
(3)
(4)
(5)
(6)
(7)
(8)
(9)
(10)
(11)
(12)
(13)
(14)
(15)
DETAILED DESCRIPTION OF EMBODIMENTS
(16) In the following, embodiments of the invention will be described in detail with reference to the accompanying drawings. It is to be understood that the following description of embodiments is not to be taken in a limiting sense. The scope of the invention is not intended to be limited by the embodiments described hereinafter or by the drawings, which are to be illustrative only.
(17) The drawings are to be regarded as being schematic representations, and elements illustrated in the drawings are not necessarily shown to scale. Rather, the various elements are represented such that their function and general purpose becomes apparent to a person skilled in the art. Any connection or coupling between functional blocks, devices, components of physical or functional units shown in the drawings and described hereinafter may also be implemented by an indirect connection or coupling. A coupling between components may be established over a wired or wireless connection. Functional blocks may be implemented in hardware, software, firmware, or a combination thereof.
(18) Within the context of the present application, the term “mobile entity” or “user equipment” (UE) refers to a device for instance used by a person (i.e. a user) for his or her personal communication. It can be a telephone type of device, for example a telephone or a Session Initiating Protocol (SIP) or Voice over IP (VoIP) phone, cellular telephone, a mobile station, cordless phone, or a personal digital assistant type of device like laptop, notebook, notepad, tablet equipped with a wireless data connection. The UE may also be associated with non-humans like animals, plants, or machines. A UE may be equipped with a SIM (Subscriber Identity Module) or electronic-SIM comprising unique identities such as IMSI (International Mobile Subscriber Identity), TMSI (Temporary Mobile Subscriber Identity), or GUTI (Globally Unique Temporary UE Identity) associated with the user using the UE. The presence of a SIM within a UE customizes the UE uniquely with a subscription of the user.
(19)
(20) In
(21) In the following a mechanism be disclosed in which the resolution of an encrypted video which is transmitted in the embodiment of
(22) In the following it will be described how the resolution of the video stream or how the quality of the media stream is estimated. Furthermore the opening multipath leg based on the determined resolution is disclosed, the closing of a multipath leg based on the determined resolution. Furthermore implementation details for closing and opening a path in the multipath environment is given and an example of opening a multipath leg for a video session.
(23) In the examples given below it is supposed that no services are able to support multipath from an end-to-end perspective in the mobile network. In
Estimation of Video Quality
(24) In the following it will be disclosed how the quality of the encrypted video is estimated based on the resolution of the video.
(25) The video resolution is analyzed according to the size of a video segment and its deviation against the mean of the average size of the video segments.
(26) In
(27) According to the table shown in
(28) When using CBR, the deviation between the different segments is not relevant to determine the video resolution (as all segments do have the same size) but the segment size will determine it, as the higher the quality the higher the segment size is.
(29) When using VBR, the deviation between the different segments provides the video quality, wherein the higher the deviation the higher is the video quality.
(30) When using CBR, it is enough with 2-3 video segments (for IOS, 12-18 seconds approximately) to derive the video resolution.
(31) When using VBR, 5-7 video segments (for IOS, 30-42 seconds approximately) are enough to derive the video resolution.
(32) The resolution of the video stream is detected analyzing the segment size of each video segment. Then, with this video segment size the resolution of the video can be deduced. The way to calculate the segment size for a video over HTTPS considers that: by means of the SNI (Subject name Indication) in a Client Hello message, it is identified that the flow contains video payload after a TLS (Transport Layer Security) handshake phase with the video server 20 is over, each uplink packet that has a TLS record containing Application data is considered as if a plain GET request is received when identifying an uplink packet with TLS Record containing Application data, DPI (Deep Packet Inspection) will start accumulating all the downlink payload received until next uplink packet with TLS Record containing Application Data. Above payload accumulation provides the segment size but to minimize the error, the size can be determined such that it lays in between some safety margins.
(33) DPI can calculate each segment size and track how much the size of the following segments is deviated from the size of the previous segment. So, during a video download if the size of the segments decreases it means that the quality of the video has decreased and the QoE of the end user has been reduced.
(34) To derive the video quality from the size deviation of the video segments, a Machine Learning algorithm (embedded in SPI software) can be used.
(35) Machine learning is a scientific discipline that explores the construction and study of algorithms that can learn from data. Such algorithms operate by building a model based on inputs and using that to make predictions or decisions, rather than following only explicitly programmed instructions.
(36) Machine learning techniques for traffic classification are based on behavioral characteristics from protocols and flows, such as TCP window size, ports, ip address, packet size distribution, time between packets, payload bit level statistics, etc. In unsupervised learning mode, machine is learning and comparing the behavior of the group towards the new devices, protocols. Then it groups those with same characteristics in the same cluster. By using unsupervised learning there is a growing accuracy when classifying packets. As more traffic goes through machine learning, clustering becomes a fine-grained classification, improving both the number of categories, and the fitness of each packet, according to its behavior.
(37) In the present case the following steps may be carried out to train the algorithm:
(38) 1—First, a set of captures should be made, with different qualities selected, to train the algorithm: YouTube, Netflix, Vimeo, etc.
(39) 2—The above captures can be preprocessed, a temporal series with the outcoming and incoming payload is elaborated. The temporal series are created using the timestamp of each packet.
(40) 3—The Machine Learning (ML) algorithm comprises two different parts, a clustering algorithm (to identify any possible pattern) and a classification algorithm (supervised learning with tags to make the proper identification).
(41) 4—Once the algorithm is trained, a test set of captures can be processed. The temporal series of each flow will enter the ML algorithm and a percentage of accuracy is obtained.
(42) 5—When the ML algorithm is already trained and tested the temporal series of each flow can be classified as: Low quality, Medium quality, and High quality. It should be understood that other classifications (more granular classifications) are possible.
(43) 6—For an online classification, the temporal series will be made with a X packet's sliding window. For each income of payload sliding window temporal series is processed, a percentage will be raised indicating the percentage of accuracy in the classification. The ML-algorithm will give an answer when a percentage of accuracy is exceeded, 90% for example.
(44) 7—As the temporal series varies for each device, O.S. and platform (Browser or app), the algorithm can also identify where the traffic comes from.
(45) 8—During the online classification, as the algorithm uses a sliding window, it can identify changes of quality during the download of the video.
Open a Multipath Leg Based on QoE (i.e. a Resolution Parameter) Value
(46) In the following example, the Hag 100, the policy server 200 and the HCPE 10 are involved.
(47) Both HAG 100 and HCPE 10 can have Multipath and DPI capabilities. From a deployment perspective, these functionalities can be included in the HAG 100 or HCPE 10 nodes or deployed in a standalone fashion. Multipath: able to send traffic towards different networks. Also, able to join traffic from several paths into one single path. Able to open and close those multipath connections. DPI (Deep Packet Inspection): a technology which comprises inspecting/analyzing the contents of the IP data packets beyond the—so called—IP 5 tuples. The so-called IP 5 tuples comprises the heading elements of an IP data packet comprising: IP source address, IP destination address, source transport address, destination transport address, and protocol over IP (e.g. TCP, UDP). Therefore, put in short terms, DPI technology comprises inspecting and analyzing the application layer information conveyed by IP data packets. Because of the DPI analysis, service classification information can be obtained, which consists on IP packets being classified—i.e. after DPI processing—according to a configured tree of rules so that they are assigned to a service session. DPI is going to work with some Machine Learning algorithms.
(48) Both HCPE 10 and HAG 100 have connectivity to a policy server as shown in
(49) It will be discussed below how HAG 100 can report QoE measures towards policy server 200, based on a resolution parameter value obtained locally in the HAG 100. Then, the decision of opening a new path can be taken locally in the HAG 100 or externally in the policy server 200. In the policy server 200, other parameters from other nodes like Customer Premises Equipment (CPE) or Subscriber Profile Repository (SPR) can be considered.
(50) According to
(51) In this example below it is assumed that the end user and internet servers are not able to send traffic natively in multipath. Thus the situation as shown in
(52) The way how currently HAG and HCPE are establishing the legs is known in the art. The HCPE 10 and HAG 100 are working as TCP Multipath proxy. Users who connect to HCPE open a TCP connection. Then HCPE and HAG have multipath connection between them. HAG talks multipath towards HCPE and TCP towards the internet server.
(53) Depending how the resolution is calculated in the solution, there are two scenarios: First one when the resolution value is based on measures done locally in HAG 100 or HCPE 10. Second one, when there is an entity that is analyzing some metrics from different areas of the network. Then, analyzing those values can lead to the resolution of the end user communication. This value is sent towards the policy server which is responsible of determining which action should be done.
(54) Both scenarios open a new path, if it is available, when the resolution of a user session for a specific service is degraded.
(55) Regarding how traffic is distributed between paths several policies can be employed. The policy server 200 determines the first path that should be employed.
(56) In connection with
(57) After this step, traffic is sent using both LTE and DSL paths.
(58) In the next example of
(59) In
(60) After this step, traffic is sent using both LTE and DSL paths.
Close a Multipath Leg Based on the Resolution Parameter Value
(61) In another example discussed in connection with
(62) There is a mechanism to indicate when one path is closed. Depending if the resolution parameter is obtained locally in the HAG 100 or in the analytics unit, there are the same two scenarios as explained above for the opening of a new path: First one when the resolution parameter value is based on measures done locally in HAG 100 or HCPE 10. Second one, when there is an entity that is analyzing some metrics from different areas of the network. Then, analyzing those values can obtain a resolution parameter of the end user communication. This value is sent towards the policy server which is responsible of determining which action should be done.
(63) Both scenarios close the path, when there is more than one path employed, when the resolution parameter of a user session for a specific service is improved. The policy for selecting which path should be closed is defined according to criteria such as which path has more congestion, which is the most expensive path, etc.
(64)
(65) After this step, traffic is sent using DSL path.
(66) In connection with
(67) Analytics unit is an external entity that receives information from different nodes regarding the communication of an end user with a flow. It can provide the QoE of end user communication. It could be included as part of the PCRF or as an external entity. In this example, it has been included as part of the policy server 200.
(68) In
(69) For opening and closing path, to avoid ping-pong effects, it is possible to have a hysteresis decision to prevent tiny fluctuations from causing unwanted flickering in the decision result. In particular, for opening a path you have a trigger that is segment size=X but for closing the path you select a trigger that is a segment size=X− value. With this one avoids opening and closing paths when values are near to X. Consequently, if the input value is significantly above or below the decision threshold, the opening/closing the path will change state, but when the input is near the threshold, it just keeps on doing whatever it had previously decided, such that unwanted rapid switching is prevented.
(70) It is furthermore possible, not to use closing mechanism if there are enough available resources in the paths.
(71) In case of a conflict between what the policy server 200 says and what is measured locally in the node, the following policies may be used: Apply what policy server 200 defines. Useful when policy server 200 is aware of network status and usage of the network. Normally, when an SDN Controller is aware of the multipath or analytics module is measuring the QoS of the network. Apply what local node defines. Useful when there is no analytics in the policy server 200 and it has no idea of the network status. Mix of both. Some services are going to apply local policies and for others what policy server 200 defines. It will depend on which services analytics module is being enabled or if SDN controller is checking what is happening in the network.
(72) By way of example, policy server requests sending traffic to a new path but new path according to local measures is congested.
(73) In connection with
(74) After step S98, HAG 100 is aware of the video quality requested by policy server.
(75) During step S99 and S101, HAG 100, by means of DPI, tracks each of the video segments and calculate the segments size and the segments dispersion.
(76) Based on the estimation of video quality and the target video quality induced by Policy Server 200, HAG 100 will be able to report any significant deviation to Policy Server and, Policy Server will take the proper action to mitigate that deviation: If the resolution parameter is degraded, LTE leg shall be open If the resolution parameter is improved. LTE leg shall be closed
(77) For the case, for example, video quality requested by policy server is high quality (720p or higher) and HAG is calculating a segment size dispersion almost negligible, meaning that video is being reproduced with low quality (144p or 240p), according to what it is indicated on step S101, HAG 100 will notify the policy server 200 that the video is not being reproduced with the requested quality.
(78) The following Use Cases are possible with the proposed solution discussed above:
(79) Use Case 1: User Subscription to Video with Maximum Quality (e.g. 480p)
(80) This Use Case allows the network operator to optimize the network resources by enforcing a maximum video quality for certain subscribers (e.g. non-premium subscribers).
(81) By using the mechanisms described above, the network will be able to detect the resolution used in a subscriber's video session and in case the detected video resolution (e.g. 720p) is above the subscribed value (e.g. 480p), the network will be able to apply a certain enforcement action (e.g. throttling or bandwidth limitation) to ensure the subscriber terminal does not use a video resolution with higher quality than the subscribed one.
(82) Use Case 2: User Subscription to Video with a Guaranteed Minimum Quality (e.g. 480p)
(83) This Use Case allows the network operator to optimize the network resources by enforcing a minimum video quality for certain subscribers (e.g. premium subscribers).
(84) By using the mechanisms described above, the network will be able to detect the resolution used in a subscriber's video session and in case the detected video resolution (e.g. 240p) is below the subscribed value (e.g. 480p), the network will be able to apply a certain enforcement action to ensure the subscriber terminal uses a video resolution with higher quality than the subscribed one. The possible enforcement actions are: Improve QoS for the default bearer or trigger a dedicated bearer to carry the video traffic. In both cases with better QCI, so UE selects higher resolution in next video segments.
(85) Use Case 3: Video Quality Control Under Congestion or CPU Limit
(86) This Use Case allows the network operator to optimize the network resources by enforcing a maximum video quality for certain subscribers (e.g. non-premium subscribers) when there is congestion or network nodes reach CPU limits.
(87) By using the mechanisms described above, the network will be able to detect the resolution used in a subscriber's video session and, in case there is network congestion or some network node/s reach their CPU limit (e.g. 85%), the non-premium subscribers will get their video traffic throttled or bandwidth limited in case the detected video resolution (e.g. 720p) is above a configured value (e.g. 480p). When the congestion situation (or CPU usage) is relieved, the throttling action will finish.
(88) For Use Case 1 and Use Case 2, one of the possibilities is reporting % of time the video resolution was below the threshold and the number of resolution changes (both as objective measurements of video QoE).
(89) In
(90)
(91) In connection with
(92) From the above said some general conclusions can be drawn:
(93) For the multipath control entity, either the hybrid access Gateway 100 or the police server 200, the step of estimating the resolution can comprise the step of determining a size of the video segments used in the video stream and can comprise the step of determining a change of the size of the video segments over time. The resolution used in the stream is estimated taking into account the determined size and the determined change of the size. One example for the determination of the size and the change of the size comprises the step of determining an average size of a defined number of last video segments, e.g. the videos present in a moving window. Furthermore a mean value of the average size of the defined number of last video segments can be determined and when a deviation of the mean value is larger than a threshold value, the adaptation of the at least one path in the multipath environment is initiated.
(94) When an adaptation of the at least one path is initiated, this can mean that a new path is opened or an existing path is closed based on the determined change of the resolution.
(95) When the resolution is estimated, it is possible to estimate the resolution of the video frames present in the video stream and this resolution is then translated into a possible set of resolution parameter values. In the example above the resolution parameter was either high, medium or low. The multipath environment is an adapted based on the change of the value of the resolution parameter.
(96) When the adaptation of the at least one path is initiated, this can mean that a policy controller or policy server is informed which is configured to control the transmission policy of the video streams in the multipath environment. This policy server is then informed about the estimated resolution or the determined change of the resolution and the at least one path in the multipath environment is adapted based on the feedback received from the policy server.
(97) When it is determined that the resolution used in the video stream during the transmission has decreased over time, an opening of an additional path in the multipath environment may be initiated. Furthermore it is possible that when it is determined that that the resolution used individual stream during the transmission has decreased, a closing of an existing path in the multipath environment is initiated.
(98) The video segment upon which the estimation of the resolution is based can comprise the payload data transmitted over the at least one path in a first transmission direction between two consecutive requests transmitted in the opposite direction requesting to receive the video stream.
(99) When it is determined that the resolution used in the video stream during transmission remains substantially the same, it can be determined that the resolution is in a lower resolution range of a known possible resolution range. However when it is determined that the resolution of the video segments changes by more than a defined threshold, it is determined that the resolution is in a higher resolution range of the known possible resolution range.
(100) It is possible to identify the encrypted media stream as being a video stream based on a name indication present in a message exchanged between the video server, here the media streaming entity and the media receiving entity, here the customer premises equipment wherein the name indication allows video server to be identified.
(101) The resolution may be estimated based on a machine learning algorithm which is embedded in a deep packet inspection module which comprises a first clustering part in which different possible resolutions of the media stream are determined based on test data and which comprises a second classification part in which the video streams are classified in one of the possible resolutions.
(102) The invention described above allows a network to detect the video resolution employed in a user's video session in case of encrypted traffic and allows a network to open or close multipath legs based on the estimated resolution.
(103) A new interface is provided between the HAG 100 and the Policy server 200 which allows the HAG to report its capabilities and the estimated resolution parameter. A new interface is provided between the HCPE 10 and the Policy server 200 which allows the HCPE to report its capabilities and the estimated QoE.
(104) The above described method (of the resolution video detection) allows the detection of the quality of the video according to the deviation against the mean of the average size of the video segments and it works even when the video traffic is encrypted. The quality/resolution of the video is detected analyzing the segment size of each video segment.
(105) The method (opening or closing a multipath leg based on resolution parameter), allows better usage of the Radio Bearer. In multipath scenarios, Radio Bearers are not assigned if the QoE of a video session is good from end user point of view. Streaming Radio Access Bearer are assigned only when the QoE of the user is bad (lower than expected quality defined by operators) or when a user has suffered more than one change in the quality of the video. LTE path is opened only when the quality of the video is not fulfilling the end user requirements.