A63F2300/5593

Information processing device, data synchronization program, data synchronization method, data synchronization system, and terminal device
11766608 · 2023-09-26 · ·

Provided are an information processing device, a data synchronization program, a data synchronization method, a data synchronization system, and a terminal device that suppress an increase in processing load and communication load in a situation in which a plurality of user terminals participate and data of the plurality of user terminals are synchronized. A server device is connected to a plurality of clients that synchronize an object with each other via a network, and includes: data reception means configured to receive a difference from a synchronization target object from a client having ownership of the object; data update means configured to update first, second, third replicas, and the like obtained by replicating the synchronization target object by using the difference; and data transmission means configured to transmit the difference to a client other than the client having the ownership among the plurality of clients.

REDUCING LATENCY IN CLOUD GAMING APPLICATIONS BY OVERLAPPING RECEPTION AND DECODING OF VIDEO FRAMES AND THEIR DISPLAY
20210354031 · 2021-11-18 ·

A method of cloud gaming is disclosed. The method including receiving an encoded video frame at a client, wherein a server executes an application to generate a rendered video frame which is then encoded at an encoder at the server as the encoded video frame, wherein the encoded video frame includes one or more encoded slices that are compressed. The method including decoding the one or more encoded slices at a decoder of the client to generate one or more decoded slices. The method including rendering the one or more decoded slices for display at the client. The method including begin displaying the one or more decoded slices that are rendered before fully receiving the one or more encoded slices at the client.

Spectating simulation

A spectator client device receives a plurality of spectator update frames that include respective actual physics state information for game objects of respective participants in a multiplayer game session. The spectator client device buffers respective ones of the spectator update frames for respective participants, and determines based on respective downlink spectator update frames buffered for the respective participants, respective simulated playback physical states at a common playback time of a current simulation period. A particular simulated playback physical state for a particular participant is determined based on actual physics state information obtained from at least two respective downlink spectator update frames buffered for the particular participant. The spectator client device renders a delayed depiction of the multiplayer game session at the common playback time of the current simulation period based on the playback physical states determined, for the respective participants, for the current simulation period.

DETERMINING TARGETED DISPLAY TIME OF A VIDEO FRAME FOR A CLIENT BASED ON SERVER SIDE TIMING INFORMATION
20230024723 · 2023-01-26 ·

A method for cloud gaming. The method including generating a video frame when executing a video game at a server. The method including performing a scan-out process to deliver the video frame to an encoder configured to compress the video frame, wherein the scan-out process begins at a flip-time of the video frame. The method including transmitting the video frame that is compressed to a client. The method including determining at the client a target display time for the video frame. The method including scheduling at the client a display time for the video frame based on the target display time.

OVERLAPPING SCAN-IN AND ENCODE AT THE SERVER
20220401835 · 2022-12-22 ·

A method for cloud gaming. The method including generating a video frame when executing a video game at a server. The method including scanning-in the video frame to an encoder at the server scanline-by-scanline. The method including encoding one or more encoder slices as one or more encoded slices at the encoder, wherein each encoded slice is delivered to a buffer at an encoder fill rate. The method including draining a first encoded slice from the buffer to stream the first encoded slice at a buffer drain rate over a network to a client, wherein the first encoded slice is streamed over the network before fully encoding the one or more slices of the video frame.

REQUEST DISTRIBUTION SYSTEM

Embodiments of the systems and methods disclosed herein provide a request distribution system in which a request for resources may be executed by a plurality of workers. Upon receiving a request for resources from a user computing system, the request distribution system may select a subset of workers from the plurality of workers to execute the request within a time limit. Once the workers generate a plurality of outputs, each output associated with a quality level, the request distribution system may transmit the output associated with the highest quality level to the user computing system.

BEGINNING SCAN-OUT PROCESS AT FLIP-TIME FOR CLOUD GAMING APPLICATIONS
20230016903 · 2023-01-19 ·

A method for cloud gaming. The method including generating a video frame when executing a video game at a server. The method including performing a scan-out process by scanning the video frame scanline-by-scanline and one or more user interface features scanline-by-scanline to one or more input frame buffers, and compositing and blending the video frame and the one or more user interface features into a modified video frame. The method including scanning in the scan-out process the modified video frame to an encoder at the server scanline-by-scanline. The method including beginning in the scan-out process scanning the video frame and the one or more user interface features to the one or more input frame buffers at a corresponding flip-time for the video frame.

Memory management in gaming rendering
11813521 · 2023-11-14 · ·

Some implementations of this application are directed to a server system including one or more CPUs, a plurality of GPUs, main dynamic memory storing programs and data for use by the CPUs and/or GPUs during program execution, a static memory pool stored in a non-volatile memory, and a memory controller configured to manage the static memory pool. Each of the GPUs includes a local cache and is configured to access the static memory pool via the memory controller. The server system executes a plurality of gaming sessions for a gaming title in parallel on the one or more CPUs. Each of the plurality of gaming sessions is associated with a static data item stored in the static memory pool, and requires a graphics operation executable by a respective GPU using the static data item.

DYNAMIC CLIENT BUFFERING USING SERVER AND CLIENT VSYNC SIGNALS OF RECEIVED VIDEO FRAMES FOR CLOUD GAMING
20230356077 · 2023-11-09 ·

A method is disclosed including setting, at a server, a server VSYNC signal to a server VSYNC frequency defining a plurality of frame periods. The server VSYNC signal corresponding to generation of a plurality of video frames at the server during the plurality of frame periods. The method including setting, at a client, a client VSYNC signal to a client VSYNC frequency. The method including sending a plurality of compressed video frames based on the plurality of video frames from the server to the client over a network using the server VSYNC signal. The method including decoding and displaying, at the client, the plurality of compressed video frames. The method including analyzing the timing of one or more client operations to set the amount of frame buffering used by the client, as the client receives the plurality of compressed video frames.

Synchronization and offset of VSYNC between peer-to-peer gaming devices

A method is disclosed including setting, at a plurality of devices, a plurality of VSYNC signals to a plurality of VSYNC frequencies, wherein a corresponding device VSYNC signal of a corresponding device is set to a corresponding device VSYNC frequency. The method including sending a plurality of signals between the plurality of devices, which are analyzed and used to adjust the relative timing between corresponding device VSYNC signals of at least two devices.