 
                 Patent Application
 Patent Application
                     20240269549
 20240269549
                    The accompanying drawings illustrate a number of example embodiments and are a part of the specification. Together with the following description, these drawings demonstrate and explain various principles of the present disclosure.
  
  
  
  
  
  
  
  
  
  
Throughout the drawings, identical reference characters and descriptions indicate similar, but not necessarily identical, elements. While the example embodiments described herein are susceptible to various modifications and alternative forms, specific embodiments have been shown by way of example in the drawings and will be described in detail herein. However, the example embodiments described herein are not intended to be limited to the particular forms disclosed. Rather, the present disclosure covers all modifications, equivalents, and alternatives falling within the scope of the appended claims.
Cloud gaming may refer to an innovative form of computer gaming where a substantial portion of video is rendered at a remote server and beamed back to a client gaming device rather than being created directly on the client gaming device itself. Cloud gaming may have substantial benefits over traditional client-side gaming technologies. In particular, cloud gaming may open up new demographics and populations of players who might otherwise not have ready access to higher end computer hardware. Instead, a larger multimedia conglomerate may optionally leverage its own data center server farms to render high-definition video for players on their client gaming devices. These gaming devices may be substantially lower powered and more affordable (e.g., a relatively inexpensive smartphone) with the processing power to download and replay high-definition video rather than directly creating the video itself. Indeed, such lower powered and more affordable devices may be unable to directly render the video themselves fast enough to enable the corresponding game playing experience.
Although cloud gaming provides a number of potential advantages over more traditional systems, cloud gaming can also introduce new challenges and complexities. For example, although cloud gaming can diminish a need or desire for higher end client-side computing hardware and processing power, cloud gaming nevertheless can require a highly reliable and high-bandwidth network connection (e.g., depending on the response times corresponding to a particular game design). Similarly, the distance between the client and the server can create a de facto barrier that can hinder or delay an ability of the server to analyze the game playing experience at the client.
Moreover, certain cloud game designers, publishers, or administrators may form agreements with a larger multimedia conglomerate to provide access to cloud games through a larger social network or multimedia service. The larger multimedia conglomerate may also have access to larger data center server farms than the cloud game designers would otherwise have ready access to. For example, a particular cloud game designer may provide access to its cloud game through a social network. In these cases, it can be desirable for the multimedia conglomerate to perform big data operations to evaluate the game playing experience that the game designer is providing, thereby helping to ensure that the common users between the game designer and the multimedia company are having a satisfactory experience.
As one illustrative example, in the context of cloud gaming it can be helpful to evaluate the quality of latency associated with the cloud gaming experience. A variety of different latency metrics may be useful for monitoring and adjusting a configuration for enabling and playing one or more cloud games.
To be even more precise, such metrics may include measurements of latency between specific events within an overall cloud gaming processing pipeline, including more common or useful events such as creation of input information as a user applies one or more inputs to a cloud gaming client device, a frame creation event at which point a frame, which was triggered by such user input, is actually generated or rendered at the cloud gaming server, and/or a frame render event at which point the original frame, which was drawn for a virtual display at the server, may be translated to draw a corresponding frame for a display at the client (e.g., a physical display). The specific latency between the creation of the user input and the frame render event on the cloud gaming client device may be useful to measure, and this application discloses an innovative methodology for capturing and reporting this measurement.
Moreover, the technology of this application does not merely measure end-to-end latency between client-side input and client-side rendering, in a conventional manner, but more importantly may perform this measurement in an innovative manner that enables a much larger scale of usage across a much wider and more diverse set of applications. Generally speaking, the methodology of this application may be application or cloud game agnostic in the sense that the methodology may apply, in a uniform or substantially uniform manner, to a wide variety of cloud games. Moreover, the methodology of this application may be applied in a manner that is abstracted away from one or more layers of implementation details regarding how each specific cloud game actually receives, parses, and/or processes one or more items of input instruction information from a user playing a cloud game. Thus, rather than the cloud game itself, and rather than a particular platform on which the cloud game is being played, directly accessing a full programming or operating system stack, and making accommodations for differences between different platforms with different underlying implementation details, the methodology of this application may instead apply at a higher level of abstraction in a substantially uniform manner across a large number of cloud gaming applications and/or corresponding platforms with a wide variety of implementation details.
To achieve these benefits, for example, one or more modules may intercept a client-side user input instruction event, a client-side render or display event, and/or a server-side frame creation event. Thus, rather than having internal access to a client-side cloud game application itself and/or a server-side frame creation rendering engine or application, and rather than accommodating various differing implementation details that these applications may have between cloud games and between platforms, one or more of these modules may instead reside external to these applications, with a layer of abstraction between them, and instead simply monitor for when the applications output data indicating a client-side user input instruction event, a client-side frame render or display event, and/or a server-side frame creation event, for example. By simply monitoring, from an external position, when one or more of these events occur, the modules that perform this monitoring and interception may bypass a request or need to fully understand various implementation details for how these applications/platforms actually generated these events, as discussed in more detail below.
Features from any of the embodiments described herein may be used in combination with one another in accordance with the general principles described herein. These and other embodiments, features, and advantages will be more fully understood upon reading the following detailed description in conjunction with the accompanying drawings and claims.
The following will provide, with reference to 
As illustrated in 
The systems described herein may perform step 101 in a variety of ways. In one example, input sending unit 104 may perform step 101 at least in part by monitoring for, detecting, and/or intercepting data indicating the creation of the cloud gaming input information. In particular, input sending unit 104 may perform step 101 as a unit that is disposed external to a cloud game application or process that generates the cloud gaming input information in response to manual or other input from a human user at a cloud gaming client device.
As one illustrative example, input sending unit 104 may be disposed directly within a corresponding cloud gaming application. In other words, in these examples, the cloud gaming application itself may have been configured or programmed to perform the functions of input sending unit 104 (e.g., by directly disposing or hooking input sending unit 104 within the cloud gaming application). This configuration may have been established as part of a prearranged agreement with the cloud gaming vendor or marketplace administrator, etc., to facilitate the performance of method 100 including the beneficial measurement of end-to-end latency, as discussed in more detail below. Furthermore, in these examples, input sending unit 104 may optionally transmit the cloud gaming input information in-band as part of regular, normal, or in-game network transmissions between the cloud gaming client device and the cloud gaming server (e.g., regular network transmissions exchanging server-side rendered video in response to client-side user input instructions).
Additionally, or alternatively, in other examples input sending unit 104 may be disposed within an external application, hypervisor, process, gaming console application or server, emulator, meta-application, general-purpose social network application or website (e.g., a cloud game non-specific social network that enables access to a multitude of different cloud games), or operating system, rather than being disposed directly within the cloud gaming application itself. In such examples, input sending unit 104 may optionally perform step 101 in a manner that is entirely or substantially cloud game agnostic. The term cloud game agnostic may refer to the performance of method 100 being substantially or entirely the same regardless of dramatic differences in implementation details between different cloud game applications regarding how they internally generate, parse, and/or process input or output information, for example. Thus, from an external position, input sending unit 104 may monitor the performance of a wide variety of different cloud games, with dramatically different internal configurations, within the same larger application (e.g., a general-purpose social network application) and simply detect attempted network packet transmissions to perform method 100 in the same or substantially the same manner regardless of which cloud game is actually executing. In summary, the cloud gaming application may optionally execute within the larger external application, even if input sending unit 104 is not actually part of the cloud gaming application itself. From this position, input sending unit 104 may monitor for network messages or items of output that the cloud gaming application is attempting to transmit to the cloud gaming server.
Upon detecting or intercepting such an attempt to upload an instance of user input across a wide area network to a remote cloud gaming server, input sending unit 104 may, in these examples, inspect, analyze, and/or parse the attempted network message. For example, input sending unit 104 may optionally identify, locate, and/or extract one or more items of information indicating the corresponding user input. Such information may identify the particular buttons pressed by a user or the particular manner and/or timing by which the user manipulated one or more buttons, screens, or user interfaces. Additionally, or alternatively, input sending unit 104 may extract or otherwise identify a timestamp that matches the corresponding user input such that the timestamp indicates the particular time at which the user input information was created in response to the actual manual input by the user. In further examples, rather than input sending unit 104 proactively extracting or generating this information itself, input sending unit 104 may simply receive the user input information and/or the corresponding timestamp from another unit or component that is configured to relay or forward this information to input sending unit 104. In either case, input sending unit 104 may optionally, in these examples, transmit the cloud gaming input information out-of-band such that the cloud gaming input information is transmitted in a channel (e.g., separate connection, separately established network path, etc.) that is separate from the network channel for regular or normal communications between the client and server for enabling the cloud gaming experience (e.g., the regular channel exchanging server-side rendered video in response to client-side entry of user input by a player of a corresponding cloud game).
  
Similarly, 
As illustrated in 
Feedback receiving unit 106 may receive the frame creation timestamp in a variety of ways. For example, prior to feedback receiving unit 106 actually receiving the frame creation timestamp, method 100 may further optionally involve the cloud gaming server generating a feedback message that includes the frame creation timestamp for transmission as a reply to the cloud gaming input information. 
Beginning with 
  
Server control unit 116 may also monitor, detect, and/or intercept frame creation events, which may correspond to events whereby a corresponding rendering engine renders sequential frames of cloud gaming video. Accordingly, server control unit 116 may optionally be disposed outside of this rendering engine and may further maintain one or more levels of abstraction away from underlying implementation details for how the rendering engine processes user input information and/or generates corresponding frames of video. In the context of 
For example, method 100 may also optionally include an input receiving unit at a cloud gaming server receiving the cloud gaming input information. In particular, an input receiving unit 112 within the cloud gaming server may, at a step 908, receive the cloud gaming input information that was transmitted by input sending unit 104 at step 906. This is shown within timing diagram 900 of 
Server control unit 116 may perform the matching procedure in a variety of ways. In some examples, server control unit 116 may perform the matching procedure based on an expected lag or lapse of time between the corresponding cloud gaming input information timestamp and the frame creation timestamp. Alternatively, with one or more additional subcomponents providing a higher level of intelligence, server control unit 116 may optionally detect that the pixels of the created frame match expected pixels or graphics that would be expected in response to the user input indicated by a corresponding cloud gaming input information message. For example, server control unit 116 may detect a deviation or burst of user input within a larger time period of user input and/or lack of user input, and then match a timing of the deviation or burst to a corresponding deviation or burst in terms of visual output. In other words, server control unit 116 may detect a significant deviation in terms of visual output and match that to a parallel or corresponding deviation in terms of user input just moments earlier. For example, a screen may remain generally static for seconds, and then a user may press a button, and then the screen may significantly change, and server control unit 116 may infer that the pressing of the button triggered the change in the display. Server control unit 116 may additionally, or alternatively, use any other suitable protocol, heuristic, or artificial intelligence component for performing a matching process to match an input timestamp to a frame creation timestamp, as discussed above.
After successfully performing the matching procedure, server control unit 116 may construct a feedback message. 
As illustrated in 
Returning to 
Client control unit 110 may perform step 107 and corresponding step 918 in a variety of ways. Generally speaking, client control unit 110 may intercept a client-side video frame render event in a manner that parallels how server control unit 116 intercepted the server-side video frame creation event, as discussed above in connection with 
Returning to 
Client control unit 110 may perform step 109 in a variety of ways. 
Such information may be useful to the client-side cloud gaming application, which might otherwise lack information or insight regarding this specific measurement of latency. In other words, without the performance of method 100, the client-side gaming application may lack insight into the precise details of how much lag is taking place between creation of the cloud gaming input information and client-side rendering of the corresponding frame, as further discussed above.
In addition to performing step 107 to arrive at the measurement of latency, client control unit 110 may also optionally provide the feedback indicating the amount of lag between creation of the cloud gaming input information and rendering of the corresponding frame to a component that is configured to adjust an aspect of the cloud gaming experience. Such a component may be part of the cloud gaming client device, the cloud gaming server, or another device that helps facilitate or manage the overall cloud gaming experience. For example, client control unit 110 may adjust one or more settings in response to a determination that the measurement of latency is higher-than-expected or beyond a predetermined threshold, for example. In these examples, client control unit 110 may optionally make one or more adjustments to compensate for the level of latency. For example, client control unit 110 may increase a prioritization for one or more network packets, may decrease an amount of resolution for a corresponding frame of video, or may prioritize one or more processing threads or computational tasks higher than previously, etc. Generally speaking, client control unit 110 may perform any suitable adjustment to help compensate for an undesirable degree of latency detected through the performance of method 100.
Example 1: An example computer-implemented method may include (i) sending, to a cloud gaming server, cloud gaming input information with an input creation timestamp that marks when the cloud gaming input information was created, (ii) receiving, in response to sending the cloud gaming input information, a frame creation timestamp that marks when a frame was drawn for a virtual display at the cloud gaming server, (iii) storing the frame creation timestamp in memory, (iv) creating a frame render timestamp that marks a timing of an intercepted client-side video frame render event of translating the frame to draw a corresponding frame for a display at a cloud gaming client device, and (v) automatically providing feedback to improve a cloud gaming experience through calculating latency by subtracting the input creation timestamp from the frame render timestamp to measure lag between creation of the cloud gaming input information and rendering of the corresponding frame at the cloud gaming client device.
Example 2: The computer-implemented method of Example 1, where a feedback message that includes the input creation timestamp is sent from the cloud gaming server to the cloud gaming client device.
Example 3: The computer-implemented method of any of Examples 1-2, where subtracting the input creation timestamp from the frame render timestamp is performed by the cloud gaming client device that sent the cloud gaming input information to the cloud gaming server.
Example 4: The computer-implemented method of any of Examples 1-3, where a client control unit at the cloud gaming client device performs subtracting the input creation timestamp from the frame render timestamp.
Example 5: The computer-implemented method of any of Examples 1-4, where the client control unit intercepts the client-side video frame render event for the corresponding frame.
Example 6: The computer-implemented method of any of Examples 1-5, where the client control unit performs subtracting the input creation timestamp from the frame render timestamp in response to intercepting the client-side video frame render event for the corresponding frame.
Example 7: The computer-implemented method of any of Examples 1-6, where the cloud gaming server matches the input creation timestamp with the frame creation timestamp.
Example 8: The computer-implemented method of any of Examples 1-7, where a feedback message that is sent from the cloud gaming server to the cloud gaming client device includes a result of matching the input creation timestamp with the frame creation timestamp.
Example 9: The computer-implemented method of any of Example 1-8, where a feedback receiving unit at the cloud gaming client device parses a feedback message to identify which input creation timestamp matches which frame creation timestamp.
Example 10: The computer-implemented method of any of Examples 1-9, where a client control unit performs subtracting the input creation timestamp from the frame render timestamp in response to a feedback receiving unit receiving a feedback message.
Example 11: The computer-implemented method of any of Examples 1-10, where an amount of lag between creation of the cloud gaming input information and rendering of the corresponding frame at the cloud gaming client device corresponds to an input latency end-to-end measurement for cloud gaming applications.
Example 12: The computer-implemented method of any of Examples 1-11, further including an input receiving unit at a cloud gaming server receiving the cloud gaming input information.
Example 13: The computer-implemented method of any of Examples 1-12, further including an input memory unit at the cloud gaming server storing the cloud gaming input information.
Example 14: The computer-implemented method of any of Examples 1-13, further including a server control unit at the cloud gaming server intercepting a server-side video frame creation event.
Example 15: The computer-implemented method of any of Examples 1-14, further including the server control unit at the cloud gaming server locating, in response to intercepting the server-side video frame creation event, input within a local cache of the cloud gaming server that matches the server-side video frame creation event.
Example 16: The computer-implemented method of any of Examples 1-15, further including a feedback sending unit delivering to a feedback receiving unit a feedback message that indicates a match between the input creation timestamp and the frame creation timestamp that marks when the frame was created in response to the cloud gaming input information.
Example 17: The computer-implemented method of any of Examples 1-16, further including providing feedback indicating an amount of lag between creation of the cloud gaming input information and rendering of the corresponding frame at the cloud gaming client device to a component that is configured to adjust an aspect of the cloud gaming experience.
Example 18: The computer-implemented method of any of Examples 1-17, further including the component adjusting the aspect of the cloud gaming experience based on the feedback indicating the amount of lag between creation of the cloud gaming input information and rendering of the corresponding frame at the cloud gaming client device.
Example 19: A system may include at least one physical processor and a physical memory including computer-executable instructions that, when executed by the physical processor, cause the physical processor to perform a method including (i) sending, to a cloud gaming server, cloud gaming input information with an input creation timestamp that marks when the cloud gaming input information was created, (ii) receiving, in response to sending the cloud gaming input information, a frame creation timestamp that marks when a frame was drawn for a virtual display at the cloud gaming server, (iii) storing the frame creation timestamp in memory, (iv) creating a frame render timestamp that marks a timing of an intercepted client-side video frame render event of translating the frame to draw a corresponding frame for a display at a cloud gaming client device, and (v) automatically providing feedback to improve a cloud gaming experience through calculating latency by subtracting the input creation timestamp from the frame render timestamp to measure lag between creation of the cloud gaming input information and rendering of the corresponding frame at the cloud gaming client device.
Example 20: A non-transitory computer-readable medium including one or more computer-executable instructions that, when executed by at least one processor of a computing device, cause the computing device to (i) send, to a cloud gaming server, cloud gaming input information with an input creation timestamp that marks when the cloud gaming input information was created, (ii) receive, in response to sending the cloud gaming input information, a frame creation timestamp that marks when a frame was drawn for a virtual display at the cloud gaming server, (iii) store the frame creation timestamp in memory, (iv) create a frame render timestamp that marks a timing of an intercepted client-side video frame render event of translating the frame to draw a corresponding frame for a display at a cloud gaming client device, and (v) automatically provide feedback to improve a cloud gaming experience through calculating latency by subtracting the input creation timestamp from the frame render timestamp to measure lag between creation of the cloud gaming input information and rendering of the corresponding frame at the cloud gaming client device.
As detailed above, the computing devices and systems described and/or illustrated herein broadly represent any type or form of computing device or system capable of executing computer-readable instructions, such as those contained within the modules described herein. In their most basic configuration, these computing device(s) may each include at least one memory device and at least one physical processor.
In some examples, the term “memory device” generally refers to any type or form of volatile or non-volatile storage device or medium capable of storing data and/or computer-readable instructions. In one example, a memory device may store, load, and/or maintain one or more of the modules described herein. Examples of memory devices include, without limitation, Random Access Memory (RAM), Read Only Memory (ROM), flash memory, Hard Disk Drives (HDDs), Solid-State Drives (SSDs), optical disk drives, caches, variations or combinations of one or more of the same, or any other suitable storage memory.
In some examples, the term “physical processor,” such as processor 130 in 
Although illustrated as separate elements, the modules described and/or illustrated herein may represent portions of a single module or application. In addition, in certain embodiments one or more of these modules may represent one or more software applications or programs that, when executed by a computing device, may cause the computing device to perform one or more tasks. For example, one or more of the modules described and/or illustrated herein may represent modules stored and configured to run on one or more of the computing devices or systems described and/or illustrated herein. One or more of these modules may also represent all or portions of one or more special-purpose computers configured to perform one or more tasks.
In addition, one or more of the modules described herein may transform data, physical devices, and/or representations of physical devices from one form to another. Additionally or alternatively, one or more of the modules recited herein may transform a processor, volatile memory, non-volatile memory, and/or any other portion of a physical computing device from one form to another by executing on the computing device, storing data on the computing device, and/or otherwise interacting with the computing device.
In some embodiments, the term “computer-readable medium” generally refers to any form of device, carrier, or medium capable of storing or carrying computer-readable instructions. Examples of computer-readable media include, without limitation, transmission-type media, such as carrier waves, and non-transitory-type media, such as magnetic-storage media (e.g., hard disk drives, tape drives, and floppy disks), optical-storage media (e.g., Compact Disks (CDs), Digital Video Disks (DVDs), and BLU-RAY disks), electronic-storage media (e.g., solid-state drives and flash media), and other distribution systems.
The process parameters and sequence of the steps described and/or illustrated herein are given by way of example only and can be varied as desired. For example, while the steps illustrated and/or described herein may be shown or discussed in a particular order, these steps do not necessarily need to be performed in the order illustrated or discussed. The various example methods described and/or illustrated herein may also omit one or more of the steps described or illustrated herein or include additional steps in addition to those disclosed.
The preceding description has been provided to enable others skilled in the art to best utilize various aspects of the example embodiments disclosed herein. This example description is not intended to be exhaustive or to be limited to any precise form disclosed. Many modifications and variations are possible without departing from the spirit and scope of the present disclosure. The embodiments disclosed herein should be considered in all respects illustrative and not restrictive. Reference should be made to the appended claims and their equivalents in determining the scope of the present disclosure.
Unless otherwise noted, the terms “connected to” and “coupled to” (and their derivatives), as used in the specification and claims, are to be construed as permitting both direct and indirect (i.e., via other elements or components) connection. In addition, the terms “a” or “an,” as used in the specification and claims, are to be construed as meaning “at least one of.” Finally, for ease of use, the terms “including” and “having” (and their derivatives), as used in the specification and claims, are interchangeable with and have the same meaning as the word “comprising.”
This application claims the benefit of U.S. Provisional Application No. 63/105,320, filed 25 Oct. 2020, and U.S. Provisional Application No. 63/194,821, filed 28 May 2021, the disclosures of each of which are incorporated, in their entirety, by this reference. Co-pending U.S. application Ser. No. 17/506,640, filed 20 Oct. 2021, is incorporated, in its entirety, by this reference.
| Number | Date | Country | |
|---|---|---|---|
| 63194821 | May 2021 | US | |
| 63105320 | Oct 2020 | US |