Calculating Service Performance Indicators

Abstract
There is provided a method of calculating a performance indicator indicating a performance of a service at one of a plurality of mobile terminals connected to said network, the method comprising the steps of receiving a set of infrastructure performance indicators, each infrastructure performance indicator being determined for a part of the network conveying data to one or more of said mobile terminals connected to the network; receiving a set of local performance indicators, each local performance indicator being determined locally at one mobile terminal of a subset of the plurality of mobile terminals connected to the network; determining a correlation between the set of infrastructure performance indicators and the set of local performance indicators; and calculating said performance indicator indicating the performance of the service at one or more mobile terminals using said correlation and one or more of infrastructure performance indicators of said set of infrastructure performance indicators.
Description
TECHNICAL FIELD

The present invention relates to a method of calculating a performance indicator indicating a performance of a service at one of a plurality of mobile terminals connected to said network. The present invention likewise relates to a system calculating such a performance indicator, and to a mobile terminal configured to determine a local performance indicator. More specifically, the present invention relates to correlating service performance indicators in the context of determining information on a quality of experience (QoE) perceived by a user at a corresponding mobile terminal. The present invention also relates to corresponding computer programs and computer program products.


BACKGROUND

Determining the performance of a network and related entities, such as a telecommunication network, internet links and providers, or, in general, of a service provided via a network may be important for providing a given target quality with the network, as problems and issues within the network and elsewhere can be recognized and addressed quickly. For instance, a service performance indicator indicating a so-called quality of experience (QoE) may convey useful information to network operators on whether the performance of the service is satisfactory.


In this context, particular attention is usually paid to the performance of a service at the site of a given mobile terminal, since it is oftentimes the point of “consumption” of the service (e.g. browsing the web, watching a video, listening to a stream, etc.). There are several performance indicators known capable of indicating the performance of the service at one of a plurality of mobile terminals. One example of such a performance indicator is known as quality of experience, QoE, quality of experience metric, or quality of experience value, which is generally a measure of a user's experience about a service. Naturally, this experience depends on the performance of the service as such, so that if the service performance for example is insufficient, the user experiences delays and dropouts.


The experience is generally a subjective measure and could vary from user to user. QoE, however, includes several objective measures for a specific service, i.e. listenability of voice, usability, video impairment and the like. A specific example of a QoE metric is a Mean Opinion Score, MOS, which provides a numerical indication of the perceived quality of service from the viewpoint of the user. Such an MOS may be representing voice quality of a received voice after encoding and transmission of a voice within a voice telephone service. Therefore, there is always an objective way to automatically determine and assess such experience values. Hence, a performance indicator (such as a QoE metric) can be obtained for a given network by means of specific user equipment (mobile terminal) employing a specific software configuration.


In this context it should be noted that feedback directly from the user is by definition subjective and may vary greatly from user to user. Moreover, such user feedback is not always possible since it depends on a user's will to collaborate and, with this, such data sources become unreliable. Therefore, other methods have been considered to obtain a performance indicator such as a QoE metric for a given service on an automated, machine-implemented and thus reliable basis.


A conventional approach is based on measuring the quality from paired comparison situations. This provides a quality estimate based on the comparison for instance of a source voice signal with the voice signal received over the network. A difference is determined from the two signals which may then be time averaged and mapped onto a quality estimate such as an MOS. As a result, conventional performance monitoring includes the employment of a QoE metric for Over The Top, OTT, network services such as video services, web services, and the like. Such monitoring is carried out by most network operators today, in order to determine the compliance of the actually provided network quality to, say, a promised or target quality. In the past, related monitoring solutions were based on network probes performing protocol parsing of data traffic (e.g. deep packet inspection, DPI). The maintenance of these parsers was difficult and expensive, since OTTs could change protocols and content delivery mechanisms at any time without any prior notice. Further, metrics were inaccurate since it is usually not possible to reconstruct all terminal states from network traffic. Furthermore, with more and more services using encryption, this method is mostly unusable for OTTs.


At the same time, however, service performance indicators could also be measured in an accurate way locally at the site of a mobile terminal. However, the known methods are dependent on specific services and vary according to the services. The very large number of applications and service providers makes a generic performance indicator measurement very difficult at the mobile terminal. Also, such solutions very much depend on the broad users' will to let corresponding probe or monitoring software to be installed on their terminals.


Despite the availability of many different solutions for measuring service performance, network quality, or quality of experience at the mobile terminal, there remains the need for improved measurement techniques and concepts for determining service performance indicators, whilst being both as accurate as possible and as independent from a user's will as possible.


In other words, an object may be to provide a service performance monitoring solution that 1) can be applied to all subscribers in a network 2) is a generic solution applicable for most OTT service providers even if their traffic is encrypted 3) provides reliable estimates of service performance indicators.


SUMMARY

The above mentioned problems and drawbacks of the conventional methods are solved by the subject matter of the independent claims. Further preferred embodiments are described in the dependent claims.


According to an aspect of the present invention there is provided a method of calculating a performance indicator indicating a performance of a service at one of a plurality of mobile terminals connected to said network, the method comprising the steps of receiving in a network entity a set of infrastructure performance indicators, each infrastructure performance indicator being determined for a part of the network conveying data to one or more of said mobile terminals connected to the network; receiving in the network entity a set of local performance indicators, each local performance indicator being determined locally at one mobile terminal of a subset of the plurality of mobile terminals connected to the network; determining a correlation between the set of infrastructure performance indicators and the set of local performance indicators; and calculating said performance indicator indicating the performance of the service at one or more mobile terminals using said correlation and one or more of infrastructure performance indicators of said set of infrastructure performance indicators.


According to another aspect of the present invention, there is provided a mobile terminal provided with a local performance indicator determination unit for determining a local performance indicator for a mobile terminal connected to a network, comprising an acquisition unit configured to acquiring screenshot data displayed on one mobile terminal of said subset of mobile terminals; a processing unit configured to processing said acquired screenshot data for determining the presence of a screen display element indicating the performance of the service at said one mobile terminal; and an analyzing unit configured to determining at least one local performance indicator of the set of local performance indicators using said screen display element.


According to another aspect of the present invention there is provided a network entity for calculating a performance indicator indicating a performance of a service at one of a plurality of mobile terminals connected to said network, the network entity comprising a first receiving module configured to receiving a set of infrastructure performance indicators, each infrastructure performance indicator being determined for a part of the network conveying data to one or more of said mobile terminals connected to the network, a second receiving module configured to receiving a set of local performance indicators, each local performance indicator being determined locally at one mobile terminal of a subset of the plurality of mobile terminals connected to the network, a correlation module configured to determining a correlation between the set of infrastructure performance indicators and the set of local performance indicators, and a calculation module configured to calculating said performance indicator indicating the performance of the service at one or more mobile terminals using said correlation and one or more of infrastructure performance indicators of said set of infrastructure performance indicators.


According to another aspect of the present invention a computer program is provided that comprises code, the code, when executed on processing resources, instructs the processing resources to perform a method embodiment of the present invention.


According to yet another aspect of the present invention a computer program product is provided that stores a code, the code, when executed on processing resources, instructs the processing resources to perform a method embodiment of the present invention.





BRIEF DESCRIPTION OF THE DRAWINGS

Embodiments of the present invention, which are presented for better understanding the inventive concepts but which are not to be seen as limiting the invention, will now be described with reference to the figures in which:



FIG. 1 shows a schematic overview of an exemplary network environment in which a performance indicator is calculated according to an embodiment of the invention;



FIG. 2 shows a general entity embodiment of the invention for calculating a service performance indicator;



FIG. 3 shows a flowchart of a general method embodiment of the present invention;



FIG. 4 shows a schematic overview of a system for calculating a performance indicator according to a further embodiment of the invention;



FIG. 5 shows a schematic overview of determining one of a set of local performance indicators according to another embodiment of the present invention;



FIG. 6A shows an exemplary embodiment of a mobile terminal provided with a local performance indicator determination unit according to another embodiment of the present invention, and



FIG. 6B shows exemplary display elements displayed on a mobile terminal according to yet another embodiment of the present invention.





DETAILED DESCRIPTION


FIG. 1 shows a schematic overview of an exemplary network environment in which a performance indicator is calculated according to an embodiment of the invention. A network 100, for instance a mobile communication network, includes a number of network elements 101-106 such as network nodes, routers, gateways, switches, switching centers, base stations, wire-less or wire-bound links, and the like. In general, the purpose of the network 100 will be to provide a network service to a plurality of mobile terminals 10, 11, where the usual services include, telephony, video-telephony, chatting, internet browsing, email access, and the like. For this purpose the network elements 101-103 will convey data via base stations 105, 106, to and from the plurality of mobile terminals 10, 11. The base stations 105, 106 may be connected to the individual mobile terminals 10a, 10b via the usual radio links for transmitting and receiving data to and from a mobile terminal 10a, 10b. The network 100 may further have a connection to some sort of network entity 110, such as a server or a resource in a data center.


In order to allow calculating a performance indicator indicating a performance of the service, such as video services, web services, and the like at one of a plurality of mobile terminals 10a, 10b connected to the network 100, the present embodiment provides a network environment that is configured such that a set of infrastructure performance indicators IPI and a set of local performance indicators LPI may be determined, as explained in greater detail below.


Generally, in one embodiment of the present invention, the plurality of mobile terminals 10a, 10b, . . . , 11a, . . . may be connected to different network elements and base stations in the usual manner. At some point or points in the network the so-called infrastructure performance indicators IPI are determined (e.g. a shallow packet inspection at node 101, so that for instance one of the set of infrastructure performance indicators is obtained as a low-level transport layer metric by such shallow packet inspection or by any other suitable other packet inspection technique). If, for example, a group of mobile terminals receives data via one of such network elements, the correlation between the corresponding infrastructure performance indicators and an actually perceived local performance indicator at the mobile terminals may be strong.


In one embodiment of the present invention the set of infrastructure performance indicators may comprise one or more of a data traffic metric such as transport layer metric and lower layer metrics, e.g. a Transmission Control Protocol, TCP, metric, a Quick User Datagram Protocol, UDP, Internet Connection, QUIC metric. One of the set of infrastructure performance indicators may be determined at a network element such as a node, base station, switching center, gateway, router, and so on. Further infrastructure performance indicators may be determined likewise at the same network element 101 or at other network elements 102, . . . .


In the present embodiment of the invention, the network environment is configured to determine and receive a so-called set of local performance indicators LPI, wherein, for example, individual local performance indicators LPI may be determined locally on selected mobile terminal 11a, and 11b. In a way, these mobile terminals represent a subset 11 of the plurality of mobile terminals being served by the network. In one embodiment, this subset 11 of the mobile terminals 11; 11a, 11b may be provided with a local performance indicator determination unit such as an application (“app”) configured to determine locally at the respective mobile terminal a local performance indicator LPI for building up a corresponding set of local performance indicators. The application may be implemented as an application or operating system module distributed by a network operator, a device manufacturer, or another party.


For example in one embodiment of the present invention the subset 11 of mobile terminals that are provided with the capability of determining a local performance indicator LPI may be relatively small compared to the total number of the plurality 10 of mobile terminals. In other words, only a few percent or p.p.t. of the plurality 10 of mobile terminals may be provided with the capabilities to determine one or more of local performance indicators LPI. Naturally, however, it is to be noted that the more mobile terminals are provided with the capability of determining a local performance indicator LPI, the better a correlation between the set of local performance indicators and the set of infrastructure performance indicators may be, and with this, the better and more accurate the performance indicator of network will be. It should be clear however, that the present disclosure does not propose to provide all or the majority of mobile terminals with such local probes, since this would imply cooperation by users and mobile terminal owners on a broad basis. It is, however, exactly one object of the present embodiments to minimize the dependence on the local performance indicators.


Therefore, the present embodiments propose that the subset 11 of mobile terminals comprises a number of mobile terminals 11; 11a, 11b that is sufficient for establishing or determining a correlation between a given set of infrastructure performance indicators IPI and a set of local performance indicators LPI. One of the set of local performance indicators LPI may for instance be a metric indicating a quality of experience, QoE, for the user at a given mobile terminal 11; 11a, 11b.


In one embodiment of the present invention, the calculated performance indicator is calculated for a mobile terminal 10; 10a, 10b, 10c for which a local performance indicator—being actually determined locally at the mobile terminal—is not available. That is, a user perceived performance indicator indicating a performance of the service at another one of the subset of mobile terminals is calculated.


In this way, an embodiment of the present invention allows for obtaining a service performance indicator (e.g. QoE metric) for a particular mobile terminal which is not equipped with any dedicated probe, measurement or indicator determining functions. As a consequence, an embodiment of the present invention allows for obtaining a service performance indicator for an arbitrary mobile terminal whilst only a subset of mobile terminals is provided with a probe functionality (determination unit). Basically, there may thus be no difference for analysis and assessment in performance indicators, regardless whether an indicator was actually measured at a mobile terminal or whether it was calculated in line with an embodiment of the present invention.


The actual processing of the received and obtained indicators may be effected at a specific location, for example at a dedicated server or at corresponding processing resources of a data center. In general, these processing and memory resources are referred to as a so-called network entity in the context of the present disclosure. In the network environment, the service performance indicator may thus be calculated by the network entity 110 which may have a direct connection to the network 100 and which is explained in greater detail in the following.



FIG. 2 shows a schematic view of such a network entity 110. Specifically, the entity is configured to perform the calculation of a performance indicator according to one or more embodiments of the present invention. The entity 110 generally comprises processing means 130, memory means 120, and communication means 140. As already mentioned, the entity may be connected to the network 100 over the communication means 140 and may be implemented as, for instance, a server, a computer, or processing resources provided by a data center or any suitable network element. Likewise, the entity 110 may be outside or inside the network 100, wherein in the latter case any network node or element may be provided with the corresponding functionalities.


Generally, the mentioned processing means 130 may be a processing unit, a processing unit collection, CPU, a share of a data/processing center and so on. The processing means 130 are capable of performing a determination of a correlation between a set of infrastructure performance indicators and a set of local performance indicators, and of calculating the performance indicator indicating the performance of the service at one or more mobile terminals using this correlation and one or more of infrastructure performance indicators. Here, it should be noted that in general the embodiments envisage that the correlation is determined before the service performance indicator is calculated, which, in turn implies, that the infrastructure performance indicators used for determining the correlation may be different from the infrastructure performance indicators used for calculating the service performance indicator. Likewise, the infrastructure performance indicators used for determining the correlation may thus be determined and received earlier in time as compared to the infrastructure performance indicators used for calculating the service performance indicator.


The memory means 120 may specifically store code instructing the processing means 130 during operation to implement any method embodiment of the present invention. Particularly, the memory means 120 may store code instructing the processing means 130 during operation to receive a set of infrastructure performance indicators, each infrastructure performance indicator being determined for a part of the network conveying data to one or more of said mobile terminals connected to the network; to receive a set of local performance indicators, each local performance indicator being determined locally at one mobile terminal of a subset of the plurality of mobile terminals connected to the network; to determine a correlation between the set of infrastructure performance indicators and the set of local performance indicators; and to calculate said performance indicator indicating the performance of the service at one or more mobile terminals using said correlation and one or more of infrastructure performance indicators of said set of infrastructure performance indicators.


For instance in one embodiment of the present invention the communication means 140 may connect to the network 100. Through the communication means 140 the entity 110 may receive the set of infrastructure performance indicators IPI and the set of local performance indicators LPI. However, there may be more than one communication means to separately receive the set of infrastructure performance indicators and the set of local performance indicators, and for instance there may be several and/or individual ports provided for receiving the set of infrastructure performance indicators and the set of local performance indicators at the communication means.


Further, in one embodiment of the present invention the communication means 140 may be connected to several entities apart from the network 100 in order to receive the set of infrastructure performance indicators and/or the set of local performance indicators. For instance there may be a data collection center storing the set of infrastructure performance indicators and there may be a separate second data center for storing the set of local performance indicators which may be connected to entity 110 through the communication means 140. In general, the entity 110 may thus be provided with means to perform the method according to the embodiments of the present invention.



FIG. 3 shows a flowchart of a method of calculating a performance indicator according to a general method embodiment of the present invention. This embodiment involves in a step S110 a receiving of a set of infrastructure performance indicators, wherein each infrastructure performance indicator may be determined for a part of the network conveying data to one or more of the mobile terminals connected to the network. The part of the network conveying data to at least one of the mobile terminals may for instance be a single network element, several network elements, e.g. network elements covering a certain area, or all network elements, i.e. the entire network 100. This way certain areas of the network may be probed in order to determine a performance indicator specific for that area of the network 100.


In a step S120 (before, after or at the same as step S110) a set of local performance indicators is received, wherein each local performance indicator may be determined locally at one mobile terminal of a subset of the plurality of mobile terminals connected to the network. In one embodiment of the invention the subset of the plurality of mobile terminals includes mobile terminals each provided with means to determine a set of local performance indicators, such as a local performance indicator determination unit. The local performance indicator determination unit may be a software program, e.g. an application, running on the mobile terminal. In one embodiment of the invention the set of local performance indicators includes at least a local performance indicator represented by a quality of experience, QoE, value or metric.


In another embodiment of the present invention determining at least one local performance indicator of the set of local performance indicators may be determined by an application displayed on the mobile terminal, when the screenshot data may be acquired. This may specifically involve the optional steps S121 to S123 replacing and/or complementing step S120, as described in greater detail below. The local performance indicator may thus be determined locally at the mobile terminal. In one embodiment of the present invention the set of infrastructure performance indicators may be determined for a specific user session.


The method may further comprise the step of determining S130 a correlation between the set of infrastructure performance indicators and a set of local performance indicators. It may be assumed that there may be generally a good correlation between at least one of the set of infrastructure performance indicators and at least one of the set of local performance indicators. However, in case the correlation may not be strong enough to derive an exact metric for the performance indicator such as an exact QoE metric, e.g. a webpage download time or video initial buffering, it may be assumed the correlation may be suitable to determine a good or bad local performance indicator, i.e. distinguish between a good and bad QoE value, based on the infrastructure performance indicator with high reliability. The correlation between the set of infrastructure performance indicators and the set of local performance indicators may be stored on respective storage means for subsequent processing.


The method may further comprise a step of calculating S140 the performance indicator indicating the performance of the service at one or more mobile terminals. The correlation together with one or more of the set of infrastructure performance indicators may be used in the step of calculating S140. The correlation may be requested by appropriate processing means from storage means for storing the correlation.


In one embodiment of the invention the method may further comprise optional steps for determining one of the set of local performance indicators. The method then may comprise a step S121 of acquiring screenshot data displayed on one mobile terminal of said the subset 11 of mobile terminals. That is, the mobile terminal may display screenshot data representing the actual usage of the user. Such usage may be for instance loading of a video, requesting a website or the like. The screenshot data may be acquired by taking a screenshot or snapshot, i.e. an image of the content displayed on a screen, i.e. display, of the mobile terminal, of the screenshot data displayed on the mobile terminal. The screenshot data may be temporarily stored on appropriate storing means for further processing.


The method may further comprise a step of processing S122 the acquired screenshot data for determining the presence of a screen display element indicating the performance of the service at said mobile terminal. For processing the screenshot data, the screenshot data may be requested by appropriate processing means, as detailed below. In the step of processing S122 the acquired screenshot data the presence of a screen display element may be determined. Such a screen display element may be determined by an application such as a video streaming application or web browser running in a foreground of the screen of the mobile terminal such that a screenshot would contain screenshot data related to the application. The screen display element may be tracked over time in order to adequately indicate the performance of the service. That is, the screen display element may change rapidly over time indicating for instance a high data traffic speed of the network.


The method may further comprise a step of determining S123 at least one local performance indicator of the set of local performance indicators using the screen display element. That is, the screen display element such as a spinner, process bar or the like may be used to determine one local performance indicator such as a quality of experience value or metric.


In order to determine a correlation between the set of infrastructure performance indicators and the set of local performance indicators there may be different models used measuring the quality from paired comparison situations. Such a model typically may use algorithms to establish the correlation. Such a model may be generated for each one of the set of infrastructure performance indicators and each one of the set of local performance indicators for instance by stepping through and observing changes in a data array corresponding to one of the infrastructure performance indicators being modeled. In such a data array changes in time of one of the set of infrastructure performance indicators may be monitored together with changes in one of the set of local performance indicators. The data array may be stored on respective storage means.


In a another embodiment of the present invention a correlation map or correlation data or a correlation data array may be generated from the correlation between the set of infrastructure performance indicators and the set of local performance indicators, and the correlation map may be input in a learning machine in order to update and/or maintain and/or verify the correlation map continuously or in predetermined time intervals or upon request.


In yet another embodiment of the present invention accuracy of the correlation map may be verified by calculating at least one local performance indicator for at least one infrastructure performance indicator from the subset of the plurality of mobile terminals and comparing the calculated local performance indicator with the received local performance indicator of the subset of the plurality of mobile terminals.


Local performance indicator can be a delay metric, indicating delay suffered on the mobile terminal when accessing a given service.



FIG. 4 shows a schematic overview of a system for calculating a performance indicator according to a further embodiment of the invention. Specifically, it is shown the updating and/or maintaining and/or verifying the correlation between a set of infrastructure performance indicators and a set of local performance indicators according to one embodiment of the present invention. In the present embodiment the mobile terminal of a subset 11, i.e. a mobile terminal or mobile device, may be provided with a local performance indicator determination unit, i.e. a terminal agent app or terminal agent application. The terminal agent app may be providing the set of local performance indicators, i.e. QoE metrics, to a correlator, i.e. correlation unit, for correlating the QoE metrics with at least one of the set of infrastructure performance indicators such as transport layer and lower layer metrics. The transport layer and lower layer metrics are provided by a network probe. A dispatcher separates the transport layer and lower layer metrics received from the probe in at least two sets and forwards one set to the correlator and another set to the learning machine or a supervised learning machine.


In the present embodiment the correlator may separate the received correlated QoE metrics and transport layer and lower layer metrics for verification and training for instance as correlation data. The correlation data may be stored in respective verification data centers and training data centers.


The training data center may provide the correlated infrastructure performance indicators and the local performance indicators to the learning machine. The learning machine then calculates the performance indicator for the transport layer and lower layer metrics received from the dispatcher and the correlation received from the training data center. The performance indicator, i.e. QoE estimate, may be forwarded to the verification unit in order to verify that the learning machine calculated the QoE estimate correctly.


If there is any difference between the infrastructure performance indicator and transport layer and lower layer metric received from the verification data center and the local performance indicator received from the learning machine respective feedback may be given to the correlator in order to adjust the correlation between the set of infrastructure performance indicators and a set of local performance indicators.


In other words, transport layer data from the probe may be routed by the dispatcher depending on whether a user has the terminal agent app installed or not. For users having the terminal agent app installed, transport layer metrics from the probe are routed to the correlator unit and correlated with QoE metrics.


In other words, by combining QoE values from reporting terminal agent apps with transport layer metrics from a network probe models for transport layer metrics may be built and maintained and further QoE estimates mappings may be obtained. Advantages of this approach may be the following. The QoE values reporting terminal agent app may only be installed in a few percent of the entire mobile terminals 10a, 10b. This way large amounts of up to date and accurate training data may be made continuously available, which may be an important pre-requisite for the learning machine, especially when data patterns might change from one day to the other without any notice.


In one embodiment infrastructure performance indicator of the set of infrastructure performance indicators is a radio access network, RAN, metric indicating RAN-level performance for the data traffic.


In one embodiment correlation data, comprising the correlation between the set of infrastructure performance indicators and a set of local performance indicators may be used as training data only from a part of the subset, e.g. 50%, of users with QoE reporting agents installed to be able to continuously monitor the accuracy of QoE estimates. Data from remaining terminal agent apps of users, e.g. the other 50%, may be routed on two separate paths simultaneously that is correlation data being fed to the verification unit and probe data being fed to the supervised learning unit and derived QoE estimates being routed to the verification unit for comparison. The QoE estimates may then be forwarded to an operations support system or a business support system of the network for further analysis and actions such as identifying network problems or supplying user support.



FIG. 5 shows a schematic overview of determining one of a set of local performance indicators according to another embodiment of the present invention. In the present embodiment the mobile terminal (e.g. 11a of FIG. 1) is provided with an operating system application program interface API running one or more applications on the mobile terminal. Screenshot data displayed on the mobile terminal may be acquired, i.e. screen capturing may be performed. The acquired screenshot data may be forwarded to a plurality of image processing units for determining the presence of a screen display element. Information on the screen display element may be forwarded to a rule engine for determining one of the set of local performance indicators based on a QoE rule determining a QoE estimate for instance based on a given application in the foreground of the mobile terminal. In other words a “Screen to QoE” app such as the terminal agent app may be installed on mobile devices of users having opted in to provide QoE reports such as one of the determined set of the local performance indicators.


In yet another embodiment of the present invention processing the acquired screenshot data for determining the presence of a screen display element may be a pattern recognition method identifying a pattern in the display element and wherein at least one local performance indicator of the set of local performance indicators indicates a pattern change. Pattern change can be pixel differences between subsequent screenshots.


In one embodiment determining at least one local performance indicator of the set of local performance indicators may be determined by screen related information describing and operation of the screen, when the screenshot data may be acquired.


In other words, the “Screen to QoE” app may have two data collection modules using standard operating system APIs on the mobile device: first an acquisition unit configured to acquiring screenshot data displayed on one mobile terminal of said subset of mobile terminals, or in other words a screen capture module getting periodical snapshots of raw screen content, and second a screen related information acquisition unit, or in other words a screen context info collection module, getting screen related information such as screen context information, e.g. screen on/off events, orientation changes and apps being in the foreground at a given point in time.


In another embodiment of the present invention the screen related information may be at least one of a screen on/off event, screen orientation change or information on an app being in a foreground of the terminal at a given point in time.


In another embodiment of the present invention one or more of the set of infrastructure performance indicators are determined in parallel.


That is, raw screen content such as the screenshot data may be analyzed in parallel by different image processing modules focusing on generic user interface building blocks, e.g., progress or stall indicators. Outputs from image processing modules and the screen context info collection module may be fed to a rule engine module. Predefined QoE rules may specify for each application running on the mobile terminal how to map image processing module outputs to QoE reports when this app is in the foreground. The QoE report for instance including the determined performance indicator or QoE estimate may be sent for instance via the mobile network for instance to a network management system of a mobile network.


In another embodiment periodically obtained raw screen content may be analyzed in parallel by different image processing modules including but not limited to loading indicator search module looking for loading indicator pattern in raw screen content, hyperlink selection search to identify user interactions triggering loading of new content, blank screen detector, error message detector, screen change rate detector, video resolution detector.


Subsequently, outputs from the plurality of image processing modules and the screen context info collection module may be fed to a rule engine module. Predefined QoE rules may specify for each application how to map image processing module outputs to QoE reports when this app is in the foreground. The content of QoE reports depends on the functionality of foreground apps, e.g. for video applications video resolution estimates and play and stall periods and for web applications page load times


The screen context data may provide important control information to the image processing module and the rule engine module, for instance as detailed in the following: When screen is off, all image processing modules may be shut down to save CPU and battery resources. When the screen orientation changes, then image processing modules may need to know that this is a temporary transition period that might need to be skipped from image change analysis.


Also, the rule engine may need to know that some screen patterns are to be expected at different parts of the screen after the orientation change. Knowing which app is in the foreground may be important information for the rule engine module to build QoE metrics from the output of individual image processing modules, e.g., for video applications video freeze length estimates may be derived from the output of the screen change rate detector and the loading indicator module. In contrast, for a browser, page rendering time may be estimated combining output from e.g., the hyperlink selection search, the blank screen detector and the screen change rate detector modules.


QoE reports may be sent via the network 100 to a network management system of a mobile network and may be used for a number of different use cases including but not limited to traffic prioritization, customer care support, network optimization, network troubleshooting.


With respect to mobile resource usage, image processing modules may be completely turned off when the screen of the device is turned off. This means no resource usage at all when idle. Screen capture itself does not consume extra resources since it is implemented using shared memory. Some image processing algorithms might be more resource consuming, however, this may be reduced with pixel sampling.


With respect to privacy, raw screen content may potentially include sensitive information. However, the information may be processed only locally and may never leave the device. That is, only condensed QoE reports may be sent to the network management system containing user ID, timestamp and QoE metrics for foreground applications. In addition, the screen to QoE app may be installed and used in an opt-in way where the user actively decides to allow such processing of data.


In yet another embodiment of the present invention wherein the screenshot data may be sent to a network client carrying out at least processing the acquired screenshot data and determining the local performance indicator.


In another embodiment of the present invention acquiring screenshot data may be carried out continuously or in predetermined intervals.



FIG. 6A shows an exemplary embodiment of a mobile terminal 11′ provided with a local performance indicator determination unit according to one embodiment of the present invention. The local performance indicator determination unit may be provided in the mobile terminal 111′ that usually comprises the display 111, processing means, memory means, and communication means.


The display ill may display content comprising screenshot data. The content may be determined by an application running in the foreground of the display 111 of the terminal 10b. The processing means may be a processing unit, CPU, or the like. The processing means may thus implement an acquisition unit 111-1 for acquiring the screenshot data and further processing the screenshot data for determining the presence of a screen display element. The screenshot data may be stored on the memory means before processing means process the acquired screenshot data. Further the determined presence of a screen display element may be stored. The processing means may further implement a processing unit 111-2 for processing said acquired screenshot data for determining the presence of a screen display element indicating the performance of the service at said one mobile terminal. The processing means may further implement a determining unit 111-3 for determining at least one local performance indicator of the set of local performance indicators using the stored screen display.



FIG. 6B shows exemplary display elements displayed on a mobile terminal according to one embodiment of the present invention. The image shown in FIG. 6B may be the content displayed on the display 111 of the terminal 11′ shown in FIG. 6A. A variety of screen display elements are as usual displayed on the display 111 during use and operation of the mobile terminal 11′, whilst only some elements are suitable for indicating a local performance of the service at the mobile terminal. In general, display elements 20a-20f may be user interface building blocks generally used to display content on the display 111 of the mobile terminal 11′. These include but are not limited to a process bar 20a, i.e. progress bar, indicating progression of an operation, such as a download, file transfer, or installation, a spinning wheel 20b, i.e. wait cursor or throbber or any other graphical control element, indicating program performing an action in the background such as downloading content, conducting intensive calculations or communicating with an external device, and content related elements such as an image building up 20c, a user input request 20d, or displayed text or hyperlinks 20e, 20f.


As already mentioned, an accurate measure for the service performance or quality of experience may be not available from the analysis of network traffic due to a number of reasons such as encryption, client settings and behavior not known to the network, etc. It may be measured accurately only on the mobile device. However, the large number of apps and OTT service providers makes generic QoE measurement very challenging on the mobile device. The present embodiment, however, makes use of the fact that quality of experience for mobile services may be almost always visible for the user from the screen and mobile operating systems recently started exposing APIs to access this raw screen content. For example, the processing unit 111-2 may determine that a spinner 20b is present in the captured display content for some time and may thus determine a quite specific local performance indicator (i.e. long spinning, low performance). The analysis of a progress bar 20a may even provide more detailed information on the actual process. Further, the appearance of and/or change in text, graphic and video elements 20f, 20e, 20d, 20c may be used for determining a sufficiently good local performance indicator. It should be clear that the proposed embodiment is independent from parsing and encryption, since it employs the same data content that the user experiences, i.e. the visual and/or sound experience. As for the latter, there may also be a probe at the mobile terminal that senses the start and/or behavior of audio playback on the terminal which may, of course, not generally reflected by display elements on the display 111.


Instead of partnering with many of OTT service providers and integrating monitoring solutions to an even higher number of apps, a small number of image processing primitives are defined on raw screen content from which QoE estimates can be created with good accuracy. These image processing primitives may be app-independent building blocks. To calculate QoE Key Performance Indicators, KPIs, for a given app, the only app specific part to be defined may be a set of rules describing how to map image processing primitive outputs to QoE metrics for the given app.


The present invention may deliver performance indicators also for mobile terminals not having a performance indicator determination unit installed. The present invention may also be capable of dynamically adapting to eventual changes in content delivery mechanisms and protocols. The present invention may further be capable of evaluating performance indicators automatically in the background and does not require any user interaction. As a result, performance indicators are not biased by the subjectivity of users. The present invention may further yet be capable of providing a generic solution to performance indicator monitoring on a mobile terminal such as a mobile device independent of the operating system running on the mobile device where screenshot data such as raw screen content may be exposed via an API to applications. The present invention may be applied to any user activity on mobile devices regardless of which applications, OTTs and protocols are involved. The present invention may further yet be capable of easy maintenance compared to an application or OTT specific method as the present invention focuses on screen display element such as generic user interface building blocks common across different applications. In order to support a new application or a new version of an application, only the correlation needs to be added or updated.


According to another embodiment of the present invention, there is provided a determination unit or a method for determining a local performance indicator, comprising the acquiring of screenshot data displayed on one mobile terminal of a mobile terminal; the processing of said acquired screenshot data for determining the presence of a screen display element indicating the performance of a service at said one mobile terminal; and the determining of at least one local performance indicator of the set of local performance indicators using said screen display element.


According to another embodiment of the present invention, there is provided a local performance indicator determination unit for determining a local performance indicator for a mobile terminal connected to a network, comprising an acquisition unit configured to acquiring screenshot data displayed on one mobile terminal of said subset of mobile terminals; a processing unit configured to processing said acquired screenshot data for determining the presence of a screen display element indicating the performance of a service at said one mobile terminal; and an analyzing unit configured to determining at least one local performance indicator of the set of local performance indicators using said screen display element.


According to another embodiment of the present invention, there is provided a mobile terminal provided with a local performance indicator determination unit for determining a local performance indicator for a mobile terminal connected to a network, comprising an acquisition unit configured to acquiring screenshot data displayed on one mobile terminal of said subset of mobile terminals; a processing unit configured to processing said acquired screenshot data for determining the presence of a screen display element indicating the performance of the service at said one mobile terminal; and an analyzing unit configured to determining at least one local performance indicator of the set of local performance indicators using said screen display element.


Although detailed embodiments have been described, these only serve to provide a better understanding of the invention defined by the independent claims and are not to be seen as limiting.

Claims
  • 1-21. (canceled)
  • 22. A method of calculating a performance indicator indicating a performance of a service at one of a plurality of mobile terminals connected to a network, the method comprising: receiving, in a network entity, a set of infrastructure performance indicators, each infrastructure performance indicator being determined for a part of the network conveying data to one or more of the mobile terminals connected to the network;receiving, in the network entity, a set of local performance indicators, each local performance indicator being determined locally at one mobile terminal of a subset of the plurality of mobile terminals connected to the network;determining a correlation between the set of infrastructure performance indicators and the set of local performance indicators; andcalculating the performance indicator indicating the performance of the service at one or more mobile terminals using the correlation and one or more infrastructure performance indicators of the set of infrastructure performance indicators.
  • 23. The method of claim 22, further comprising determining at least one of the local performance indicators, the determining at least one of the local performance indicators comprising: acquiring screenshot data displayed on one mobile terminal of the subset of mobile terminals;processing the acquired screenshot data for determining the presence of a screen display element indicating the performance of the service at the one mobile terminal;determining at least one local performance indicator of the set of local performance indicators using the screen display element.
  • 24. The method of claim 23, wherein the calculated performance indicator is calculated for a mobile terminal for which a local performance indicator determined locally at the mobile terminal is not available.
  • 25. The method of claim 22, wherein the set of infrastructure performance indicators is determined for a specific user session.
  • 26. The method of claim 22, wherein one or more of the set of infrastructure performance indicators are determined in parallel.
  • 27. The method of claim 22, wherein at least one infrastructure performance indicator of the set of infrastructure performance indicators is a transport layer metric value indicating transport layer performance for the data.
  • 28. The method of claim 22, wherein at least one infrastructure performance indicator of the set of infrastructure performance indicators is a radio access network (RAN) metric indicating RAN-level performance for the data.
  • 29. The method of claim 22, wherein at least one local performance indicator of the set of local performance indicators is a Quality of Experience (QoE) value indicating performance at a mobile terminal.
  • 30. The method of claim 22, wherein at least one local performance indicator of the set of local performance indicators is a delay metric indicating delays suffered on the mobile terminal when accessing a given service.
  • 31. The method of claim 23, wherein the determining the at least one local performance indicator of the set of local performance indicators is determined for an application displayed on the mobile terminal, via screenshot data acquired.
  • 32. The method of claim 23, wherein the determining the at least one local performance indicator of the set of local performance indicators is influenced by screen related information describing an operation of the screen.
  • 33. The method of claim 32, wherein the screen related information is at least one of a screen on/off event, screen orientation change, or information on an app being in a foreground of the terminal at a given point in time.
  • 34. The method of claim 23, wherein the processing the acquired screenshot data for determining the presence of a screen display element utilizes is a pattern recognition method identifying a pattern or one or more pattern changes in the display element.
  • 35. The method of claim 34, wherein pattern changes are pixel differences between subsequent screenshots.
  • 36. The method of claim 23, wherein the acquiring and processing screenshot data is carried out continuously or in predetermined intervals.
  • 37. The method of claim 23, wherein the display element is a user interface building block.
  • 38. The method claim 22, wherein accuracy of determining a correlation between the set of infrastructure performance indicators and the set of local performance indicators is verified by: calculating at least one performance indicator for at least one infrastructure performance indicator from the subset of the plurality of mobile terminals; andcomparing the calculated performance indicator with the received local performance indicator of the subset of the plurality of mobile terminals.
  • 39. A mobile terminal connected to a network, the mobile terminal comprising: processing circuitry;memory containing instructions executable by the processing circuitry whereby the mobile terminal is operative to: acquire screenshot data displayed on the mobile terminal;process the acquired screenshot data for determining the presence of a screen display element indicating the performance of a service at the mobile terminal; anddetermine at least one local performance indicator using the screen display element.
  • 40. A network entity for calculating a performance indicator indicating a performance of a service at one of a plurality of mobile terminals connected to a network, the network entity comprising: processing circuitry;memory containing instructions executable by the processing circuitry whereby the network entity is operative to: receive a set of infrastructure performance indicators, each infrastructure performance indicator being determined for a part of the network conveying data to one or more of the mobile terminals connected to the network;receive a set of local performance indicators, each local performance indicator being determined locally at one mobile terminal of a subset of the plurality of mobile terminals connected to the network;determine a correlation between the set of infrastructure performance indicators and the set of local performance indicators; andcalculate the performance indicator indicating the performance of the service at one or more mobile terminals using the correlation and one or more of infrastructure performance indicators of the set of infrastructure performance indicators.
PCT Information
Filing Document Filing Date Country Kind
PCT/EP2016/053011 2/12/2016 WO 00