The invention relates to systems and methods for streaming video. More particularly, although not exclusively, the invention relates to systems and methods for streaming 360-degree video over mobile devices.
The widespread popularity of mobile devices, such as smartphones and wearable devices, and the rich variety of Internet applications available have greatly improved Internet experiences of users. Mobile devices account for a significant amount of Internet traffic. One recent application of mobile devices is immersive, interactive, and/or autonomous 360-degree video streaming over mobile devices. With the rapid advancement in computer vision and human-computer interaction, increasing the user's quality of experience (QoE) in 360-degree video streaming, e.g., using a head-mounted display (HMD), has become a hot topic in the field of multimedia experiences over mobile devices. Generally, to provide high-quality immersive experiences in 360-degree video streaming for users streaming 360-degree video over mobile devices, high resolutions and bitrates are needed for the 360-degree streaming. However, transmitting the content of an entire 360-degree video over a mobile network requires high bandwidth and, as the users will see only a small spatial area of the 360-degree video at a time, would lead to wasted bandwidth.
In a first aspect, there is provided a method for streaming a video, comprising: (a) determining a total bitrate for a segment of a video to be received; (b) predicting a viewpoint of a user (viewer) for the segment; and (c) determining bitrates for one or more tiles in the segment based on the determined total bitrate and the predicted viewpoint. Steps (a) and (b) may be performed in any order (including at least partly simultaneously). As used herein, a segment of a video may include or be formed by one or more frames (temporal slices) of the video; a tile of a segment of a video may refer to a part of the segment (spatial slices).
Optionally, step (a) and/or step (b) is performed after all tiles in a previous segment of the video have been received. The previous segment and the segment are preferably consecutive segments of the video.
Optionally, step (a) comprises determining the total bitrate based on adaptive optimization of a quality of experience function.
Optionally, the adaptive optimization of the quality of experience function is based on a deep reinforcement learning model. The deep reinforcement learning model may include a deep deterministic policy gradient algorithm or model.
Optionally, step (a) is performed by the deep deterministic policy gradient algorithm processing the playback states of the user (e.g., associated with the previous segment(s) of the video) to determine a total bitrate (e.g., mapped from quality factor) of the segment with the objective to optimize or maximize the quality of experience function.
Optionally, the playback states include one or more or all of: past K bitrate records, corresponding download time, predetermined tile bitrate set for the segment, current buffer length, and current freezing length. K is a number larger than 1. The playback states may include additional parameters.
Optionally, the quality of experience function includes one or more or all of the following: a factor associated with visual quality of viewed tiles in the previous segment, a factor associated with average quality variation between two segments, a playback freezing event (e.g., length) factor, and a future freezing risk factor.
Optionally, one or more or all of the factors of the quality of experience function (including one or more or all of the above mentioned factors) is weighted by a respective weighting factor. The respective weighting factors may be adjustable. For example, the weighting factor may be adjustable based on a user input (user preference, selection, etc.) and/or a content of the segment or the video.
Optionally, the method further comprising receiving the playback states of the user (e.g., associated with the previous segment(s) of the video).
Optionally, step (b) includes predicting a single-user viewpoint trace for the segment based on a received viewpoint trace of the user (e.g., associated with the previous segment(s) of the video).
Optionally, step (b) further includes predicting a cross-user viewpoint trace for the segment.
Optionally, the method further comprises receiving the viewpoint trace of the user (e.g., associated with the previous segment(s) of the video). The viewpoint trace of the user may comprise, at least, a head movement trace and an eye fixation trace.
Optionally, step (b) includes generating a viewpoint prediction map of the user for the segment.
Optionally, step (b) includes predicting head movement area (e.g., map) of the user for the segment and predicting eye fixation area (e.g., map) of the user for the segment.
Optionally, the prediction of the single-user viewpoint trace for the segment is performed by a recurrent neural network model (e.g., a long short term memory model) processing the received viewpoint trace of the user. The prediction of the head movement area (e.g., map) of the user for the segment and the eye fixation area (e.g., map) of the user for the segment may be performed using the same recurrent neural network model (e.g., a long short term memory model) or different recurrent neural network models (e.g., long short term memory models).
Optionally, the prediction of the cross-user viewpoint trace for the segment is performed based on a saliency map (SM) of known cross-user viewpoint traces associated with the segment.
Optionally, the predicted single-user viewpoint trace for the segment and the predicted cross-user viewpoint trace for the segment are both applied to predict the viewpoint of the user for the segment.
Optionally, the predicted single-user viewpoint trace for the segment is weighted with a weighting factor and the predicted cross-user viewpoint trace for the segment is weighted with a weighting factor. The two weighting factors may be the same or different. Optionally, one or both of the weighting factors may be adjustable.
The segment of the video may include, at least, a first portion and a second portion. In this case, optionally, the method includes: assigning a higher weighting to the predicted single-user viewpoint trace for the first portion of the segment and assigning a lower weighting to the predicted cross-user viewpoint trace for the first portion of the segment, and/or assigning a lower weighting to the predicted single-user viewpoint trace for the first portion of the segment and assigning a higher weighting to the predicted cross-user viewpoint trace for the first portion of the segment.
Optionally, step (c) comprises determining bitrates for all tiles in the segment.
Optionally, determining bitrates for all tiles in the segment comprises allocating bitrate to each of the tiles such that a sum of the bitrates of all tiles in the segment in substantially equal to the total bitrate.
Optionally, the determining comprises: allocating a lower bitrate to the tiles in area outside a predicted head movement area for the segment; and allocating a higher bitrate to the tiles in area inside a predicted head movement area for the segment.
Optionally, allocating a lower bitrate to the tiles in area outside a predicted head movement area for the segment comprises: allocating minimum bitrate to the tiles in area outside a predicted head movement area for the segment.
Optionally, allocating a higher bitrate to area inside a predicted head movement area for the segment, comprises: allocating a lower bitrate to the tiles in area outside the predicted eye fixation area for the segment; and allocating a higher bitrate to the tiles in area inside the predicted eye fixation area for the segment.
Optionally, the determining comprises: controlling bitrates between adjacent tiles of the segment to be within a difference threshold.
Optionally, the method further comprises: transmitting a request to receive the tiles of the segment in accordance with the determined bitrates for the tiles.
Optionally, the request includes an order indicator to receive the tiles of the segment with the largest determined bitrate first.
Optionally, the request includes an order indicator to receive the tiles of the segment in the order of decreasing bitrates.
Optionally, the method further comprises: receiving the tiles of the segment in accordance with the determined bitrates for the tiles.
Optionally, the method further comprises: receiving the tiles of the segment in the order of decreasing bitrates.
Optionally, the method further comprises: presenting (and/or streaming) the received segment to a user. This may include, e.g., displaying the received segment to the user.
Optionally, the method includes repeating steps (a) to (c) for two or more segments of the video so as to stream at least part of the video.
Optionally, the method includes repeating steps (a) to (c) for all segments of the video so as to stream the entire video.
Optionally, the method for streaming the video is performed with an electrical device, e.g., a mobile device, operably connected with a streaming server via a communication network. The communication network may include one or more communication links, which may be wired or wireless. The electrical device may include one or more (a combination) of: smartphones, wearable computing devices, desktop computer, mobile computer device, head mounted display/device (e.g., with motion tracking device), VR headset, set-top-box, digital signage/kiosk/projector, etc. The electrical device may include a client, e.g., a video player for playing and/or streaming a video. The streaming server may be a DASH over HTTP server. The streaming server may hold, relay, and/or store tile-based 360-degree video sequence.
Optionally, the streaming is live streaming of a video.
Optionally, the video is an immersive video. The video may be Generally-spherical video, spherical video, or part spherical video. In a preferred example, the video is a 360-degree video.
In a second aspect, there is provided a system with respective means for implementing the method of the first aspect. The respective means may serve one or more function in the method of the first aspects.
In a third aspect, there is provided a system streaming a video, comprising one or more controllers arranged to: (a) determine a total bitrate for a segment of a video to be received; (b) predict a viewpoint of a user for the segment; and (c) determine bitrates for one or more tiles in the segment based on the determined total bitrate and the predicted viewpoint. The one or more controllers may be arranged to perform (a) and (b) in any order (including at least partly simultaneously). As used herein, a segment of a video may include or be formed by one or more frames (temporal slices) of the video; a tile of a segment of a video may refer to a part of the segment (spatial slices). The one or more controllers may be arranged in the same device or arranged distributive across two or more operably-connected devices.
Optionally, the one or more controllers are arranged to perform (a) and/or (b) after all tiles in a previous segment of the video have been received. The previous segment and the segment are preferably consecutive segments of the video.
Optionally, the one or more controllers are arranged to determine the total bitrate based on adaptive optimization of a quality of experience function.
Optionally, the one or more controllers are arranged to adaptively optimize the quality of experience function based on a deep reinforcement learning model.
Optionally, the deep reinforcement learning model comprises a deep deterministic policy gradient algorithm.
Optionally, the one or more controllers are arranged to use the deep deterministic policy gradient algorithm to process the playback states of the user (e.g., associated with the previous segment(s) of the video) to determine a total bitrate (e.g., mapped from quality) of the segment with the objective so as to optimize or maximize the quality of experience function.
Optionally, the playback states include one or more or all of: past K bitrate records, corresponding download time, predetermined tile bitrate set for the segment, current buffer length, and current freezing length, wherein K is a number larger than 0. The playback states may include additional parameters.
Optionally, the quality of experience function includes one or more or all of the following factors: factor associated with visual quality of viewed tiles in the previous segment; factor associated with average quality variation between two segments; playback freezing event factor; and future freezing risk factor.
Optionally, one or more or all of the factors of the quality of experience function (including one or more or all of the above mentioned factors) is weighted by a respective weighting factor. The respective weighting factors may be adjustable. For example, the weighting factor may be adjustable based on a user input (user preference, selection, etc.) and/or a content of the segment or the video. The user input may be received at a input device operably connected with the one or more controllers.
Optionally, the one or more controllers are arranged to receive the playback states of the user (associated with the previous segment).
Optionally, the one or more controllers are arranged to predict a single-user viewpoint trace for the segment based on a received viewpoint trace of the user (associated with the previous segment(s) of the video) to perform (b).
Optionally, the one or more controllers are further arranged to a cross-user viewpoint trace for the segment to perform (b).
Optionally, the one or more controllers are arranged to receive viewpoint trace of the user (associated with the previous segment(s))
Optionally, the viewpoint trace of the user comprises a head movement trace and an eye fixation trace.
Optionally, the one or more controllers are further arranged to generate a viewpoint prediction map of the user for the segment.
Optionally, the one or more controllers are further arranged to predict head movement area (e.g., map) of the user for the segment and predict eye fixation area (e.g., map) of the user for the segment.
Optionally, the one or more controllers are arranged to predict the single-user viewpoint trace for the segment by using a recurrent neural network model (e.g., a long short term memory model) to process the received viewpoint trace of the user. In one example, the one or more controllers are arranged to predict head movement area (e.g., map) of the user for the segment using one recurrent neural network model (e.g., a long short term memory model) and to predict eye fixation area (e.g., map) of the user for the segment using another recurrent neural network model (e.g., another long short term memory model). In another example, the one or more controllers are arranged to predict head movement area (e.g., map) of the user for the segment and eye fixation area (e.g., map) of the user for the segment using the same recurrent neural network model (e.g., long short term memory model).
Optionally, the one or more controllers are arranged to predict the cross-user viewpoint trace for the segment is performed based on a saliency map (SM) of known cross-user viewpoint traces associated with the segment.
Optionally, the one or more controllers are arranged to apply both the predicted single-user viewpoint trace for the segment and the predicted cross-user viewpoint trace for the segment to predict the viewpoint of the user for the segment.
Optionally, the predicted single-user viewpoint trace for the segment is weighted with a weighting factor and the predicted cross-user viewpoint trace for the segment is weighted with a weighting factor. Optionally, one or both of the weighting factors may be adjustable.
The segment of the video may include, at least, a first portion and a second portion. In this case, optionally, the one or more controllers are arranged to perform (b) such that the first portion of the segment includes a higher weighting to the predicted single-user viewpoint trace and a lower weighting to the predicted cross-user viewpoint trace, and/or the second portion of the segment includes a lower weighting to the predicted single-user viewpoint trace and a higher weighting to the predicted cross-user viewpoint trace.
Optionally, the one or more controllers are arranged to determine bitrates for all tiles in the segment.
Optionally, the one or more controllers are arranged to allocate bitrate to each of the tiles such that a sum of the bitrates of all tiles in the segment in substantially equal to the total bitrate.
Optionally, the one or more controllers are arranged to: allocate a lower bitrate to the tiles in area outside a predicted head movement area for the segment; and allocate a higher bitrate to the tiles in area inside a predicted head movement area for the segment.
Optionally, the one or more controllers are arranged to: allocating minimum bitrate to the tiles in area outside a predicted head movement area for the segment.
Optionally, the one or more controllers are arranged to: allocating a lower bitrate to the tiles in area outside the predicted eye fixation area for the segment; and allocating a higher bitrate to the tiles in area inside the predicted eye fixation area for the segment.
Optionally, the one or more controllers are arranged to control the bitrates between adjacent tiles of the segment to be within a difference threshold.
Optionally, the one or more controllers are arranged to generate, for transmission, a request to receive the tiles of the segment in accordance with the determined bitrates for the tiles. The request may include an order indicator to receive the tiles of the segment with the largest determined bitrate first. The request may include an order indicator to receive the tiles of the segment in the order of decreasing bitrates.
Optionally, the one or more controllers are arranged to receive the tiles of the segment in accordance with the determined bitrates for the tiles. The one or more controllers may be arranged to receive the tiles of the segment in the order of decreasing bitrates.
Optionally, the system further comprises a display operably connected with the one or more controllers for presenting the received segment to the user.
Optionally, the one or more controllers are arranged to repeat (a) to (c) for two or more segments of the video so as to stream at least part of the video.
Optionally, the one or more controllers are arranged to repeat (a) to (c) for all segments of the video so as to stream the entire video.
Optionally, the one or more controllers is arranged in an electrical device (e.g., mobile device) operably connected with a streaming server via a communication network.
The communication network may include one or more communication links, which may be wired or wireless. The electrical device may include one or more (a combination) of: smartphones, wearable computing devices, desktop computer, mobile computer device, head mounted display/device (e.g., with motion tracking device), VR headset, digital signage/kiosk/projector, etc. The electrical device may include a client, e.g., a video player for playing and/or streaming a video. The streaming server may be a DASH over HTTP server. The streaming server may hold, relay, and/or store tile-based 360-degree video sequence.
Optionally, the one or more controllers is arranged in a streaming server operably connected with an electrical device (e.g., a mobile device, for streaming the video) via a communication network.
Optionally, the one or more controllers is arranged partly in the electrical device and partly in the streaming server.
Optionally, the streaming is live streaming of a video.
Optionally, the video is an immersive video. The video may be a generally-spherical video, a spherical video, or a part spherical video. In a preferred example, the video is a 360-degree video.
Other features and aspects of the invention will become apparent by consideration of the detailed description and accompanying drawings. Any feature(s) described herein in relation to one aspect or embodiment may be combined with any other feature(s) described herein in relation to any other aspect or embodiment as appropriate and applicable.
Embodiments of the invention will now be described, by way of example, with reference to the accompanying drawings in which:
The inventors of the present invention have devised, through research, experiments, and trials, that tile-based coding schemes or layer-based coding schemes can both be used in viewpoint-based streaming strategies to allocate different bitrates to the contents of different video regions. Compared with layer-based coding scheme, tile-based coding schemes are usually easier to use and less complex.
The inventors of the present invention have determined, through research, experiments, and trials, that tile-based ABR control can be regarded as a Markov decision process (MDP), which can be addressed through reinforcement learning (RL). In RL methods, appropriate actions, such as ABR control and viewpoint prediction, are adaptively taken to maximize a given QoE reward. In addition, bitrate allocation for each tile can benefit from game theory techniques, which assist in taking full advantage of the limited network bandwidth and in improving the user's QoE.
The inventors of the present invention have realized that existing ABR algorithm designs have achieved some QoE gains but are still subjected to challenges and shortcomings. First, the main characteristic of a mobile network is high variability in both link conditions and traffic characteristics. This inherent complexity of mobile networks has been overlooked in the design of existing ABR algorithms, making them not particularly suitable for 360-degree video streaming systems over mobile devices. Second, suitable metrics for QoE over mobile devices have not been fully considered in existing RL-based ABR methods. In practice, the video quality and its fluctuations directly affect the user QoE; however, the video bitrate cannot directly affect the video quality in Dynamic Adaptive Streaming over HTTP (DASH) QoE modelling. Playback freezing is another factor that has not been considered in the design of existing ABR algorithms. Finally, in addition to the application of ABR algorithms, 360-degree video streaming systems require interaction between the server and the clients since the user's current viewpoint information must be considered. Therefore, for regional quality control, it is necessary to consider a user's future viewpoint, meaning that 360-degree video streaming systems require viewpoint prediction capabilities. The inventors of the present invention have realized that viewpoint prediction relies on historical trace data or video content analysis, cross-user viewpoint prediction could further improve the prediction accuracy by allowing the viewpoint trajectories of multiple viewers to be correlated. Viewing behavior is correlated with the video content, and such correlation may help to predict future viewpoints. However, most existing studies have not focused on combining historical traces with video content information, thus preventing tile-level bitrate allocation from reaching the global optimum.
Against this background, the inventors of the present invention have devised, in one embodiment, a joint RL and game theory method for segment-level continuous bitrate selection and tile-level bitrate allocation for 360-degree streaming. In this embodiment, the tile-based 360-degree video sequences are stored on the DASH server. The head mount device (HMD) the playback state and the user's viewpoint traces to the controller, which then estimates the total requested quality/bitrate level for the upcoming segment and allocates the corresponding bitrate for every tile in this segment.
The inventors of the present invention have devised, through research, experiments, and trials, that streaming systems generally consist of streaming data, codecs, and players. Given the smoothness requirement for successive segments, fluctuating mobile network conditions, playback freezing avoidance, and other relevant factors, adaptive bitrate streaming (ABS) techniques have become a new technological trend for providing smooth and high-quality streaming. Some existing ABS systems can provide consumers with relatively high-quality videos while using less manpower and fewer resources, and thus have become predominant systems among video delivery systems. When an ABS system is working properly, end users can enjoy high-quality video playback without notable interruption. Among the various ABS strategies, DASH is often used because of its convenience and ease of system construction. In an ABS system, the original videos are divided into “segments” of a fixed playback length, each of which is encoded into multiple representations with different resolutions, bitrates, and qualities; then, ABS clients request segments with the appropriate representations in accordance with the playback state and the expected network conditions. First, because the DASH system is built on top of HTTP, the video packets encounter no difficulties passing through firewalls or network address translation (NAT) devices. Second, the DASH ABR decisions are mainly client driven; thus, all of the ABR logic resides on the client side, and playback does not require a persistent connection between the server and the client. Furthermore, the server is not required to maintain session state information for each client, thereby increasing scalability. Also, because the DASH system transmits its video data over HTIP, it can be easily and seamlessly deployed on and adapted to all existing HTIP facilities, including HTTP caches, servers, and scalable content delivery networks (CDNs). At present, demand for high-definition (HD) videos and ultra-high-definition (UHD) videos is continuing to increase. To enhance the performance of 360-degree streaming systems, the concepts of tiles and slices are used in High Efficiency Video Coding (HEVC) to split video frames; consequently, tile-based strategies, as shown in
The inventors of the present invention have devised, through research, experiments, and trials, that various bitrate allocation strategies have been developed for 360-degree streaming systems to improve streaming performance. For example, C L Fan et al, “Fixation prediction for 360° video streaming in head-mounted virtual reality,” in Proceedings of the 27th Workshop on Network and Operating Systems Support for Digital Audio and Video, 2017 has disclosed allocating more bitrate to the tiles inside the viewpoint area, which can be predicted with the help of the previous viewpoint or frame features. The streaming system disclosed in F. Qian et al “Flare: Practical viewport-adaptive 360-degree video streaming for mobile devices,” in Proceedings of the 24th Annual International Conference on Mobile Computing and Networking, 2018, is designed to combine adaptive QoE optimization models with new transmission protocols for efficient streaming. The streaming system ‘EPASS’ disclosed in Y. Zhang, et al “Epass360: QoE-Aware 360-degree video streaming over mobile devices,” IEEE Transactions on Mobile Computing, pp. 1-1, 2020 concentrates on the common scenarios in real-world 360-degree video streaming services in which users may specify various preferences for QoE metrics. In tile-based 360-degree video streaming schemes, the viewpoint prediction method is critical for lowering the bandwidth cost of unnecessary tiles. Any prediction error may lead to wasted bandwidth and reduced user QoE. The process of viewpoint prediction can be divided into two parts: head movement (HM) area prediction and eye fixation (EF) area prediction. HM area prediction determines the view region to be seen in one frame, and EF area prediction indicates the region of highest interest to humans within the view region. Accordingly, the HM areas should be predicted first to identify which tiles will be viewed by users. Then, given the predicted HM overlap area, the predicted EF area within the view region can be further estimated to help determine the bitrates of the tiles. For illustration, the HM and EF overlap areas in one segment are shown in
The 360-degree videos used for testing in this embodiment are encoded in the commonly used equirectangular projection format, and the 360-degree streaming performance is evaluated under dynamic viewpoint changes and bandwidth fluctuations. Accurate bitrate allocation for every tile in a segment enables high-quality video playback and avoids playback freezing. Meanwhile, as the long short-term dependency greatly influences the prediction task, an LSTM network is applied in this embodiment to model the RL-based segment-level bitrate selection process. The LSTM model is particularly effective for online time-series prediction over multiple sources and tasks.
In the tile-level bitrate allocation method of this embodiment, to address the case in which the user may occasionally exhibit an orientation inconsistency with the predicted HM area as a result of prediction error, the tiles outside the HM area are first allocated a fixed minimum bitrate. Thus, there will always be video content within the user's view region to ensure a certain user QoE during playback. Then, the tiles inside the HM area are allocated different selected rates depending on the predicted EF area, where these bitrates are chosen in accordance with the interest level of the tiles in the predicted EF area with the help of game theory methods. Furthermore, once the bitrates of all tiles in one segment are determined, in the method of this embodiment, the tiles with the maximum bitrate are requested first to ensure a smooth and high-quality playback experience. The bitrate difference between adjacent tiles is constrained not to exceed a certain level to avoid distinct borders observable by the user. Following the above rules, a suitable bitrate is selected for every tile inside and outside the view area, as shown in
Training a Reinforcement Learning (RL Model with a Freezing-Aware QoE Model
In one embodiment, a freezing-aware QoE model with the following features is formulated to evaluate the method of present embodiment. In the QoE model, Segi denotes segment i, where i is the video segment index. Tilei,j,k is the tile representation of segment Segi, where j is the jth tile of video segment i and k is the quality/bitrate level index for video segment i. rate(Tilei,j,k) is the corresponding video bitrate, and u(Tilei,j,k) is the video quality measured in terms of the weighted-to-spherically-uniform peak signal-to-noise ratio (WS-PSNR). The ABR decision is made after all tiles in one segment have been fully downloaded to choose a suitable video representation {rate(Tilei,j,k),u(Tilei,j,k)} for the next segment from the available set. For each segment Segi, the download time τi is calculated as follows:
where Σj=1N (rate(Tilei,j,k)) is the total bitrate of the tiles in segment Segi, also called the segment-level bitrate, which is selected from {rate(Tilei,j,k|k=1, 2, . . . , L}; T is the playback duration of segment i; and Ci is the average network capacity during the download of segment i.
Whereas Σj=1N (rate(Tilei,j,k)) is the total bitrate of the tiles in Segi, for every frame in Segi, only the HM area can be seen by the user. Therefore, xj∈[0,1] is introduced to represent whether Tilei,j,k is in the HM area, and the visual quality of the viewed tiles can be formulated as
where x∈{0,1} represents whether the tile is inside the view area, with xj=1 meaning that the tile Tilei,j,k is in the HM area; otherwise, xj=0. Furthermore, the average quality variation between two segments can be calculated as
where inVAR is the average intra-segment quality variation, i.e., the quality variation within the user's view. Let B(Segi) be the buffer length when starting to download segment Segi. When τi is less than or equal to B(Segi), the DASH user will have a smooth playback experience; when it is greater than B(Segi), playback freezing will occur, influencing the user QoE. The playback freezing length Fi is defined as
Fi=max{0,τi−B(Segi)}. (4)
A suitable buffer level can prevent playback freezing events in the case of a sudden drop in network throughput. When τi>B(Segi), the playback buffer becomes empty before the next segment is completely downloaded. When segment i+1 is fully downloaded, the buffer length for the next segment is T. When T<τi<B(Segi), the buffer length for the next segment decreases. When τi<T<B(Segi), the buffer length for the next segment increases.
Thus, the buffer length variation can be described as follows:
Accordingly, in this embodiment, the QoE of the tile-based 360-degree DASH streaming system is formulated based on several factors: the visual quality of the viewed tiles in the received segment, the quality variations between two segments, the occurrence of playback freezing events, and the future freezing risk. To derive an RL policy that maximizes the user QoE, in this embodiment, the abovementioned QoE factors are considered and e a QoE reward function for use in the RL-based ABR decision-making method are proposed. In this embodiment, the WS-PSNR is applied as the instantaneous quality metric for a video sequence.
In addition, the future freezing risk FFRi is introduced to avoid excessively short buffer lengths:
FFRi=max(0,Bthresh−B(Segi)), (6)
where Bthresh represents the risk of playback freezing. The value of Bthresh is calculated as follows:
The DASH QoE function is defined in the form of a weighted sum:
in which the weights ωu, ωf and ωffr are used to balance the different QoE metrics. Thus, they also represent the trade-off between high video quality, a constant quality level, and smooth playback. The desired operating point might depend on several factors, including user preferences and video content. For the parameter tuning strategy, the strategy disclosed in Y. Zhang et al “DRL360: 360-degree video streaming with deep reinforcement learning,”, IEEE INFOCOM 2019—IEEE Conference on Computer Communications, April 2019, pp. 1252-1260 is applied. To provide a high user QoE, the bitrate/quality level, for all segments should be determined via the ABR scheme to maximize the total QoE objective:
ABR Control with Viewpoint Prediction Maps
Viewpoint Prediction Method
Understanding the viewing behavior of a user/viewer is important for an ABR algorithm to make future decisions. A user's viewing behavior mainly depends on the current viewing traces and is also related to the video content. In this embodiment, a viewpoint prediction method based on SU viewpoint traces and a cross-user viewpoint model is applied to capture the spatial and temporal behavior of users in order to determine the HM and EF areas for every segment. The SU viewpoint traces are predicted utilizing an LSTM network to determine the HM and EF areas for the user. Because a user's viewing behavior mainly depends on the current viewing traces, an LSTM network can model the user's behavior and generate a precise prediction. The model parameters are denoted by θ, and the LSTM model for predicting the EF trace in the time dimension is formulated as follows:
EF′t+1=LSTM(EF0, . . . ,EFt;θEF), (10)
where θEF denotes the parameters used in predicting the EF area. The frequency at which consecutive images appear on the HMD display is expressed in terms of the number of frames per second (FPS or frame rate, denoted by NFPS). The predicted EF area in one frame can be recurrently fed into the LSTM model to obtain NFPS EF areas to generate the predicted EF area for one segment.
Similarly, the future HM trace at the segment level can be predicted with an LSTM model, as follows:
HM′n+1=LSTM(HM0, . . . ,HMn;θHM), (11)
where θHM denotes the parameters used in predicting the HM area. Because different users may have different viewing behaviors, such as watching videos without much HMD movement or moving the HMD frequently to explore the video content, in order to further decrease the prediction error, an SM prediction method is introduced to model cross-user viewpoint traces. If the predicted SU trace is driven by the video content, then the SM method, such as the one disclosed in M. Xu at al “Predicting head movement in panoramic video: A deep reinforcement learning approach,” IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 41, no. 11, pp. 2693-2708, November 2019, will yield more precise prediction results. Otherwise, the SU results will work better. In this embodiment, to benefit from the advantages of both the SU and SM methods, higher weights ϵ1 and ϵ2 are set for the SU prediction results in the first half of each segment. In the second half of each segment, higher weights ϵ1 and ϵ2 are assigned to the SM prediction results. The final HM area FNHM′i+1 and EF area FNEF′i+1 are predicted via the following equations:
FNHM′i+1=ϵ1SUHM1′i+1+(1−ϵ1)SMHM1′i+1+(1−ϵ2)SUHM2′i+1+ϵ2SMHM2′i+1, (12)
FNEF′i+1=ϵ1SUEF1′i+1+(1−ϵ1)SMEF1′i+1+(1−ϵ2)SUEF2′i+1+ϵ2SMEF2′i+1, (13)
where {SUHM1′i+1,SUHM2′i+1}, {SUEF1′i+1,SUEF2′i+1}, {SMHM1′i+1,SMHM2′i+1}, and {SMEF1′i+1,SMEF2′i+1} represent the HM/EF areas predicted using the SU/SM methods in the first/second halves of each segment. For the HM area, the weights ϵ1 and ϵ2 are calculated via the following equations:
ϵ1=max{PPSU1′i+1,HM,PPSM1′i+1,HM}, (14)
ϵ2=max{PPSU2′+i+1,HM,PPSM2′i+1,HM}, (15)
where {PPSU1′i+1,HM,PPSM1′i+1,HM} are the prediction precisions in the first half of each segment using the SU and SM methods, respectively, and {PPSU2′i+1,HM, PPSM2′i+1,HM} are the corresponding prediction precisions in the second half of each segment. For the EF area, the weights ϵ1 and ϵ2 are calculated via the following equations:
ϵ1=max{PPSU1′i+1,EF,PPSM1′i+1,EF}, (16)
ϵ2=max{PPSU2′i+1,EF,PPSM2′i+1,EF}, (17)
where {PPSU1′i+1,EF, PPSM1′i+1,EF} are the prediction precisions in the first half of each segment using the SU and SM methods, respectively, and {PPSU2′i+1,EF, PPSM2′i+1,EF} are the corresponding prediction precision in the second half of each segment.
Segment-Level RL-Based Bitrate Selection
An algorithm for joint RL- and cooperative-bargaining-game-based bitrate selection is provided in this embodiment. In this embodiment, the deep deterministic policy gradient (DDPG) algorithm is used as the basis for the RL-based ABR decision algorithm for segment bitrate control. The DDPG framework for RL-based DASH ABR decision-making is illustrated in
Input State: After downloading each segment i, the DASH agent receives the playback state si=(, , rate(Segi), B(Segi), Fi) as its input.
Action Mapping: When segment i is completely downloaded (e.g., in time step i), the DASH learning agent generates an output action ai that determines the quality level Ui+1=(ratei+1,u(Tilei+1)) of the next segment to be downloaded, ai∈[bitratemin,bitratemax,], corresponding to the available bitrate level for the video segment. Considering the bitrate limits and discrete quality levels, to make more precise ABR decisions, the action is mapped to the available bitrate level to improve the accuracy of each choice.
Reward: Given a state and an action, the DASH MDP reward function ri is defined as follows:
ri(si,ai)=QoEi. (18)
The goal of the agent is to maximize the expected return from each state si. The action value Qπ(s, a) is the expected return when action a is selected in state s following policy π:
Qπ(s,a)=E[Ri|si=s,a]. (19)
The optimization algorithm presented in R. Hong et al “Continuous bitrate & latency control with deep reinforcement learning for live video streaming,” in Proceedings of the 27th ACM International Conference on Multimedia, 2019 is used to learn the RL network parameters, with base learning rates of 10−3 and 10−4 for the actor and critic networks, respectively. The discount factor γ used for training is 0.99. The Ornstein-Uhlenbeck process is utilized to ensure the exploratory behavior of the actor network.
Tile-Level Cooperative-Bargaining-Game-Based Bitrate Selection
Once the bitrate for the next segment has been selected, tile-level bitrate allocation is then performed in accordance with the view prediction results. An algorithm is constructed for this purpose as follows. A cooperative bargaining game represents a situation in which the players have similar motivations to cooperate but have different preferences and conflicts of interest over how to cooperate and thus is suitable for describing this task, in which the tiles in different positions in the same segment bargain over the available bitrate. The objective of such a bargaining game is to reach a beneficial agreement among the players. Consider a bargaining game with N players; if an agreement is reached, players 1, 2, . . . , N will receive utilities u1, u2, . . . , uN, respectively. The utility vector {right arrow over (u)}=(u1, u2, . . . , uN)T is one entry in the set of all possible utility combinations, which is denoted by U=({right arrow over (u)}1, {right arrow over (u)}2, . . . , {right arrow over (u)}m),m∈[0,Ω], where Ω is the number of possible utility combinations. In addition, dj denotes the disagreement of player j, and the disagreement vector d=(d1, d2, . . . , dN)T is defined to ensure a minimum utility for each player. Each element in the Nash bargaining solution (NBS, a possible utility combination) must be larger than the disagreement of the corresponding player; otherwise, the bargaining game will fail.
If U is non-empty, convex, closed and bounded, then the cooperative bargaining game with N players can be denoted by h(U, d), and the NBS can be obtained by means of the following theorem.
Theorem 1: The NBS {right arrow over (u)}opt=(u1,opt, u2,opt, . . . , un,opt)T is the unique bargaining solution for h(U, d) if the following equation is satisfied:
where {right arrow over (u)}opt=(u1,opt,u2,opt, . . . , un,opt)T and u1,opt≥d1,u2,opt≥d2, . . . , un,opt≥dN.
In addition, there are several axioms concerning the NBS, as follows:
i) Individual rationality. uj,opt≥dj for all j.
ii) Feasibility uopt∈U.
iii) Pareto optimality of uopt.
iv) Independence of irrelevant alternatives. If uopt∈V⊂U is the NBS of h(V, d), then the NBS of h(U, d) is also uopt.
v) Independence of linear transformations. Let uopt be the solution to h(U, d), and let g be a linear transformation function.
Suppose that Ug=g(U) and dg=g(d); then, the solution to h(Ug,dg) is g(uopt).
vi) Symmetry. If U is invariant under all exchanges of users, then all elements of uopt are equal, i.e., u1,opt=u2,opt= . . . =un,opt.
Axioms (i)-(iii) guarantee the existence and efficiency of the NBS, while axioms (iv)-(vi) guarantee the fairness of the solution. The symmetry axiom guarantees equal priority of the players during the bargaining game when the players have the same utility function and disagreement. It should be noted that when the elements of the disagreement vector d are set to equal values, the NBS will be equal to an optimized solution that maximizes the average utility when the channel conditions for all users are the same. Based on bargaining game theory and the NBS, the optimal bandwidth allocation for multiple tiles in a 360-degree streaming system is modelled as a Nash bargaining game and thus can be solved by the NBS. In the tile-level bitrate allocation algorithm of this embodiment, the utility is the expected quality for the next segment, and the maximization problem is formulated as a bargaining game as follows:
where Cj is the number of header bitrates, ρj and kj are the utility parameters, and mj denotes the mean average deviation (MAD) of the average residuals between the original and reconstructed segments. These parameters are given by the server side before the start of transmission. dj is obtained via the following equation:
where rate(Tilei,j,1) is the bitrate of tile j in segment i with quality level 1 and rate(Tilei,j,2) is the bitrate of tile j in segment i with quality level 2. The set {ISHMj,ISEFj} represents whether tile j is located in the predicted EF area. If tile j is located in the predicted EF area, then {ISHMj, ISEFj}={0,1}; otherwise, {ISHMj, ISEFj}={1,0}. The utility set U is first proven to be a convex set, as follows.
The utility set U is a convex set: The utility set U is a convex set if and only if for any utility points X=(X1, . . . , XN)=(u1(x), . . . , uN(x))∈U and Y=(Y1, . . . , YN)=(u1(y), . . . , uN(y))∈U, the following condition is satisfied:
θX+(1−θ)Y∈U, (24)
where 0≤θ≤1 and x=(x1, x2, . . . , xN) and y=(y1, y2, . . . , yN) are bitrate allocation strategies that satisfy the total bitrate constraints. Based on the utility function,
and
(θXj+(1−θ)Yj)ρjkjmj+Cj=θxj+(1−θ)yj>Rj0. (26)
Therefore, θX+(1−θ)Y∈U; thus, the feasible utility set U is convex.
Determination of the NBS: Because U is a convex set, Equation (21) can be converted into the following format:
The optimal solution to Equation (27) can be obtained by solving the Karush-Kuhn-Tucker (KKT) conditions. Let λ and nj (j=1, . . . ,N) be the Lagrange multipliers; then the following Lagrangian function L(rate(Tilei,j,k),λ, nj) can be obtained:
The KKT conditions for Equation (28) can be written as
By substituting the utility function (22) into Equation (29(vii)), this condition can be rewritten as
According to Equation (29(vi)), there must be a solution rate j that is larger than rate(dj), such that dj−u(Tilei,j,k)<0 and nj=0:
As shown in Equation (29(v)),
Δ can be calculated as
Therefore, the NBS, i.e., teopt=(rate(Tilei,1,k)opt, . . . , rate(Tilei,N,k)opt)T, can be obtained as
where rateopt={ratej,opt}, j=1, . . . , N, is the NBS for Equation (21). Based on the NBS, in the method of this embodiment, the bitrate list for the current tile set is used as a look-up table to find an appropriate bitrate that is close to the NBS for every tile in the segment.
Implementation
The method of the above embodiment is implemented on the mobile device client and the streaming server to achieve precise viewpoint prediction and bitrate allocation for the requested tiles. The mobile client receives the requested 360-degree video segments and the updated cross-user viewpoint prediction map generated via the SM method. By jointly considering the SM and SU viewpoint prediction results, the segment- and tile-level bitrates are allocated with the method. After bitrate allocation, the client sends the ordered tile requests and the recorded user viewpoint traces to the server to be used to update the cross-user viewpoint prediction map using the SM method.
Mobile device client and streaming server: In the evaluation of the performance of the method of the above embodiment, all experiments were performed on an Ubuntu (Version 16.04) system with a GTX 2080 Ti GPU, an i7-8700K CPU, and 32 GB of memory. The platform was modified to support the testing of all ABR algorithms requesting video segments from the DASH client side. In the experiment, the Google Chrome browser was used as the mobile device client, and an Apache web server (version 2.4.7) was modified with the software dash.js (version 3.0.0) to serve as a DASH server running on the same machine as the client. The DASH client was configured to have a maximum playback buffer capacity of 10 seconds.
Videos and viewpoint traces: For the experiments, 360-degree video contents were collected from a dataset that includes videos playing both fast and slow. The corresponding user viewpoint traces were also provided by this dataset, with a 200-ms granularity. Videos and their corresponding viewpoint traces were randomly selected to form the training set, and the remaining videos were used as the test set for evaluation. All videos were encoded by Kvazaar with HEVC under rate control mode and assigned bitrates of 0.8 Mbps, 1.2 Mbps, 2 Mbps, 3 Mbps, 4 Mbps, 8 Mbps, 12 Mbps, 20 Mbps and 36 Mbps (8192×4096). Thus, each video was encoded to generate nine bitrate representations, i.e., NR=9. Then, the videos were divided into segments of one second, two seconds, and three seconds in length using MP4 box to investigate the influence of the segment length on 360-degree video streaming. In addition, for each segment, the frames were split into 6×6, 12×6, and 12×12 tile configurations to investigate the influence of the tile configuration on 360-degree video streaming. The viewpoint angle was set to be the commonly used viewpoint angle for mobile devices of 100×100 degrees.
Bandwidth profiles: The method of the above embodiment was evaluated using both real and synthetic bandwidth profile datasets. For the real bandwidth dataset, five hundred bandwidth profiles of at least 320 seconds in length under various network conditions were randomly selected and scaled up from the typical HSDPA bandwidth dataset and 5G dataset. Two hundred of the generated bandwidth profiles were randomly selected to train the RL-based ABR model, and the rest were used for testing. The values of the selected bandwidth profiles fell between 0.7 Mbps and 20 Mbps. For the synthetic bandwidth dataset, bandwidth profiles classified into four types were used for evaluation; the four types of profiles are depicted in
Algorithms for comparison: The following five existing tile-based 360-degree ABR control algorithms were chosen for comparison with the 360-degree streaming method in the above embodiment of the invention:
Performance Evaluation
The performance of the method of the above embodiment is evaluated relative to that of various existing methods for multiple 360-degree videos under a variety of real network traces. Both the prediction performance for the HM and EF overlap areas and the ABR performance are evaluated.
Viewpoint Prediction Performance
To quantify the viewpoint prediction performance during the playback of 360-degree video contents under different network conditions, the average prediction precision and prediction error of the SU, SM, and the above-proposed viewpoint prediction methods were evaluated. A prediction method with a low prediction precision or a high prediction error will cause low-quality areas to be rendered to the user. The average prediction precision is represented by the intersection over union (IoU), which can be obtained by dividing the overlap area by the union area between the predicted and ground-truth view areas with a view angle of 100°×100°. The performance of the viewpoint prediction methods was measured without considering bandwidth variations. The prediction error represents the situation in which necessary tiles for view rendering are assigned the lowest bitrate as a result of the uncertainty of the prediction method. Accordingly, the prediction error is defined as the percentage of lowest-bitrate tiles rendered in the user's view area in one segment.
The average prediction precision and the prediction error of all viewpoint prediction algorithms were measured at five timestamps in every segment. For every frame in the segment, the precision value was obtained after prediction, and the prediction error was calculated after processing the whole segment. The average prediction results at timestamps m=0, . . . , 1 of the SU, SM, and the proposed algorithms of the above embodiment are shown in
Effectiveness of Continuous Bitrate Control
Once the viewpoint prediction results have been generated, the download bitrate for the tiles in the next segment should be determined and allocated. The segment-level bitrate is determined by the proposed RL-based ABR algorithm, and the tile-level bitrates are chosen based on the predicted HM and EF areas and the selected segment-level bitrate following the allocation strategy described above. Here, the effectiveness of continuous segment-level bitrate control and game-theory-based tile-level bitrate allocation is evaluated under real bandwidth profiles. The performance is evaluated in terms of the average effective viewpoint WS-PSNR (ePSNR) and the average effective bitrate (eBitrate) under various experimental conditions. The ePSNR is the average WS-PSNR of tiles used to render the view area, and the eBitrate represents the actual downloaded bitrates of the tiles for rendering. First, stable network conditions (6 Mbps) were used to test the influence of different viewpoint prediction methods and tile configuration schemes on 360-degree streaming ABR control, as shown in
QoE Gain of the Proposed Method
To further compare and analyze each algorithm, the user QoE gains in terms of different QoE objectives were further evaluated based on the real bandwidth profile dataset. The detailed QoE gains in terms of different QoE objectives are shown in the table of
Performance Evaluation on Synthetic Bandwidth Datasets
The performance evaluation conducted on synthetic bandwidth datasets is also presented. The detailed QoE metrics under the different cases of synthetic mobile network profiles are presented in the tables of
Ablation Study on Real Bandwidth Datasets
The results of an ablation study for which the normalized QoE (minimum is set to 0.1, and maximum is set to 0.9) results under different QoE objectives are shown in
Remarks
Existing bitrate adaptation algorithms have difficulty providing smooth and steady video quality for 360-degree streaming users on mobile devices under highly dynamic network conditions because the viewpoint prediction and bitrate adaptation methods are based on instantaneous states rather than full consideration of historical data. To guarantee a high QoE in terms of different objectives to ensure both smoothness and steadiness, a hybrid control scheme is proposed in the above embodiment for a dynamic adaptive 360-degree streaming system, which can efficiently make viewpoint prediction and ABR decisions under various network and user behavior conditions to optimize various QoE objectives for the user. The proposed method leverages RL for continuous segment-level bitrate control and game theory for tile-level bitrate allocation while fully considering both temporal viewpoint variations and spatial video content variations. Experimental evaluations of the proposed scheme show that the proposed tile-based 360-degree streaming system can achieve improved QoE gains in diverse scenarios on mobile devices.
Exemplary Hardware
The controller 1900 includes a processor 1902 and a memory 1904. The processor 1902 may be formed by one or more of: CPU, MCU, controllers, logic circuits, Raspberry Pi chip, digital signal processor (DSP), application-specific integrated circuit (ASIC), Field-Programmable Gate Array (FPGA), or any other digital or analog circuitry configured to interpret and/or to execute program instructions and/or to process information and/or data. The memory 1904 may include one or more volatile memory unit (such as RAM, DRAM, SRAM), one or more non-volatile memory unit (such as ROM, PROM, EPROM, EEPROM, FRAM, MRAM, FLASH, SSD, NAND, and NVDIMM), or any of their combinations.
The processor 1902 includes a machine learning processing module 1902A and a non machine learning processing module 1902B. The machine learning processing module 1902A is arranged to process data using one or more machine learning processing models (e.g., reinforcement learning model such as DDPG model, recurrent neural network model such as LSTM model). The non machine learning processing module 1902B is arranged to process data without using machine learning processing models or methods. For example, the non machine learning processing module 1902B may be used to perform various data processing such as filtering, segmenting, thresholding, averaging, smoothing, padding, transforming, scaling, etc. The processor 1902 also includes a training module 1902C arranged to train the machine learning processing model(s), such as the model(s) in the memory 1904.
The memory 1904 includes a machine learning processing model store 1904A arranged to store one or more machine learning processing models to be used by the processor 1902 for processing data. The one or more machine learning processing models may include the reinforcement learning model such as the DDPG model and the recurrent neural network model(s) such as LSTM model(s) for HM and EF predictions. In one example, only one machine learning processing model is stored. In another example, multiple machine learning processing models are stored. The machine learning processing model(s) in the machine learning processing model store 1904A may be trained, re-trained, or updated as needed—new or modified machine learning processing model(s) may be obtained by training or by data transfer (loading into the controller 1900). The memory 1904 also includes data store 1904B and instructions store 1904C. The data store 1904B may store: training/validation/test data for training/validating/testing the machine learning processing model(s), data received from external devices such as a streaming server, etc. The training/validation/test data used to train/validate/test the respective machine learning processing model(s) may be classified for use in the training/validating/testing different machine learning processing models. The instructions store 1904C stores instructions, commands, codes, etc., that can be used by the processor 1902 to operate the controller 1900.
General Video Streaming Method
As shown in
In step 2102, the total bitrate is determined/predicted based at least in part on the received playback states (e.g., associated with a previous video segment consecutive with the video segment). The determination may be based on adaptive optimization of a quality of experience function. The adaptive optimization of the quality of experience function may be based on a deep reinforcement learning model, such as a deep deterministic policy gradient algorithm, including but not limited to the one presented in the above embodiment.
In step 2103, the viewpoint of the user is determined/predicted based at least in part on the received viewpoint trace (e.g., associated with a previous video segment consecutive with the video segment, or a current viewpoint of the user). The determination/prediction of the viewpoint of the user may be based on the method presented in the above embodiment. The viewpoint trace of the user may comprise, at least, a head movement trace and an eye fixation trace. Step 2103 may include predicting a single-user viewpoint trace for the segment based on a received viewpoint trace of the user (e.g., associated with the previous segment(s) of the video), and optionally, also predicting a cross-user viewpoint trace for the segment. Step 2103 may include predicting head movement area (e.g., map) of the user for the segment and predicting eye fixation area (e.g., map) of the user for the segment. The prediction may be performed using a recurrent neural network model (e.g., a long short term memory model) processing the received viewpoint trace of the user. The prediction of the cross-user viewpoint trace for the segment may be performed based on a saliency map (SM) of known cross-user viewpoint traces associated with the segment.
After steps 2102 and 2103, in step 2104, the method 2100 determines bitrates for the tiles (preferably all of the tiles) in the segment based on the determined total bitrate and the predicted viewpoint. The determination may include allocating bitrate to each of the tiles such that a sum of the bitrates of all tiles in the segment in substantially equal to the determined total bitrate. In one example, step 2104 includes allocating a lower bitrate (or bitrates) to the tiles in area outside a predicted head movement area for the segment and allocating a higher bitrate (or bitrates) to the tiles in area inside a predicted head movement area for the segment. The bitrate(s) of the tiles in area outside the predicted head movement area need not be identical. Likewise, the bitrate(s) of the tiles in area inside the predicted head movement area need not be identical. In one implementation, a minimum available bitrate is allocated to the tiles in area outside a predicted head movement area for the segment. In one implementation, the tiles in area inside the predicted head movement area but outside the predicted eye fixation area for the segment is allocated lower bitrate (or bitrates) compared with the tiles in area inside both the predicted head movement area and the predicted eye fixation area for the segment. In one implementation, bitrates between adjacent tiles of the segment to be within a difference threshold to avoid apparent presence of boundary.
Once the bitrates for the tiles of the segment are determined, then in step 2106, a request to receive the tiles of the segment in accordance with the determined bitrates for the tiles is generated and transmitted, e.g., from the one or more controllers to a streaming server. In a preferred embodiment, the request includes an order indicator to receive the tiles of the segment with the largest determined bitrate first or in the order of decreasing bitrates. This ensures that the tiles with highest bitrate are received earlier than the other tiles.
In step 2108, the tiles of the segment are received, e.g., from a streaming server operably connected with the one or more controllers, in accordance with the determined bitrates for the tiles.
In step 2110, a determination is made, e.g. by the one or more controllers, as to whether all tiles of that segment is received. If yes, the method 2100 returns to receiving updated playback states and viewpoint trace, or to steps 2102 and 2103, for the next video segment to be received (or downloaded). If not, the method 2100 will wait unit all tiles of that segment is received before returning to receiving updated playback states and viewpoint trace, or to steps 2102 and 2103, for the next video segment to be received (or downloaded).
In step 2112, which may be performed after step 2108 irrespective of the progress of step 2110, the received tiles are processed and the corresponding video content is streamed to the user (e.g., provided to the user at a display operably connected with the one or more controllers).
The steps in method 2100 may be performed by one or more controllers, e.g., at the electrical device for streaming and playing the video, in which case the viewpoint trace and the playback states may be received locally from detectors operably connected with the one or more controllers. The method 2100 can be repeated for two or more or all segments of the video so as to stream the video. The method 2100 is preferably applied for streaming 360 degrees video. However, it is contemplated that the method 2100 can be used to stream other video.
Although not required, the embodiments described with reference to the Figures can be implemented as an application programming interface (API) or as a series of libraries for use by a developer or can be included within another software application, such as a terminal or computer operating system or a portable computing device operating system. Generally, as program modules include routines, programs, objects, components and data files assisting in the performance of particular functions, the skilled person will understand that the functionality of the software application may be distributed across a number of routines, objects and/or components to achieve the same functionality desired herein.
It will also be appreciated that where the methods and systems of the invention are either wholly implemented by computing system or partly implemented by computing systems then any appropriate computing system architecture may be utilized. This will include stand-alone computers, network computers, dedicated or non-dedicated hardware devices. Where the terms “computing system” and “computing device” are used, these terms are intended to include (but not limited to) any appropriate arrangement of computer or information processing hardware capable of implementing the function described.
It will be appreciated by persons skilled in the art that numerous variations and/or modifications may be made to the invention as shown in the specific embodiments to provide other embodiments of the invention. The described embodiments of the invention should therefore be considered in all respects as illustrative, not restrictive. Various optional features of the invention are set out in the summary. For example, the steaming method and/or system may be applied to steam video other than 360 degrees video. The steaming method and/or system may be applied to stream only part of an entire video. The specific algorithms, models, etc., may be adjusted or modified to take into account additional or alternative factors for streaming the video. The video source file may be encoded or processed in a different format. The steaming method and/or system may be applied to other electrical device (not limited to mobile device).
Number | Name | Date | Kind |
---|---|---|---|
10062414 | Westphal | Aug 2018 | B1 |
10158685 | Hobby et al. | Dec 2018 | B1 |
10469568 | Jenkins | Nov 2019 | B2 |
10554953 | Raphael | Feb 2020 | B2 |
10754511 | Birkbeck | Aug 2020 | B2 |
11010632 | Han | May 2021 | B2 |
11108841 | Han | Aug 2021 | B2 |
11330239 | Shi | May 2022 | B2 |
20150143239 | Birkbeck | May 2015 | A1 |
20150373153 | Jenkins | Dec 2015 | A1 |
20170295222 | Jenkins | Oct 2017 | A1 |
20180241988 | Zhou | Aug 2018 | A1 |
20190191147 | Raphael | Jun 2019 | A1 |
20190230142 | He et al. | Jul 2019 | A1 |
20190387039 | Han et al. | Dec 2019 | A1 |
20200279127 | Han et al. | Sep 2020 | A1 |
20200413022 | Shi | Dec 2020 | A1 |
20210042964 | Yeung | Feb 2021 | A1 |
20220239896 | Xu | Jul 2022 | A1 |
Number | Date | Country |
---|---|---|
3346709 | Nov 2018 | EP |
102089457 | Mar 2020 | KR |
2017140948 | Aug 2017 | WO |
2017214291 | Dec 2017 | WO |
Entry |
---|
H. Yuan, S. Zhao, J. Hou, X. Wei, and S. Kwong, “Spatial and temporal consistency-aware dynamic adaptive streaming for 360-degree videos,” IEEE Journal of Selected Topics in Signal Processing, vol. 14, No. 1, pp. 177-193, 2020. |
M. Xu, C. Li, S. Zhang, and P. L. Callet, “State-of-the-art in 360-degree video/image processing: Perception, assessment and compression,” IEEE Journal of Selected Topics in Signal Processing, vol. 14, No. 1, pp. 5-26, 2020. |
A. Elgabli, K. Liu, and V. Aggarwal, “Optimized preference-aware multi-path video streaming with scalable video coding,” IEEE Transactions on Mobile Computing, vol. 19, No. 1, pp. 159-172, 2020. |
J. Li, S. Chu, F. Shu, J. Wu, and D. N. K. Jayakody, “Contract-based small-cell caching for data disseminations in ultra-dense cellular networks,” IEEE Transactions on Mobile Computing, vol. 18, No. 5, pp. 1042-1053, 2019. |
J. Lee, D. Yang, Y. Chen, and W. Liao, “Efficient multi-view 3d video multicast with depth-image-based rendering in Ite-advanced networks with carrier aggregation,” IEEE Transactions on Mobile Computing, vol. 17, No. 1, pp. 85-98, 2018. |