This application claims benefit of and priority to India Patent Application No. 202041035136, filed Aug. 14, 2020, which is herein incorporated by reference in its entirety for all applicable purposes.
Aspects of the present disclosure relate to wireless communications, and more particularly, to techniques for staggering clients for cloud-based services based on network information.
Wireless communication systems are widely deployed to provide various telecommunication services such as telephony, video, data, messaging, broadcasts, etc. These wireless communication systems may employ multiple-access technologies capable of supporting communication with multiple users by sharing available system resources (e.g., bandwidth, transmit power, etc.). Examples of such multiple-access systems include 3rd Generation Partnership Project (3GPP) Long Term Evolution (LTE) systems, LTE Advanced (LTE-A) systems, code division multiple access (CDMA) systems, time division multiple access (TDMA) systems, frequency division multiple access (FDMA) systems, orthogonal frequency division multiple access (OFDMA) systems, single-carrier frequency division multiple access (SC-FDMA) systems, and time division synchronous code division multiple access (TD-SCDMA) systems, to name a few.
These multiple access technologies have been adopted in various telecommunication standards to provide a common protocol that enables different wireless devices to communicate on a municipal, national, regional, and even global level. New radio (e.g., 5G NR) is an example of an emerging telecommunication standard. NR is a set of enhancements to the LTE mobile standard promulgated by 3GPP. NR is designed to better support mobile broadband Internet access by improving spectral efficiency, lowering costs, improving services, making use of new spectrum, and better integrating with other open standards using OFDMA with a cyclic prefix (CP) on the downlink (DL) and on the uplink (UL). To these ends, NR supports beamforming, multiple-input multiple-output (MIMO) antenna technology, and carrier aggregation.
However, as the demand for mobile broadband access continues to increase, there exists a need for further improvements in NR and LTE technology. Preferably, these improvements should be applicable to other multi-access technologies and the telecommunication standards that employ these technologies.
The systems, methods, and devices of the disclosure each have several aspects, no single one of which is solely responsible for its desirable attributes. Without limiting the scope of this disclosure as expressed by the claims which follow, some features will now be discussed briefly. After considering this discussion, and particularly after reading the section entitled “Detailed Description” one will understand how the features of this disclosure provide advantages that include desirable latency at a client or desirable traffic capacity at serving cell and/or wireless network.
Certain aspects of the subject matter described in this disclosure can be implemented in a method for communicating, from a client to a server, information associated with a wireless communication network by a user equipment (UE). The method generally includes obtaining, by a client from a modem, information associated with a wireless communication network. The method also includes transmitting, from the client to the server, at an application level, a first message including the information. The method further includes receiving, by the client from the server, data at a time determined based on the information.
Certain aspects of the subject matter described in this disclosure can be implemented in a method for transmitting client data by a server. The method generally includes receiving, from a plurality of clients by a server, a plurality of messages, wherein at least two of the messages includes information associated with one or more wireless communication networks; and transmitting, from the server to at least one of the clients, client data, at one or more transmission occasions based on the information.
Certain aspects of the subject matter described in this disclosure can be implemented in an apparatus for communicating, from a client to a server, information associated with a wireless communication network. The apparatus generally includes a modem, a memory, and a processor, which is coupled to the memory and the modem. The processor and the memory are configured to obtain, by a client from the modem, information associated with a wireless communication network, transmit, from the client to the server, at an application level, a first message including the information, and receive, by the client from the server, data at a time determined based on the information.
Certain aspects of the subject matter described in this disclosure can be implemented in an apparatus for transmitting client data. The apparatus generally includes a memory and a processor, which is coupled to the memory. The processor and the memory are configured to receive, from a plurality of clients by the server, a plurality of messages, wherein at least two of the messages includes information associated with one or more wireless communication networks; and transmit, from the server to at least one of the clients, client data, at one or more transmission occasions based on the information.
Certain aspects of the subject matter described in this disclosure can be implemented in an apparatus for communicating, from a client to a server, information associated with a wireless communication network. The apparatus generally includes means for obtaining, by a client from a modem, information associated with a wireless communication network; means for transmitting, from the client to the server, at an application level, a first message including the information; and means for receiving, by the client from the server, data at a time determined based on the information.
Certain aspects of the subject matter described in this disclosure can be implemented in an apparatus for transmitting client data. The apparatus generally includes means for receiving, from a plurality of clients by a server, a plurality of messages, wherein at least two of the messages includes information associated with one or more wireless communication networks; and means for transmitting, from the server to at least one of the clients, client data, at one or more transmission occasions based on the information.
Certain aspects of the subject matter described in this disclosure can be implemented in a computer-readable medium. The computer readable medium includes computer-executable instructions that, when executed by one or more processors of a processing system, cause the processing system to perform obtaining, by a client from a modem, information associated with a wireless communication network; transmitting, from the client to the server, at an application level, a first message including the information; and receiving, by the client from the server, data at a time determined based on the information.
Certain aspects of the subject matter described in this disclosure can be implemented in a computer-readable medium. The computer readable medium includes computer-executable instructions that, when executed by one or more processors of a processing system, cause the processing system to perform receiving, from a plurality of clients by a server, a plurality of messages, wherein at least two of the messages includes information associated with one or more wireless communication networks; and transmitting, from the server to at least one of the clients, client data, at one or more transmission occasions based on the information.
To the accomplishment of the foregoing and related ends, the one or more aspects comprise the features hereinafter fully described and particularly pointed out in the claims. The following description and the appended drawings set forth in detail certain illustrative features of the one or more aspects. These features are indicative, however, of but a few of the various ways in which the principles of various aspects may be employed.
So that the manner in which the above-recited features of the present disclosure can be understood in detail, a more particular description, briefly summarized above, may be had by reference to aspects, some of which are illustrated in the drawings. It is to be noted, however, that the appended drawings illustrate only certain typical aspects of this disclosure and are therefore not to be considered limiting of its scope, for the description may admit to other equally effective aspects.
To facilitate understanding, identical reference numerals have been used, where possible, to designate identical elements that are common to the figures. It is contemplated that elements disclosed in one aspect may be beneficially utilized on other aspects without specific recitation.
Aspects of the present disclosure provide apparatus, methods, processing systems, and computer readable mediums for staggering or distributing client sessions served by a server.
Under certain low-latency cloud-based services (such as split extended reality (XR) or live video streaming), the timelines of when packets for each of the clients are generated at a server and delivered may affect the traffic capacity of certain wireless communication networks (e.g., a 5G NR network and/or LTE network). For example, the server may send content to clients, which are camped on/served by the same cell, in overlapping periods. In certain cases, the content sent to the clients in the overlapping periods may exceed the traffic capacity at the cell that is serving the clients for the period. In such cases, the clients may experience lag or lower downlink data rates in content delivery from the server due to the traffic capacity of the cell. In certain cases, the lag and/or lower downlink data rates may translate to lower frame rates and/or lower resolutions for certain content, such as video frames. In certain cases, the overlapping content delivery may limit the number of users that a serving cell can serve for a given period.
Client traffic, for multiple clients, that shares network capacity, for example, at the same serving cell, may be spread out over time to enable a desirable number of users that can be served by a wireless communication network or provide desirable latency and/or downlink throughput for client data delivery at the clients. In certain aspects, the clients may send network information, such as cell identifiers of the serving cell, to the server, and the server may spread out transmission and/or generation of the client data based on the network information received from the clients. The network information may enable the server to map a client session to a specific network entity, such as a serving cell of the client, and the server may use the mapping between the client session and a specific network entity to determine a time at which content is delivered to the client. In a cluster of servers that provide content to clients, the servers may coordinate and adjust the transmission and/or generation of client data based on the network information associated with the clients. The various client data delivery schemes described herein may enable desirable latency at the clients, desirable downlink throughputs at the clients, and/or desirable user capacity for a wireless communication network, for example, at a specific serving cell.
The following description provides examples of staggering clients in communication systems, and is not limiting of the scope, applicability, or examples set forth in the claims. Changes may be made in the function and arrangement of elements discussed without departing from the scope of the disclosure. Various examples may omit, substitute, or add various procedures or components as appropriate. For instance, the methods described may be performed in an order different from that described, and various steps may be added, omitted, or combined. Also, features described with respect to some examples may be combined in some other examples. For example, an apparatus may be implemented or a method may be practiced using any number of the aspects set forth herein. In addition, the scope of the disclosure is intended to cover such an apparatus or method which is practiced using other structure, functionality, or structure and functionality in addition to, or other than, the various aspects of the disclosure set forth herein. It should be understood that any aspect of the disclosure disclosed herein may be embodied by one or more elements of a claim. The word “exemplary” is used herein to mean “serving as an example, instance, or illustration.” Any aspect described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other aspects.
In general, any number of wireless networks may be deployed in a given geographic area. Each wireless network may support a particular radio access technology (RAT) and may operate on one or more frequencies. A RAT may also be referred to as a radio technology, an air interface, etc. A frequency may also be referred to as a carrier, a subcarrier, a frequency channel, a tone, a subband, etc. Each frequency may support a single RAT in a given geographic area in order to avoid interference between wireless networks of different RATs.
The techniques described herein may be used for various wireless networks and radio technologies. While aspects may be described herein using terminology commonly associated with 3G, 4G, and/or new radio (e.g., 5G NR) wireless technologies, aspects of the present disclosure can be applied in other generation-based communication systems.
NR access may support various wireless communication services, such as enhanced mobile broadband (eMBB) targeting wide bandwidth (e.g., 80 MHz or beyond), millimeter wave (mmW) targeting high carrier frequency (e.g., 24 GHz to 53 GHz or beyond), massive machine type communications MTC (mMTC) targeting non-backward compatible MTC techniques, and/or mission critical targeting ultra-reliable low-latency communications (URLLC). These services may include latency and reliability requirements. These services may also have different transmission time intervals (TTI) to meet respective quality of service (QoS) requirements. In addition, these services may co-exist in the same subframe. NR supports beamforming and beam direction may be dynamically configured. MIMO transmissions with precoding may also be supported. MIMO configurations in the DL may support up to 8 transmit antennas with multi-layer DL transmissions up to 8 streams and up to 2 streams per UE. Multi-layer transmissions with up to 2 streams per UE may be supported. Aggregation of multiple cells may be supported with up to 8 serving cells.
The UE 120a includes a client manager 122 that sends network information (e.g., a cell identifier) to the server 134 at an application level and receives client data at a time determined based on the network information, in accordance with aspects of the present disclosure. The server 134 includes a client manager 136 that generates and/or transmits client data at one or more occasions based on the network information, in accordance with aspects of the present disclosure.
As illustrated in
The BSs 110 communicate with UEs 120a-y (each also individually referred to herein as UE 120 or collectively as UEs 120) in the wireless communication network 100. The UEs 120 (e.g., 120x, 120y, etc.) may be dispersed throughout the wireless communication network 100, and each UE 120 may be stationary or mobile. Wireless communication network 100 may also include relay stations (e.g., relay station 110r), also referred to as relays or the like, that receive a transmission of data and/or other information from an upstream station (e.g., a BS 110a or a UE 120r) and sends a transmission of the data and/or other information to a downstream station (e.g., a UE 120 or a BS 110), or that relays transmissions between UEs 120, to facilitate communication between devices.
A network controller 130 may be in communication with a set of BSs 110 and provide coordination and control for these BSs 110 (e.g., via a backhaul). In aspects, the network controller 130 may be in communication with a core network 132 (e.g., a 5G Core Network (5GC)), which provides various network functions such as Access and Mobility Management, Session Management, User Plane Function, Policy Control Function, Authentication Server Function, Unified Data Management, Application Function, Network Exposure Function, Network Repository Function, Network Slice Selection Function, etc.
The core network 132 may be in communication with the server 134, such that the core network 132 serves as a packet gateway for providing the UE 120a with access to the server 134. The core network 132 may include various servers and networking devices, such as switches, routers, and gateways. The server 134 may be or include a computer, computing device, or processing system that provides a service (e.g., split extended reality (XR), cloud-gaming, live streaming, etc.) to a client, such as the UE 120a. The server may be or include a program, process, or thread running on the computer, computing device, or processing system. For example, the server 134 may be a virtual instance of a processing system or application, which is hosted on another processing system. That is, the server 134 may be virtualized in an application container or a virtual machine running on the host processing system. A computer-readable medium may include computer-executable instructions that, when executed by one or more processors of the host processing system, cause the host processing system to run the application container or virtual machine, which operates as the server. As further described herein with respect to
At the BS 110a, a transmit processor 220 may receive data from a data source 212 and control information from a controller/processor 240. The control information may be for the physical broadcast channel (PBCH), physical control format indicator channel (PCFICH), physical hybrid ARQ indicator channel (PHICH), physical downlink control channel (PDCCH), group common PDCCH (GC PDCCH), etc. The data may be for the physical downlink shared channel (PDSCH), etc. A medium access control (MAC)-control element (MAC-CE) is a MAC layer communication structure that may be used for control command exchange between wireless nodes. The MAC-CE may be carried in a shared channel such as a physical downlink shared channel (PDSCH), a physical uplink shared channel (PUSCH), or a physical sidelink shared channel (PSSCH).
The processor 220 may process (e.g., encode and symbol map) the data and control information to obtain data symbols and control symbols, respectively. The transmit processor 220 may also generate reference symbols, such as for the primary synchronization signal (PSS), secondary synchronization signal (SSS), PBCH demodulation reference signal (DMRS), and channel state information reference signal (CSI-RS). A transmit (TX) multiple-input multiple-output (MIMO) processor 230 may perform spatial processing (e.g., precoding) on the data symbols, the control symbols, and/or the reference symbols, if applicable, and may provide output symbol streams to the modulators (MODs) 232a-232t. Each modulator 232 may process a respective output symbol stream (e.g., for OFDM, etc.) to obtain an output sample stream. Each modulator may further process (e.g., convert to analog, amplify, filter, and upconvert) the output sample stream to obtain a downlink signal. Downlink signals from modulators 232a-232t may be transmitted via the antennas 234a-234t, respectively.
At the UE 120a, the antennas 252a-252r may receive the downlink signals from the BS 110a and may provide received signals to the demodulators (DEMODs) in transceivers 254a-254r, respectively. Each demodulator 254 may condition (e.g., filter, amplify, downconvert, and digitize) a respective received signal to obtain input samples. Each demodulator may further process the input samples (e.g., for OFDM, etc.) to obtain received symbols. A MIMO detector 256 may obtain received symbols from all the demodulators in transceivers 254a-254r, perform MIMO detection on the received symbols if applicable, and provide detected symbols. A receive processor 258 may process (e.g., demodulate, deinterleave, and decode) the detected symbols, provide decoded data for the UE 120a to a data sink 260, and provide decoded control information to a controller/processor 280.
On the uplink, at UE 120a, a transmit processor 264 may receive and process data (e.g., for the physical uplink shared channel (PUSCH)) from a data source 262 and control information (e.g., for the physical uplink control channel (PUCCH) from the controller/processor 280. The transmit processor 264 may also generate reference symbols for a reference signal (e.g., for the sounding reference signal (SRS)). The symbols from the transmit processor 264 may be precoded by a TX MIMO processor 266 if applicable, further processed by the modulators in transceivers 254a-254r (e.g., for SC-FDM, etc.), and transmitted to the BS 110a. At the BS 110a, the uplink signals from the UE 120a may be received by the antennas 234, processed by the modulators 232, detected by a MIMO detector 236 if applicable, and further processed by a receive processor 238 to obtain decoded data and control information sent by the UE 120a. The receive processor 238 may provide the decoded data to a data sink 239 and the decoded control information to the controller/processor 240.
The memories 242 and 282 may store data and program codes for BS 110a and UE 120a, respectively. A scheduler 244 may schedule UEs for data transmission on the downlink and/or uplink.
Antennas 252, processors 266, 258, 264, and/or controller/processor 280 of the UE 120a and/or antennas 234, processors 220, 230, 238, and/or controller/processor 240 of the BS 110a may be used to perform the various techniques and methods described herein. As shown in
NR may utilize orthogonal frequency division multiplexing (OFDM) with a cyclic prefix (CP) on the uplink and downlink. NR may support half-duplex operation using time division duplexing (TDD). OFDM and single-carrier frequency division multiplexing (SC-FDM) partition the system bandwidth into multiple orthogonal subcarriers, which are also commonly referred to as tones, bins, etc. Each subcarrier may be modulated with data. Modulation symbols may be sent in the frequency domain with OFDM and in the time domain with SC-FDM. The spacing between adjacent subcarriers may be fixed, and the total number of subcarriers may be dependent on the system bandwidth. The minimum resource allocation, called a resource block (RB), may be 12 consecutive subcarriers. The system bandwidth may also be partitioned into subbands. For example, a subband may cover multiple RBs. NR may support a base subcarrier spacing (SCS) of 15 KHz and other SCS may be defined with respect to the base SCS (e.g., 30 kHz, 60 kHz, 120 kHz, 240 kHz, etc.).
In NR, a synchronization signal block (SSB) is transmitted. In certain aspects, SSBs may be transmitted in a burst where each SSB in the burst corresponds to a different beam direction for UE-side beam management (e.g., including beam selection and/or beam refinement). The SSB includes a PSS, a SSS, and a two symbol PBCH. The SSB can be transmitted in a fixed slot location, such as the symbols 0-3 as shown in
Certain cloud-based services (such as split XR) may offload the computation or rendering of various content or data (e.g., video and/or audio streams) to servers with high-powered processors (e.g., graphics processing units (GPUs)). In certain cases, a head mount display (HMD) may be equipped with a wireless modem, which provides access to a wireless communication network (e.g., the wireless communication network 100) and enables a split XR session to be wirelessly streamed between the HMD and a server. For example,
A split XR session may have various traffic flow characteristics to provide an acceptable XR experience to the user (i.e., an immersive, realistic, and comfortable experience). For example, a split XR session may have a low-latency (e.g., 5-20 ms delay) between the UE and server, a highly reliable bit error rate (e.g., a packet error rate (PER) of less than or equal to 10−3), high downlink throughputs (100-600 Mbit/s or 1-2.5 Gbit/s or higher), and periodic low downlink throughputs (e.g., <1 Mbps). As used herein, split XR may include various low-latency cloud-based services such as cloud gaming, split rendering, split computation, virtual reality (VR), augmented reality (AR), mixed reality (MR), or live video streaming.
Under certain low-latency cloud-based services (such as split XR or live video streaming), the timelines of when packets for each of the clients (e.g., the UE 120) are generated at the server (e.g., the server 134) and delivered may affect the traffic capacity of certain wireless communication networks (e.g., 5G NR network or LTE network). For example, the server may send content to clients, which are camped on/served by the same cell (e.g., BS 110a of
Aspects of the present disclosure provide various apparatus and methods for providing staggered transmission and/or generation of client data based on wireless network information. For example, client traffic, for multiple clients, that shares network capacity, for example, at the same serving cell, may be spread out over time to enable a desirable number of users that can be served by a wireless communication network or provide desirable latency and/or downlink throughput for client data delivery at the clients. In certain aspects, the clients may send network information, such as cell identifiers of the serving cell, to the server, and the server may spread out transmission and/or generation of the client data based on the network information received from the clients. The network information may enable the server to map a client session to a specific network entity, such as a serving cell for the client, and the server may use the mapping between the client session and a specific network entity to determine a time at which content is delivered to the client. In a cluster of servers that provide content to clients, the servers may coordinate and adjust the transmission and/or generation of client data based on the network information associated with the clients. The various client data delivery schemes described herein may enable desirable latency and/or downlink throughputs at the clients and/or desirable user capacity for a wireless communication network, for example, at a specific serving cell.
The operations 500 may begin at 502, where a client (e.g., the UE 120) may obtain, from a modem (e.g., a cellular modem such as the modulators/demodulators in the transceivers 254a-254r), information associated with a wireless communication network. At 504, the client may transmit, to the server, at an application level, a first message including the information. Optionally, at 506, the client may transmit, to the server, a second message including client information (e.g., headset orientation information, prediction coefficients, controller input, etc.). At 508, the client may receive, from the server, data at a time determined based on the information. Optionally, the client may display the data as one or more video frames, for example, using a VR headset or other display device.
In aspects, the information sent to the server at 504 may enable the server to stagger or adjust the times at which the data is transmitted or generated for multiple clients, as further described herein with respect to
As used herein, an application level (or layer) may refer to a layer of a protocol stack in which the application layer is the topmost layer, and the remaining layers include a Packet Data Convergence Protocol (PDCP) layer, a Radio Link Control (RLC) layer, a Medium Access Control (MAC) layer, and a Physical (PHY) layer, in descending order. For example, the application level may be the level in which the payload for the protocol stack in a user plane is generated. The payload may be processed at various layers (e.g., the PDCP layer, RLC layer, MAC layer, and PHY layer) to enable transmission of the payload over wireless resources (e.g., frequency-time resources). In certain aspects, the application level may include Session Initiation Protocol (SIP) signaling used to establish, maintain, or terminate a real-time session between the client and server.
In certain aspects, obtaining the information at 502 may involve the client accessing the information via the modem. For example, the client may request the information from the modem, and the modem may provide the information to the client. In certain cases, an application programming interface (API) may be used to pass the information (such as cell identifier, beam identifier, etc.) from the modem to the client. In certain cases, an operating system of the UE (such as Android, Linux, Windows, iOS, macOS, etc.) may provide the API to access the modem at the application level via the client. That is, the operating system may serve as an intermediary between the client at the application level and modem at the hardware level. In certain aspects, the information may include various attributes of the client with respect to the wireless network. For example, the information may include at least one of a cell identifier of a serving cell (e.g., the BS 110a) of the client, a beam identifier of the serving cell, quasi-colocation (QCL) information associated with a reference signal of the serving cell, a medium access control (MAC) address of an access point serving the client, or a network identifier of a network serving the client.
The cell identifier may be an enhanced cell identity (ECI) or a global cell identification such as a cell identity used to unambiguously identify a cell within a wireless network (e.g., a public land mobile network (PLMN)). The beam identifier may be an indication of a downlink beam that the client uses to receive the data at 508. For example, the beam identifier may be an SSB identifier associated with an SSB. The QCL information may also be representative of the downlink beam that carries the data from the serving cell to the client. In certain cases, a reference signal (e.g., a channel state information reference signal (CSI-RS) or a DIVERS) may have a QCL relationship with another reference signal (e.g., an SSB or CSI-RS). The QCL information may include the reference signals, reference signal resources, or a QCL type included in a QCL configuration, such as a Transmission Configuration Indication (TCI) state. The network identifier may be, for example, a mobile country code (MCC), mobile network code (MNC), PLMN (which includes the MCC and MNC), a base station identifier (such as an eNodeB identifier or a gNodeB identifier), or a combination thereof.
In certain aspects, the wireless communication network may be a wireless wide area network (WWAN) (such as a 5G NR network or a LTE network) or a wireless local area network (WLAN) (such as a WiFi network). In aspects, the base station serving the client may be a wireless access point in a WLAN, and the information obtained at 502 may include the MAC address of the access point or a service set identifier (SSID) of a WLAN.
In certain aspects, the first message may be included in Session Description Protocol (SDP) signaling for various real-time transfer protocols (RTPs), such as session initiation protocol (SIP). That is, the first message may be an SDP message for SIP. In certain cases, the SDP message may include the information using an attribute field (e.g., “a=”). As an example, the attribute field may have the following format:
a=X-cell:<MNC> <MCC> <CID>
where X-cell is the name of the attribute field (other suitable names may be used), MNC is the mobile network code, MCC is the mobile country code, and CID is the cell identifier.
In certain cases, the client may report a wait time between when a frame is ready (e.g., received and decoded at the client) and when time the frame is consumed by the display or other display processing such as an asynchronous reprojection or asynchronous timewarp (ATW). In such cases, the server may adjust the transmission and/or generation times for client data across some or all of the clients by changing the order of render. In certain cases, the client may report a downlink time spread of packets (e.g., IP packets) arriving for a video frame. The downlink time spread may refer to the duration of time that it takes for a video frame to arrive at the client across multiple packets. In such cases, the server may adjust the transmission and/or generation times for the client based on such a time offset if possible.
As an example, the operations 500 may include the client transmitting, to the server, a third message including a wait time for processing the data at the client or a downlink time spread of packets arriving at the client and carrying the generated data, wherein the time is further determined based on the third message. In response to the third message, the client may receive, from the server, additional data at another time determined based on the information and the third message.
In certain aspects, the client may send updated information to the server, for example, when the client performs a handover to a target cell. As an example, the client may handover from a serving cell to a target cell, and based on the handing over, the client may transmit, to the server, updated information. In aspects, the updated information may include a cell identifier of the target cell, a beam identifier of the target cell, QCL information of the target cell, or a network identifier of the network serving the client. In certain aspects, the updated information may include a MAC address of an access point to which the client has transitioned.
In certain aspects, the server may be providing various cloud-based services to the client, such as split XR, split rendering, split computation, cloud gaming, live streaming, or the like. That is, the operations 500 may be implemented for a split XR session or cloud-gaming session. For example, the client information transmitted at 506 may include headset orientation information, prediction coefficients for the headset orientation, controller input, or other suitable processing input for generating the data. The data received at 508 may include one or more rendered video frames, where the server performs the rendering based on the client information. In aspects, the data received at 508 may include one or more rendered video frames (e.g., video frames for the right eye and video frames for the left eye), audio streams, and/or instructions for haptic feedback, and the client may display the one or more rendered video frames, play the audio streams, and/or provide the haptic feedback. As examples, the video frames may be displayed on an HMD in a split XR setting or television screen in a cloud gaming setting, the audio stream may be played through headset speakers, and the haptic feedback may vibrate a controller. The server may generate the data received at 508 based on various input provided by the client. That is, the data received at 508 may be generated based on the client information included in the second message at 506.
In certain cases, the data received at 508 may be instructions or data for an Internet-of-Things (IOT) device in which the server provides low-latency split computation based on sensor data measured by the IOT device. That is, the client information at 506 may include various sensor measurements.
In certain aspects, the operations 500 may be implemented for live streams of various content, such as live video streams. For example, the data received at 508 and displayed at 510 may be video frames of a live video stream.
The operations 600 may begin at 602, where the server may receive, from a plurality of clients, a plurality of messages. In aspects, at least two of the messages may include information associated with one or more wireless communication networks, and the information may correspond to the information at 502/504 of the operations 500. Optionally, at 604, the server may receive, from the clients by the server, a plurality of additional messages including client information (e.g., headset orientation information, prediction coefficients for the headset orientation, controller input, or other suitable processing input). Optionally, at 606, the server may, in response to the additional messages, generate client data for at least one of the clients based on the information and the client information. At 608, the server may transmit, to the at least one of the clients, client data, at one or more transmission occasions based on the information. In aspects, the information received at 602 may enable the server to stagger or adjust the times at which the data is transmitted and/or generated for multiple clients. In certain cases, information received at 602 may enable the server to spread out or distribute the downlink data of multiple clients over time in order to prevent or reduce overloading the network capacity and/or channel capacity of a specific serving cell or wireless network.
In certain aspects, the server may be a computer, computing device, or processing system that provides a service (e.g., split XR rendering of video frames, audio streams, and/or haptic feedback) to the client. In certain aspects, the server may be a program, process, or thread running on the computer, computing device, or processing system. For example, the server 134 may be a virtual instance of a processing system or application, which is hosted on another processing system. That is, the server 134 may be virtualized in an application container or a virtual machine running on the host processing system.
In certain aspects, the same server may provide cloud-based services to certain clients (for example, clients with the same cell identifier). In certain cases, a cluster of servers may provide the cloud-based services to multiple clients, as further described herein with respect to
The server may select the group of clients based on various attributes associated with the wireless communication networks. For example, the server may select the clients with the same cell identifier based on the information received at 602 and the additional information. As an example, selecting the group of clients may include selecting the group of clients with at least one of the same cell identifier of a serving cell of the group of clients, the same beam identifier of the serving cell, the same QCL information of the serving cell, the same MAC address of an access point, or the same network identifier of a network (e.g., a wireless communication network such as a PLMN) serving the group of clients.
In certain cases, multiple servers may provide cloud-based services to clients connected to the same network entity (e.g., the same serving cell or wireless network). In such cases, the servers may negotiate to agree on the times at which client data is generated (e.g., rendered at 606) or transmitted at 608. For example, the servers may determine the times at which client data is generated or transmitted based on the times when the sessions were established (e.g., a new session may set the times based on the available gap) or the round-trip latencies among the clients (e.g., the session with a lower latency may be shifted).
As an example, the operations 600 may further include the server obtaining additional information associated with the one or more wireless communication networks and additional clients. The server may select a group of clients among the clients and the additional clients based at least in part on the information and the additional information. For example, the server may identify clients connected to the same serving cell or wireless network (e.g., PLMN). The server may transmit, to another server, a schedule indicating the one or more transmission occasions or one or more processing occasions for the group of clients. The other server may use the schedule to generate or transmit data at the one or more transmission occasions or one or more processing occasions for the clients in the group served by the other server. In aspects, the schedule may be determined based on session establishment times of the group of clients or round-trip latencies of the group of clients. In certain cases, the server and the other server may be time synchronized with each other, for example via a time server, such as a precision time protocol (PTP) server or a network time protocol (NTP) server.
In certain cases, the generation of data at 606 or the transmission of data at 608 may be staggered or shifted based on the information received at 602. For example, the server may initiate generating of the client data at one or more processing occasions, timing of which is based at least in part on the information. Suppose, for example, a first client and a second client are connected to the same serving cell. The server may initiate generating the client data for the first client at a first processing occasion and initiate generating the client data for the second client at a second processing occasion. For example, the second processing occasion may be offset from the first processing occasion by a specific duration (e.g., 5 or 10 ms).
In certain aspects, the transmission of the client data at 608 may include the server initiating transmitting of the client data at the one or more transmission occasions, timing of which is based at least in part on the information. For example, the server may initiate generating the client data for the first client at a first transmission occasion and initiate generating the client data for the second client at a second transmission occasion. The second transmission occasion may be offset from the first transmission occasion by a specific duration (e.g., 5 or 10 ms).
In certain aspects, the information may include various attributes of the clients with respect to the wireless networks. For example, the information may include at least one of one or more cell identifiers of serving cells (e.g., the BS 110a) of the clients, one or more beam identifiers of the serving cells, QCL information associated with one or more reference signals of the serving cells, one or more MAC addresses of access points serving the clients, or one or more network identifiers of networks serving the clients.
In certain aspects, the messages received at 602 may be included in SDP signaling for various RTPs, such as SIP, for example, as described herein with respect to the operations 500. As an example, the messages received at 602 may be SDP messages for SIP.
In certain aspects, the server may receive updated information from a client, for example, when the client performs a handover to a target cell. When the server receives the updated information, the server may adjust the times at which client data is generated or transmitted. For example, the operations 600 may further include the server receiving, from one of the clients, updated information. In aspects, the updated information may include a cell identifier of the target cell, a beam identifier of the target cell, QCL information of the target cell, or a network identifier of the network serving the client. In certain aspects, the updated information may include a MAC address of an access point to which the client has transitioned. The server may initiate transmitting or generating of the client data at one or more processing occasions or one or more transmission occasions, timing of which is based at least in part on the updated information (e.g., the cell identifier). For example, suppose the client moves to a cell where there are no other clients being served by the server. In such a case, the server may concurrently generate or transmit the data for this client with other clients. In certain cases, when the server receives the updated information, the server may request or instruct another server to process the client data for the client. For example, the server may handover processing of the client data to another server in response to receiving the updated information.
In certain cases, the server may receive, from a client, a wait time between when a frame is ready (e.g., received and decoded at the client) and when time the frame is consumed by the display or other display processing such as an asynchronous reprojection or ATW. The server may adjust the transmission and/or generation times for client data across some or all of the clients based on the wait time. That is, the server may adjust the order at which client data is generated or transmitted based on the wait time reported by a client. For example, the wait time may enable the server to shift the client to a later processing occasion or transmission occasion in the order. In certain cases, the server may receive a downlink time spread of packets (e.g., IP packets) arriving for a video frame. In such cases, the server may adjust the transmission and/or generation times for the client based on such a time offset.
As an example, the operations 600 may further include the server receiving, from the clients, a plurality of additional messages including wait times for processing the generated data at the clients or downlink time spreads of packets arriving at the clients and carrying the generated data. The server may initiate generating or transmitting of additional client data at one or more processing occasions or at one or more transmission occasions, timing of which is based at least in part on the wait times or the downlink time spreads.
In certain aspects, the server may be providing various cloud-based services to the client, such as split XR, split rendering, split computation, cloud gaming, live streaming, or the like. That is, the operations 600 may be implemented for a split XR session or cloud-gaming session. For example, the client information received at 604 may include headset orientation information, prediction coefficients for the headset orientation, controller input, or other suitable processing input for generating the data. The data generated at 608 may include one or more rendered video frames, where the server performs the rendering based on the client information. In aspects, the data generated at 606 and transmitted at 608 may include one or more rendered video frames (e.g., video frames for the right eye and video frames for the left eye), audio streams, and/or instructions for haptic feedback, and the client may display the one or more rendered video frames, play the audio streams, and/or provide the haptic feedback. As examples, the video frames may be displayed on an HMD in a split XR setting or television screen in a cloud gaming setting, the audio stream may be played through headset speakers, and the haptic feedback may vibrate a controller. The server may generate the data received at 606 based on various input provided by the client.
In certain aspects, the operations 600 may be implemented for split computation applications. For example, the data generated at 606 and transmitted at 608 may be instructions or data for IOT device in which the server provides low-latency split computation based on sensor data measured by the IOT device. That is, the client information at 604 may include various sensor measurements, and the server may generate at 606 output based on the sensor measurements. The server may stagger or adjust the generation and/or transmission of the data for various clients based on the information received at 602.
In certain aspects, the operations 600 may be implemented for live streaming sessions of various content, such as live video streams. For example, the data transmitted at 608 may be video frames of a live video stream. The server may stagger or adjust the transmission of live streaming content to various clients based on the wireless received at 602.
In certain cases, the server 134 may stagger or adjust the generation of the client data for each of the UEs 120a, 120b depending on the wireless network information. For example, suppose the UEs 120a, 120b are connected to the same serving cell. The server 134 may identify that the UEs 120a, 120b are connected to the same serving cell based on the cell identifiers included in the wireless network information and mapped to the sessions of the UEs 120a, 120b. Based on the identification, the server 134 may generate the client data for the UE 120a at a first processing occasion and generate the client data for the UE 120b at a second processing occasion, where the first processing occasion is offset from the second processing occasion by a specific duration. In certain cases, for example, where the UEs 120a, 120b are connected to separate cells or separate wireless networks, the server 134 may generate the client data for the UEs 120a, 120b concurrently.
At 710a and 710b, the server 134 may transmit the client data to the UEs 120a, 120b through the access network 740. In certain cases, the server 134 may stagger or adjust the transmission of the client data for each of the UEs 120a, 120b depending on the wireless network information. For example, suppose the UEs 120a, 120b are connected to the same serving cell. The server 134 may transmit, at 710a, the client data for the UE 120a at a first transmission occasion and transmit, at 710b, the client data for the UE 120b at a second transmission occasion, where the first transmission occasion is offset from the second transmission occasion by a specific duration. In certain cases, for example, where the UEs 120a, 120b are connected to separate cells or separate wireless networks, the server 134 may transmit the client data, at 710a and 710b, for the UEs 120a, 120b concurrently.
Optionally, at 712a and 712b, the UEs 120a, 120b may display the client data as video frames. For example, at 712a, the UE 120a may display the video frames with a HMD from the generated client data. In certain cases, at 712b, the UE 120b display the video frames with a display of a smartphone or tablet.
In certain aspects, the server described herein may be part of a cluster of servers that provide various cloud-based services to clients. For example,
In certain aspects, the cluster of servers 800 may be time synchronized via a time server 812. In aspects, the timer server 812 may be a precision time protocol (PTP) server or a network time protocol (NTP) server. PTP may provide an accuracy in the range of microseconds or nanoseconds (e.g., 100 ns). NTP may provide an accuracy in the range of milliseconds or seconds (e.g., 1 ms). The time server 812 may provide a common clock source for the cluster of servers 800 in scheduling processing occasions and/or transmission occasions of client data to clients.
For example, suppose the first server 802 is serving a session for the first UE 120a, and the second server 804 is serving a session for the second UE 120b. Because the first UE 120a and second UE 120b are connected to the same serving cell, the servers 802, 804 may coordinate to stagger the generation and/or transmission of client data to these UEs. As an example, the first server 802 may generate or transmit the client data for the first UE 120a before the second server 804 generates or transmits the client data for the second UE 120b. Staggering the generation and/or transmission of client data for the UEs 120a, 120b may reduce the traffic load at the base station 110a and enable the base station 110a to server more users. Staggering the generation and/or transmission of client data for the UEs 120a, 120b may provide a desirable latency and/or downlink throughput for the cloud-based service at the UEs 120a, 120b.
In aspects, the server may distribute the transmission of client data over the various transmission occasions 906, 908, 910. In this example, the transmission occasions for clients from the same serving cell may be staggered such that the transmission occasions do not overlap with other, such as the first transmission occasion 906 and second transmission occasion 908 not overlapping for the UEs 120a, 120b, respectively. In certain cases, the transmission occasions for clients from the same serving cell may partially overlap with each other depending on the network or channel capacity of the RAN serving the clients. In certain aspects, the server may adjust or shift when client data is generated for specific clients at the server to provide the staggered transmission occasions. For example, the server may initiate the generation of client data for the UE 120a before initiating the generation of client data for the UE 120b to provide the staggered transmission occasions 906, 908. In certain cases, the server may adjust or shift when the client data is sent to specific clients to provide the staggered transmission occasions. For example, in live streaming applications, the server may send a burst of live streaming content to the UE 120a at the first transmission occasion 906 before sending a separate burst of live streaming content to the UE 120b at the second transmission occasion 908.
As depicted in the timing diagrams 904, the client data may arrive at the UEs via the respective base stations in a staggered or distributed fashion. For example, at a first occasion 912 corresponding to the first transmission occasion 906, the UE 120a may receive the client data via the base station 110a, and at a second occasion 914 corresponding to the second transmission occasion 908, the UE 120b may receive the client data via the base station 110a. For the base station 110b, the UE 120c may receive the client data at a third occasion 916 corresponding to the first transmission occasion 906, and the UE 120d may receive the client data at a fourth occasion 918 corresponding to the third transmission occasion 910.
While the examples depicted in
The RAN may forward the client data 1004 to the client, and this process may take a certain duration. The client may receive the client data 1004. In some cases, the client may perform processing on the client data such as decoding video frames or audio streams. In certain cases, the client may display the client data via a display, for example, at the display occasion 1010. The timeline, in this example, demonstrates that the server may shift the processing occasion 1006 or the transmission occasion 1008 to stagger, adjust, or distribute the arrival of client data at the RAN/UEs, for example, as described herein with respect to
While the various examples are described herein with respect to split XR applications to facilitate understanding, aspects of the present disclosure may also be applied to various other cloud-based or edge-based services, such as cloud-gaming, split rendering, split computation, and/or live streaming services.
The processing system 1202 includes a processor 1204 coupled to a computer-readable medium/memory 1212 via a bus 1206. In certain aspects, the computer-readable medium/memory 1212 is configured to store instructions (e.g., computer-executable code) that when executed by the processor 1204, cause the processor 1204 to perform the operations illustrated in
The processing system 1302 includes a processor 1304 coupled to a computer-readable medium/memory 1312 via the bus 1306. In certain aspects, the computer-readable medium/memory 1312 is configured to store instructions (e.g., computer-executable code) that when executed by the processor 1304, cause the processor 1304 to perform the operations illustrated in
In addition to the various aspects described above, specific combinations of aspects are within the scope of the disclosure, some of which are detailed below:
Aspect 1: A client for communicating, to a server, information associated with a wireless communication network, comprising: a modem; a memory; and a processor coupled to the memory and the modem, the processor and the memory being configured to: obtain, from the modem, information associated with a wireless communication network, transmit, to the server, at an application level, a first message including the information, and receive, from the server, data at a time determined based on the information.
Aspect 2: The client of Aspect 1, wherein the information includes at least one of: a cell identifier of a serving cell of the client; a beam identifier of the serving cell; quasi-colocation (QCL) information associated with a reference signal of the serving cell; a medium access control (MAC) address of an access point serving the client; or a network identifier of a network serving the client.
Aspect 3: The client according to any one of Aspects 1 or 2, wherein the first message is a session description protocol (SDP) message for session initiation protocol (SIP).
Aspect 4: The client according to any one of Aspects 1-3, wherein the processor and the memory are further configured to: transmit, to the server, a second message including a wait time for processing the data at the client or a downlink time spread of packets arriving at the client and carrying the data, wherein the time is further determined based on the second message; and receive, by the client from the server in response to the second message, additional data at another time determined based on the information and the second message.
Aspect 5: The client according to any one of Aspects 1-4, wherein the processor and the memory are further configured to: hand over from a serving cell to a target cell, and transmit, to the server, updated information indicating a cell identifier of the target cell based on the handing over.
Aspect 6: The client according to any one of Aspects 1-5, wherein: the processor and the memory are further configured to transmit, to the server, a second message including client information; and the apparatus further comprises a display configured to display the data as one or more rendered video frames, wherein the data comprises the one or more rendered video frames, and the data is generated based on the client information included in the second message.
Aspect 7: A server for transmitting client data, comprising: a memory; and a processor coupled to the memory, the processor and the memory being configured to: receive, from a plurality of clients, a plurality of messages, wherein at least two of the messages includes information associated with one or more wireless communication networks; and transmit, to at least one of the clients, client data, at one or more transmission occasions based on the information.
Aspect 8: The server of Aspect 7, wherein the processor and the memory are further configured to: obtain additional information associated with the one or more wireless communication networks and additional clients, select a group of clients among the clients and the additional clients based at least in part on the information and the additional information, and transmit, to the group of clients, the client data.
Aspect 9: The server of Aspect 8, wherein the processor and the memory are configured to select the group of clients with at least one of: a same cell identifier of a serving cell, a same beam identifier of the serving cell, a same quasi-colocation (QCL) information associated with a reference signal of the serving cell, a same medium access control (MAC) address of an access point, or a same network identifier of a network.
Aspect 10: The server according to any one of Aspects 8 or 9, wherein the processor and the memory are configured to obtain the additional information from a database or another server.
Aspect 11: The server according to any one of Aspects 7-10, wherein the processor and the memory are further configured to: obtain additional information associated with the one or more wireless communication networks and additional clients, select a group of clients among the clients and the additional clients based at least in part on the information and the additional information, and transmit, to another server, a schedule indicating the one or more transmission occasions for the group of clients, wherein the server and the other server are time synchronized with each other.
Aspect 12: The server of Aspect 11, wherein the schedule is determined based on session establishment times of the group of clients or round-trip latencies of the group of clients.
Aspect 13: The server according to any one of Aspects 7-12, wherein the processor and the memory are further configured to: initiate generating of the client data at one or more processing occasions, timing of which is based at least in part on the information.
Aspect 14: The server according to any one of Aspects 7-13, wherein the processor and the memory are further configured to initiate transmitting of the client data at the one or more transmission occasions, timing of which is based at least in part on the information.
Aspect 15: The server according to any one of Aspects 7-14, wherein the information includes at least one of: one or more cell identifiers of serving cells of the clients; one or more beam identifiers of the serving cells; quasi-colocation (QCL) information associated with one or more reference signals of the serving cells; one or more medium access control (MAC) addresses of access points serving the clients; or one or more network identifiers of networks serving the clients.
Aspect 16: The server according to any one of Aspects 7-15, wherein the messages are session description protocol (SDP) messages for session initiation protocol (SIP).
Aspect 17: The server according to any one of Aspects 7-16, wherein the processor and the memory are further configured to: receive, from one of the clients, updated information indicating a cell identifier of a serving cell, and initiate generating of the client data at one or more processing occasions, timing of which is based at least in part on the cell identifier.
Aspect 18: The server according to any one of Aspects 7-17, processor and the memory are further configured to: receive, from the clients by the server, a plurality of additional messages including wait times for processing the data at the clients or downlink time spreads of packets arriving at the clients and carrying the data, and initiate generating or transmitting of additional client data at one or more processing occasions or at one or more transmission occasions, timing of which is based at least in part on the wait times or the downlink time spreads.
Aspect 19: The server according to any one of Aspects 7-18, wherein the processor and the memory are further configured to: receive, from the clients, a plurality of additional messages including client information, and render, in response to the additional messages, one or more video frames for at least one of the clients based on the information and the client information, wherein the client data includes the rendered one or more video frames.
Aspect 20: A method of communicating, from a client to a server, information associated with a wireless communication network, comprising: obtaining, by a client from a modem, information associated with a wireless communication network; transmitting, from the client to the server, at an application level, a first message including the information; and receiving, by the client from the server, data at a time determined based on the information.
Aspect 21: The method of Aspect 20, wherein the information includes at least one of: a cell identifier of a serving cell of the client; a beam identifier of the serving cell; quasi-colocation (QCL) information associated with a reference signal of the serving cell; a medium access control (MAC) address of an access point serving the client; or a network identifier of a network serving the client.
Aspect 22: The method according to any one of Aspects 20 or 21, further comprising: handing over, by the client, from a serving cell to a target cell; and based on the handing over, transmitting, from the client to the server, updated information indicating a cell identifier of the target cell.
Aspect 23: A method of transmitting client data, comprising: receiving, from a plurality of clients by a server, a plurality of messages, wherein at least two of the messages includes information associated with one or more wireless communication networks; and transmitting, from the server to at least one of the clients, client data, at one or more transmission occasions based on the information.
Aspect 24: The method of Aspect 23, further comprising: obtaining additional information associated with the one or more wireless communication networks and additional clients; selecting a group of clients among the clients and the additional clients based at least in part on the information and the additional information; wherein transmitting the client data comprises transmitting, from the server to the group of clients, the client data.
Aspect 25: The method according to any one of Aspects 23 or 24, further comprising: obtaining additional information associated with the one or more wireless communication networks and additional clients; selecting a group of clients among the clients and the additional clients based at least in part on the information and the additional information; and transmitting, to another server, a schedule indicating the one or more transmission occasions for the group of clients, wherein the server and the other server are time synchronized with each other.
Aspect 26: The method according to any one of Aspects 23-25, further comprising initiating generating of the client data at one or more processing occasions, timing of which is based at least in part on the information.
Aspect 27: The method according to any one of Aspects 23-26, wherein the information includes at least one of: one or more cell identifiers of serving cells of the clients; one or more beam identifiers of the serving cells; quasi-colocation (QCL) information associated with one or more reference signals of the serving cells; one or more medium access control (MAC) addresses of access points serving the clients; or one or more network identifiers of networks serving the clients.
Aspect 28: The method according to any one of Aspects 23-27, further comprising: receiving, from one of the clients by the server, updated information indicating a cell identifier of a serving cell; and initiating generating of the client data at one or more processing occasions, timing of which is based at least in part on the cell identifier.
Aspect 29: The method according to any one of Aspects 23-28, further comprising: receiving, from the clients by the server, a plurality of additional messages including wait times for processing the data at the clients or downlink time spreads of packets arriving at the clients and carrying the data; and initiating generating or transmitting of additional client data at one or more processing occasions or at one or more transmission occasions, timing of which is based at least in part on the wait times or the downlink time spreads.
Aspect 30: The method according to any one of Aspects 23-29, further comprising: receiving, from the clients by the server, a plurality of additional messages including client information; and in response to the additional messages, rendering, by the server, one or more video frames for at least one of the clients based on the information and the client information, wherein the client data includes the rendered one or more video frames.
Aspect 31: A method of communicating, from a client to a server, information associated with a wireless communication network, comprising: obtaining, by a client from a modem, information associated with a wireless communication network; transmitting, from the client to the server, at an application level, a first message including the information; and receiving, by the client from the server, data at a time determined based on the information.
Aspect 32: The method of Aspect 31, wherein the information includes at least one of: a cell identifier of a serving cell of the client; a beam identifier of the serving cell; quasi-colocation (QCL) information associated with a reference signal of the serving cell; a medium access control (MAC) address of an access point serving the client; or a network identifier of a network serving the client.
Aspect 33: The method according to any one of Aspects 31 or 32, wherein the first message is a session description protocol (SDP) message for session initiation protocol (SIP).
Aspect 34: The method according to any one of Aspects 31-33, further comprising: transmitting, from the client to the server, a second message including a wait time for processing the data at the client or a downlink time spread of packets arriving at the client and carrying the data, wherein the time is further determined based on the second message; and in response to the second message, receiving, by the client from the server, additional data at another time determined based on the information and the second message.
Aspect 35: The method according to any one of Aspects 31-34, further comprising handing over, by the client, from a serving cell to a target cell; and based on the handing over, transmitting, from the client to the server, updated information indicating a cell identifier of the target cell.
Aspect 36: The method according to any one of Aspects 31-35, further comprising: transmitting, from the client to the server, a second message including client information; displaying, by the client, the data as one or more rendered video frames, wherein the data comprises the one or more rendered video frames, and the data is generated based on the client information included in the second message.
Aspect 37: A method of transmitting client data, comprising: receiving, from a plurality of clients by a server, a plurality of messages, wherein at least two of the messages includes information associated with one or more wireless communication networks; and transmitting, from the server to at least one of the clients, client data, at one or more transmission occasions based on the information.
Aspect 38: The method of Aspect 37, further comprising: obtaining additional information associated with the one or more wireless communication networks and additional clients; selecting a group of clients among the clients and the additional clients based at least in part on the information and the additional information; wherein transmitting the client data comprises transmitting, from the server to the group of clients, the client data.
Aspect 39: The method of Aspect 38, wherein selecting the group of clients comprises selecting the group of clients with at least one of: a same cell identifier of a serving cell, a same beam identifier of the serving cell, a same quasi-colocation (QCL) information associated with a reference signal of the serving cell, a same medium access control (MAC) address of an access point, or a same network identifier of a network.
Aspect 40: The method according to any one of Aspects 38 or 39, wherein obtaining the additional information comprises obtaining the additional information from a database or another server.
Aspect 41: The method according to any one of Aspects 37-40, further comprising: obtaining additional information associated with the one or more wireless communication networks and additional clients; selecting a group of clients among the clients and the additional clients based at least in part on the information and the additional information; and transmitting, to another server, a schedule indicating the one or more transmission occasions for the group of clients, wherein the server and the other server are time synchronized with each other.
Aspect 42: The method of Aspect 41, wherein the schedule is determined based on session establishment times of the group of clients or round-trip latencies of the group of clients.
Aspect 43: The method according to any one of Aspects 37-42, further comprising: initiating generating of the client data at one or more processing occasions, timing of which is based at least in part on the information.
Aspect 44: The method according to any one of Aspects 37-43, transmitting the client data comprises initiating transmitting of the client data at the one or more transmission occasions, timing of which is based at least in part on the information.
Aspect 45: The method according to any one of Aspects 37-44, wherein the information includes at least one of: one or more cell identifiers of serving cells of the clients; one or more beam identifiers of the serving cells; quasi-colocation (QCL) information associated with one or more reference signals of the serving cells; one or more medium access control (MAC) addresses of access points serving the clients; or one or more network identifiers of networks serving the clients.
Aspect 46: The method according to any one of Aspects 37-45, wherein the messages are session description protocol (SDP) messages for session initiation protocol (SIP).
Aspect 47: The method according to any one of Aspects 37-46, further comprising: receiving, from one of the clients by the server, updated information indicating a cell identifier of a serving cell; and initiating generating of the client data at one or more processing occasions, timing of which is based at least in part on the cell identifier.
Aspect 48: The method according to any one of Aspects 37-47, further comprising: receiving, from the clients by the server, a plurality of additional messages including wait times for processing the data at the clients or downlink time spreads of packets arriving at the clients and carrying the data; and initiating generating or transmitting of additional client data at one or more processing occasions or at one or more transmission occasions, timing of which is based at least in part on the wait times or the downlink time spreads.
Aspect 49: An apparatus, comprising: a memory comprising computer-executable instructions; one or more processors configured to execute the computer-executable instructions and cause the processing system to perform a method in accordance with any one of Aspects 20-48.
Aspect 50: An apparatus, comprising means for performing a method in accordance with any one of Aspects 20-48.
Aspect 51: A computer-readable medium comprising computer-executable instructions that, when executed by one or more processors of a processing system, cause the processing system to perform a method in accordance with any one of Aspects 20-48.
Aspect 52: A computer program product embodied on a computer-readable storage medium comprising code for performing a method in accordance with any one of Aspects 20-48.
The techniques described herein may be used for various wireless communication technologies, such as NR (e.g., 5G NR), 3GPP Long Term Evolution (LTE), LTE-Advanced (LTE-A), code division multiple access (CDMA), time division multiple access (TDMA), frequency division multiple access (FDMA), orthogonal frequency division multiple access (OFDMA), single-carrier frequency division multiple access (SC-FDMA), time division synchronous code division multiple access (TD-SCDMA), and other networks. The terms “network” and “system” are often used interchangeably. A CDMA network may implement a radio technology such as Universal Terrestrial Radio Access (UTRA), cdma2000, etc. UTRA includes Wideband CDMA (WCDMA) and other variants of CDMA. cdma2000 covers IS-2000, IS-95 and IS-856 standards. A TDMA network may implement a radio technology such as Global System for Mobile Communications (GSM). An OFDMA network may implement a radio technology such as NR (e.g. 5G RA), Evolved UTRA (E-UTRA), Ultra Mobile Broadband (UMB), IEEE 802.11 (Wi-Fi), IEEE 802.16 (WiMAX), IEEE 802.20, Flash-OFDMA, etc. UTRA and E-UTRA are part of Universal Mobile Telecommunication System (UMTS). LTE and LTE-A are releases of UMTS that use E-UTRA. UTRA, E-UTRA, UMTS, LTE, LTE-A and GSM are described in documents from an organization named “3rd Generation Partnership Project” (3GPP). cdma2000 and UMB are described in documents from an organization named “3rd Generation Partnership Project 2” (3GPP2). NR is an emerging wireless communications technology under development.
In 3GPP, the term “cell” can refer to a coverage area of a Node B (NB) and/or a NB subsystem serving this coverage area, depending on the context in which the term is used. In NR systems, the term “cell” and BS, next generation NodeB (gNB or gNodeB), access point (AP), distributed unit (DU), carrier, or transmission reception point (TRP) may be used interchangeably. A BS may provide communication coverage for a macro cell, a pico cell, a femto cell, and/or other types of cells. A macro cell may cover a relatively large geographic area (e.g., several kilometers in radius) and may allow unrestricted access by UEs with service subscription. A pico cell may cover a relatively small geographic area and may allow unrestricted access by UEs with service subscription. A femto cell may cover a relatively small geographic area (e.g., a home) and may allow restricted access by UEs having an association with the femto cell (e.g., UEs in a Closed Subscriber Group (CSG), UEs for users in the home, etc.). A BS for a macro cell may be referred to as a macro BS. A BS for a pico cell may be referred to as a pico BS. A BS for a femto cell may be referred to as a femto BS or a home BS.
A UE may also be referred to as a mobile station, a terminal, an access terminal, a subscriber unit, a station, a Customer Premises Equipment (CPE), a cellular phone, a smart phone, a personal digital assistant (PDA), a wireless modem, a wireless communication device, a handheld device, a laptop computer, a cordless phone, a wireless local loop (WLL) station, a tablet computer, a camera, a gaming device, a netbook, a smartbook, an ultrabook, an appliance, a medical device or medical equipment, a biometric sensor/device, a wearable device such as a smart watch, smart clothing, smart glasses, a smart wrist band, smart jewelry (e.g., a smart ring, a smart bracelet, etc.), an entertainment device (e.g., a music device, a video device, a satellite radio, etc.), a vehicular component or sensor, a smart meter/sensor, industrial manufacturing equipment, a global positioning system device, or any other suitable device that is configured to communicate via a wireless or wired medium. Some UEs may be considered machine-type communication (MTC) devices or evolved MTC (eMTC) devices. MTC and eMTC UEs include, for example, robots, drones, remote devices, sensors, meters, monitors, location tags, etc., that may communicate with a BS, another device (e.g., remote device), or some other entity. A wireless node may provide, for example, connectivity for or to a network (e.g., a wide area network such as Internet or a cellular network) via a wired or wireless communication link. Some UEs may be considered Internet-of-Things (IoT) devices, which may be narrowband IoT (NB-IoT) devices.
In some examples, access to the air interface may be scheduled. A scheduling entity (e.g., a BS) allocates resources for communication among some or all devices and equipment within its service area or cell. The scheduling entity may be responsible for scheduling, assigning, reconfiguring, and releasing resources for one or more subordinate entities. That is, for scheduled communication, subordinate entities utilize resources allocated by the scheduling entity. Base stations are not the only entities that may function as a scheduling entity. In some examples, a UE may function as a scheduling entity and may schedule resources for one or more subordinate entities (e.g., one or more other UEs), and the other UEs may utilize the resources scheduled by the UE for wireless communication. In some examples, a UE may function as a scheduling entity in a peer-to-peer (P2P) network, and/or in a mesh network. In a mesh network example, UEs may communicate directly with one another in addition to communicating with a scheduling entity.
The methods disclosed herein comprise one or more steps or actions for achieving the methods. The method steps and/or actions may be interchanged with one another without departing from the scope of the claims. In other words, unless a specific order of steps or actions is specified, the order and/or use of specific steps and/or actions may be modified without departing from the scope of the claims.
As used herein, a phrase referring to “at least one of” a list of items refers to any combination of those items, including single members. As an example, “at least one of: a, b, or c” is intended to cover a, b, c, a-b, a-c, b-c, and a-b-c, as well as any combination with multiples of the same element (e.g., a-a, a-a-a, a-a-b, a-a-c, a-b-b, a-c-c, b-b, b-b-b, b-b-c, c-c, and c-c-c or any other ordering of a, b, and c).
As used herein, the term “determining” encompasses a wide variety of actions. For example, “determining” may include calculating, computing, processing, deriving, investigating, looking up (e.g., looking up in a table, a database or another data structure), ascertaining and the like. Also, “determining” may include receiving (e.g., receiving information), accessing (e.g., accessing data in a memory) and the like. Also, “determining” may include resolving, selecting, choosing, establishing and the like.
The previous description is provided to enable any person skilled in the art to practice the various aspects described herein. Various modifications to these aspects will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other aspects. Thus, the claims are not intended to be limited to the aspects shown herein, but is to be accorded the full scope consistent with the language of the claims, wherein reference to an element in the singular is not intended to mean “one and only one” unless specifically so stated, but rather “one or more.” Unless specifically stated otherwise, the term “some” refers to one or more. All structural and functional equivalents to the elements of the various aspects described throughout this disclosure that are known or later come to be known to those of ordinary skill in the art are expressly incorporated herein by reference and are intended to be encompassed by the claims. Moreover, nothing disclosed herein is intended to be dedicated to the public regardless of whether such disclosure is explicitly recited in the claims. No claim element is to be construed under the provisions of 35 U.S.C. § 112(f) unless the element is expressly recited using the phrase “means for” or, in the case of a method claim, the element is recited using the phrase “step for.”
The various operations of methods described above may be performed by any suitable means capable of performing the corresponding functions. The means may include various hardware and/or software component(s) and/or module(s), including, but not limited to a circuit, an application specific integrated circuit (ASIC), or processor. Generally, where there are operations illustrated in figures, those operations may have corresponding counterpart means-plus-function components with similar numbering.
The various illustrative logical blocks, modules and circuits described in connection with the present disclosure may be implemented or performed with a general purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device (PLD), discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general-purpose processor may be a microprocessor, but in the alternative, the processor may be any commercially available processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
If implemented in hardware, an example hardware configuration may comprise a processing system in a wireless node. The processing system may be implemented with a bus architecture. The bus may include any number of interconnecting buses and bridges depending on the specific application of the processing system and the overall design constraints. The bus may link together various circuits including a processor, machine-readable media, and a bus interface. The bus interface may be used to connect a network adapter, among other things, to the processing system via the bus. The network adapter may be used to implement the signal processing functions of the PHY layer. In the case of a user terminal (see
If implemented in software, the functions may be stored or transmitted over as one or more instructions or code on a computer readable medium. Software shall be construed broadly to mean instructions, data, or any combination thereof, whether referred to as software, firmware, middleware, microcode, hardware description language, or otherwise. Computer-readable media include both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. The processor may be responsible for managing the bus and general processing, including the execution of software modules stored on the machine-readable storage media. A computer-readable storage medium may be coupled to a processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor. By way of example, the machine-readable media may include a transmission line, a carrier wave modulated by data, and/or a computer readable storage medium with instructions stored thereon separate from the wireless node, all of which may be accessed by the processor through the bus interface. Alternatively, or in addition, the machine-readable media, or any portion thereof, may be integrated into the processor, such as the case may be with cache and/or general register files. Examples of machine-readable storage media may include, by way of example, RAM (Random Access Memory), flash memory, ROM (Read Only Memory), PROM (Programmable Read-Only Memory), EPROM (Erasable Programmable Read-Only Memory), EEPROM (Electrically Erasable Programmable Read-Only Memory), registers, magnetic disks, optical disks, hard drives, or any other suitable storage medium, or any combination thereof. The machine-readable media may be embodied in a computer-program product.
A software module may comprise a single instruction, or many instructions, and may be distributed over several different code segments, among different programs, and across multiple storage media. The computer-readable media may comprise a number of software modules. The software modules include instructions that, when executed by an apparatus such as a processor, cause the processing system to perform various functions. The software modules may include a transmission module and a receiving module. Each software module may reside in a single storage device or be distributed across multiple storage devices. By way of example, a software module may be loaded into RAM from a hard drive when a triggering event occurs. During execution of the software module, the processor may load some of the instructions into cache to increase access speed. One or more cache lines may then be loaded into a general register file for execution by the processor. When referring to the functionality of a software module below, it will be understood that such functionality is implemented by the processor when executing instructions from that software module.
Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared (IR), radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium. Disk and disc, as used herein, include compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk, and Blu-ray® disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Thus, in some aspects computer-readable media may comprise non-transitory computer-readable media (e.g., tangible media). In addition, for other aspects computer-readable media may comprise transitory computer-readable media (e.g., a signal). Combinations of the above should also be included within the scope of computer-readable media.
Thus, certain aspects may comprise a computer program product for performing the operations presented herein. For example, such a computer program product may comprise a computer-readable medium having instructions stored (and/or encoded) thereon, the instructions being executable by one or more processors to perform the operations described herein, for example, instructions for performing the operations described herein and illustrated in
Further, it should be appreciated that modules and/or other appropriate means for performing the methods and techniques described herein can be downloaded and/or otherwise obtained by a user terminal and/or base station as applicable. For example, such a device can be coupled to a server to facilitate the transfer of means for performing the methods described herein. Alternatively, various methods described herein can be provided via storage means (e.g., RAM, ROM, a physical storage medium such as a compact disc (CD) or floppy disk, etc.), such that a user terminal and/or base station can obtain the various methods upon coupling or providing the storage means to the device. Moreover, any other suitable technique for providing the methods and techniques described herein to a device can be utilized.
It is to be understood that the claims are not limited to the precise configuration and components illustrated above. Various modifications, changes and variations may be made in the arrangement, operation and details of the methods and apparatus described above without departing from the scope of the claims.
Number | Date | Country | Kind |
---|---|---|---|
202041035136 | Aug 2020 | IN | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2021/042379 | 7/20/2021 | WO |