The invention relates to video coding based on global motion compensated motion vectors, and, in particular, though not exclusively, to methods and systems for video coding based on global motion compensated motion vectors, a video decoder apparatus and a video encoder apparatus using such methods and a computer program product for executing such methods.
State of the art video coding standards use a hybrid block-based video coding scheme wherein a video frame is partitioned into video blocks which are subsequently encoded using predictive block-based compression techniques. Here, a video block or in short a block refers to a basic processing unit of a video standard, e.g., coding tree units (CTUs) as defined in HEVC, macroblocks as defined in AVC and super blocks as defined in VP9 and AVC1. In certain video coding standards, such as HEVC, blocks may be partitioned into smaller sub-blocks e.g. Coding Units (CUs) and Prediction Units (PUs). Different prediction modes may be used to code each of the blocks or sub-blocks. For example, different intra-prediction modes may be used to code a block based on predictive data within the same frame so as to exploit spatial redundancy within a video frame. Additionally, inter-prediction modes may be used to code a block based on predictive data from another frame so that temporal redundancy across a sequence of video frames can be exploited.
Inter-prediction uses a motion estimation technique to determine motion vectors (MVs), wherein a motion vector identifies a block in an already encoded reference video frame (past or future video frame) that is suitable for predicting a block in a video frame that needs to be encoded wherein the block that needs to be encoded and its associated MV are typically referred to as the current block and the current MV respectively. The difference between a predictive block and a current block may define a residual block, which can be encoded together with metadata, such as the MV and transmitted to a video playout device that includes a video decoder for decoding the encoded information using the metadata. In turn, MVs may be compressed by exploiting correlations between motion vectors of blocks that have been already encoded and a motion vector of a current block. Translational moving objects in video pictures typically cover many blocks that have similar motion vectors in directions and length. Video coding standards typically exploit this correlation.
For example, motion vector compression schemes such as the so-called Advanced Motion Vector Prediction (AMVP) algorithm used by HEVC or the Dynamic Reference Motion Vector Prediction (REFMV) used by AV1, aim to compress information about motion vectors in the bitstream by using a motion vector that already have been calculated as a reference for predicting a current MV. Such motion vector may be referred to as a motion vector predictor (MVP). In this scheme, a MVP for a MV of a current block may be generated by determining candidate MVs of already encoded blocks of the current video frame or co-located blocks of an encoded reference video frame and selecting a candidate MV as the best predictor, a MVP, for the current block based on an optimization scheme such as a well-known rate distortion and optimization (RDO) scheme. The difference between the MVP and the MV and information about the selected motion vector predictor is entropy coded into a bitstream. The decoder uses the information of the selected MVP and the MV difference to reconstruct a motion vector of a current block that needs to be decoded. The motion vector compression schemes of the video standards are all based on the fact that blocks close to the current block, e.g. neighbouring blocks in the same video frame or co-located blocks in a reference frame, will typically have the same or similar motion vector values due to the spatial correlation of pixels in blocks of consecutive frames.
A problem associated with the inter-prediction algorithms used by most coding standards is that these algorithms assume that the motion relates to translational movement of objects in the video. This movement of objects in pictures is sometimes referred to as local motion. Motion vectors determined by a motion estimation technique however provide an estimate of all motion in video blocks of a video frame, local motion associated with moving objects as well as global motion associated with a moving background caused by a moving camera. Conventional inter-prediction schemes are optimized for local motion but are not designed to deal with global motion effects.
Video coding schemes that can deal with both local and global motion are known. For example, the Advanced Simple Profile (ASP) of the MPEG-4 standard includes an inter-prediction scheme that includes both local motion estimation (LME) and global motion estimation (GME) for blocks in a video frame. The encoder may select for each block, the best prediction, i.e. either a prediction based on the LME mode or a prediction based on the GME mode. If the GME mode is selected for one or more blocks in a video frame a set of global motion parameters for a video frame is coded and sent in the bitstream to the decoder apparatus. Motion vectors are determined for blocks for which the LME mode is selected. Due to the increased complexity and computation load at both the encoder and the decoder side the proposed Advanced Simple Profile scheme was less suitable for hardware implementation. Moreover, the gain that can be achieved by the GME process was relatively little as in conventional 2D video global motion effects due to camera motion, e.g. zooming or panning, are relatively short and not easy to predict.
Currently an increasing number of professional and consumer-grade cameras are able to produce 360-degree video content. Such video content (also referred to as omnidirectional content), which can be regarded as pixels arranged on a spherical surface (sometimes referred to as a pixel sphere or a sphere of pixels), is hereafter referred to in short by the term spherical content. The delivery of spherical content usually requires a higher bandwidth than conventional video. Spherical content represents a wider field of view than conventional videos and thus contains more information than conventional 2D video. Moreover, in order to provide an “immersive” video experience, spherical video content often contains relatively long scenes which are captured using a translational moving camera (e.g. a camera mounted on a drone, a car, a bike or carried by the camera man moving at a certain speed in a certain direction).
A typical video processing pipeline for spherical video may include: capturing of panoramic images with a panoramic or 360-degree image capturing system, stitching the images together in an image stitching operation into spherical video data and projecting the spherical video data onto a 2D rectangular surface of a video frame using a suitable projection model. The resulting video frame may be referred to as a projected video frame. Different projection models, such as an equirectangular projection (ERP), cube or pyramid projection model can be used for generating projected video frames, which can be coded using existing video coding standards, such as H.264/AVC, H.265/HEVC, VP9 and AV1. The encoded spherical video data may be stored on a storage medium or provided to (e.g. transmitted to) media playback devices. A decoder apparatus may decode the encoded video frames and a rendering engine may render the spherical content on a suitable display device, e.g. a head mounted device (HMD) or the like. In spherical video, wherein video data in video frames are a result of a projection of a 3D world-scene onto the imaging plane of a physically moving 360 camera, the effect of global motion is particularly pronounced. In that case, the global motion field in projected video frames due to camera movement cannot be efficiently processed by known inter-prediction scheme thereby substantially reducing the encoding efficiency.
In their article, Vishwanath et al, “Rotational motion model for temporal prediction in 360 video coding”, explain that 360-video projected onto a 2D imaging plane of a camera yields non-linear motion in video frames which needs to be processed by a state of the art video coding system. The non-linear motion degrades the compression efficiency and the authors propose to solve this problem by using a spherical model wherein motion in video pictures is described as angular motion on the sphere of pixels. This model is used in a motion estimation process of an HEVC encoder. Although a description of the motion in 360-video in terms of spherical coordinates may lead to a more accurate determination of the motion vectors of video blocks of a video frame, it does not solve the problem of a global motion field in video frames due to camera motion and the difficulty of compressing motion vectors that include global motion. Motion vectors that include a global motion component projected on a 2D video frame cannot be efficiently handled by state of the art inter-prediction schemes since the correlation of motion vectors in that case violates the assumption described earlier, i.e. strong spatial correlation of motion vector direction and amplitude, which can lead to substantial compression inefficiencies.
Hence, from the above it follows there is a need in the art for improved methods and systems for coding of video data that includes a global motion field that is caused by motion, in particular camera motion.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Functions described in this disclosure may be implemented as an algorithm executed by a microprocessor of a computer. Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied, e.g., stored, thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber, cable, RF, etc., or any suitable combination of the foregoing. Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java™, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the users computer, as a stand-alone software package, partly on the users computer and partly on a remote computer, or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the users computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present invention are described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor, in particular a microprocessor or central processing unit (CPU), of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer, other programmable data processing apparatus, or other devices create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. Additionally, the Instructions may be executed by any type of processors, including but not limited to one or more digital signal processors (DSPs), general purpose microprocessors, application specific integrated circuits (ASICs), field programmable logic arrays (FP-GAs), or other equivalent integrated or discrete logic circuitry.
The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the blocks may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustrations, and combinations of blocks in the block diagrams and/or flowchart illustrations, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The embodiments in this application aim to improve the efficiency of coding video, in particular 360 video, but also any other type of video that has global motion due to movement of the camera position of the camera that captures the video, which can either be a virtual (computer generated world) camera or a real camera. Here, the movement may be associated with a physically moving camera (e.g. due to a panning or tilting operation), or with a virtually moving camera (e.g. due to a zooming action). The improvements include compensating of global motion in the video during the video coding process so that effects associated with global motion that suppress the coding efficiency are removed.
The inventors recognized that a global motion field in video frames due to translational movement of a camera has a distinct pattern, which may depend on the type of video data in the video frames. The global motion is particularly distinct in case of spherical video, wherein the characteristic pattern of the global motion may depend on the projection that is used to project the spherical video onto a rectangular 2D plane of a video frame. For example, in an equirectangular (ERP) projected video frame, camera motion may cause a characteristic pattern in the video including an expansion point and a compression point in the video frames. Pixels in the area around expansion points may have motion vectors that point in opposite direction with the origin located at the same point (expansion point) and pixels in the area around compression points may have motion vectors that point toward the same point (compression point) causing complex but accurately predictable motion patterns in these two types of area. Such patterns can be predicted using a simple parametric algorithm that models the movement of the camera in the 3D scene, hence causing a global motion in the captured video. It should be noted that global motion is also present in conventional (non-spherical) video captured with a moving camera position, which global motion becomes more pronounced with the speed of movement and the angle of view. Also in these cases the global motion patterns (e.g. the components of motion vectors) that are the result of global motion may be modelled on the basis of parametric algorithms, or may be determined based on video analysis (using an image processing algorithm) and used for generating a motion compensation map comprising motion compensation vectors.
In an aspect, the invention may relate to a method of providing a bitstream comprising video data encoded by an encoder apparatus. In an embodiment, the method may include: determining, preferably by a processor of the encoder apparatus, a motion vector of a current block of a video frame of a sequence of video frames comprising video data captured by a video capturing device, the motion vector defining an offset of the current block relative to a prediction block of an already encoded first reference video frame stored in a memory of the encoder apparatus, wherein at least a part of the offset defined by the motion vector is associated with (caused by) global motion in the video data if the video capturing device is moving relative to a scene; a difference between the current block and the prediction block defining a residual block. Here, prediction blocks may be interpolated from the samples of the reference frames when sub-pixel accuracy is used for the motion vectors. In addition, motion models more complex than translational, e.g. with rotation and/or scaling, may also require interpolation of the value of the prediction block based on the samples of the reference frames.
The video data are preferably spherical video data captured by one or more capturing devices that have been projected onto a rectangular video frame on the basis of a projection model.
Additionally, prediction blocks may define any collection of samples, including rectangular shaped collections of samples, from the reference frames that can be used to calculate the prediction of samples of the blocks of a video frame.
The method may include determining, preferably by the processor, a motion vector predictor for predicting the motion vector. In an embodiment, the determining a motion vector predictor may include selecting a motion vector predictor from motion vectors of one or more already encoded blocks of the current video frame and/or of one or more already encoded blocks of one or more reference video frames, preferably the first reference video frame, stored in the memory of the encoder apparatus.
Additionally, the method may include determining or receiving, preferably by the processor, a motion compensation vector for the motion vector of the current block, the motion compensation vector providing an estimate of the part of the motion vector that is associated with global motion; and determining, preferably by the processor, a global motion compensated motion vector based on a difference between the motion vector and motion compensation vector; and, determining, preferably by the processor, a motion vector difference based on the motion vector predictor and the compensated motion vector.
Further, the method may include using, preferably by the processor, an entropy coding algorithm to code the residual block, the motion vector difference, an indication of the selected motion vector predictor, an indication, preferably a binary flag, that the motion vector difference is based on a difference between the motion vector and a global motion compensated motion vector; and, conversion information for converting the compensated motion vector into the motion vector, into a bitstream.
Hence, motion vectors of blocks of a video frame are compensated for global motion using motion compensation vectors wherein each motion vector provides an estimate of the global motion for pixels of a block. Here, the global motion is caused by the video capturing device moving relative to a scene. Compensation of the global motion during the video encoding process enables efficient compression of the motion vector based on motion vector predictors in case global motion is present in the video data that needs to be encoded.
In an embodiment, a motion vector prediction process may be used to determine the motion vector predictor, wherein the motion vector prediction process may include selecting the motion vector predictor from at least one candidate list, the candidate list including motion vectors of one or more already encoded blocks of the current video frame and/or of one or more already encoded blocks of one or more reference video frames, preferably the first reference video frame, stored in the memory of the encoder apparatus.
In an embodiment, the motion vectors of one or more already encoded blocks may form at least one indexed list of motion vectors and wherein the indication of the motion vector predictor selected by the encoder apparatus includes an index of the selected motion vector in the at least one indexed list. By using an indexed list only the index of the selected motion vector needs to transmitted in the bitstream.
In an embodiment, the conversion information may comprise an indication of an algorithm used by the encoder apparatus to determine the motion compensation vector.
In an embodiment, the conversion information may include one or more parameters for an algorithm stored in the decoder to determine the motion compensation vector. This information may signal the decoder apparatus which algorithm was used by the encoder apparatus to determine the compensation motion vectors.
In an embodiment, at least part of the one or more parameters being associated with the movement of the video capturing device relative to the scene. In an embodiment, at least part of the one or more parameters may include: a speed of the video capturing device, a height of the video capturing device or a direction in which the video capturing device is moving relative to the scene. The parameters may be used by the decoder apparatus to calculate motion compensation vectors based on a parametric algorithm stored its memory.
In an embodiment, the motion compensation vector may be part of a motion compensation map comprising motion compensation vectors for blocks of the current video frame. Hence, a map of motion compensation vectors representing blocks of the video frame may be used for compensating motion vectors.
In an embodiment, the conversion information may comprise the motion compensation vector or a motion compensation map comprising motion compensation vectors for blocks of the current video frame or the sequence of video frames that includes the current video frame. In this embodiment, motion compensation vectors may be transmitted directly in the bitstream to the decoder apparatus.
In an embodiment, determining a motion vector difference may include: determining a first motion vector difference candidate based the motion vector predictor and the compensated motion vector; and, a second motion vector difference candidate based on the motion vector predictor and the motion vector; selecting the motion vector difference from the first and second motion vector difference candidate based on an optimization process, preferably a rate-distortion optimization RDO process. Thus, an optimization method such as an RDO scheme may be used to determine whether the use of the global motion compensated motion vector results in an improved compression efficiency. If RDO costs relating to compensated motion vectors are higher than the RDO costs relating to non-compensated motion vectors then the encoder apparatus may determine to code the block on the basis of conventional motion vectors.
In an embodiment, the motion compensation map be compressed using a compression algorithm, preferably a run-length coding algorithm. In an embodiment, the conversion information may include a part of the motion compensation. Hence, the motion compensation map may be compressed using the symmetry of the global motion vector field so that only one part (one quadrant) needs to be transmitted to the decoder apparatus.
In an embodiment, the motion compensation vector may be determined based on a parametric algorithm (parametric function), the algorithm being configured to generate an estimate of the global motion for the current block of the video frame. In an embodiment, the algorithm may represent a parametric world model, e.g. a (2-plane) world model including top and bottom planes. Hence, a parametric algorithm representing a simple model of the global motion in sequence of video frames due to movement of the camera, which is known to the encoder and the decoder, may be used to determine motion compensation vectors.
In an embodiment the parametric algorithm depends on a projection model used to project the video data onto a frame. In a further embodiment the parametric algorithm depends on one or more camera parameters. For example the translational (or rotational) velocity of the camera, camera height, zooming speed etc.
In embodiments of the invention, the parametric algorithm depends on both the projection model as well as one or more camera parameters.
In an embodiment, the motion compensation vector may be determined based on an image processing algorithm. In an embodiment, the image processing algorithm may be configured to determine a motion field in the current video frame, a motion field including a motion vector associated with a pixel or a block of pixels of the current video frame. Further, the algorithm may be configured to classify motion vectors of the motion field in motion vectors representing local motion in the current video frame and motion vectors representing global motion in the current video frame. Thus, if motion compensation vectors are transmitted in the bitstream, any algorithm can be used to determine motion compensation vectors that provide an estimate of the global motion in the video frames.
In an embodiment, the video capturing device may be adapted to capture spherical video data. In an embodiment, video frames of the sequence of video frames may comprise spherical video data that preferably have been projected onto a rectangular video frame on the basis of a projection model. The projection model may be an equirectangular or a cubic projection model or any other suitable projection model. The invention is particular suitable for spherical video for which the effects of global motion due to camera movement, in particular translation camera movement, are particularly pronounced.
In an embodiment, at least part of the conversion information may be included in the bitstream as one or more SEI messages; and/or, one or more network abstraction layer, NAL, units, preferably a non-VCL NAL unit such as a Picture Parameter Set, PPS.
In an embodiment, the determining of the motion vector and the motion vector predictor and the coding is based on a video coding standard. In an embodiment, the video coding standard may be one of: AVC, HEVC, VP9, AV1 coding standard or a coding standard based on of the AVC, HEVC, VP9, AV1 coding standards.
In a further aspect, the invention may relate to a method for reconstructing a block of a video frame from a bitstream encoded by an encoder apparatus. In an embodiment, the method may comprise: receiving, preferably by a processor of a decoder apparatus, the bitstream comprising a current block of a video frame to be reconstructed by the decoder apparatus based an already decoded block of a first reference video frame stored in the memory of the decoder apparatus and based on a motion vector defining an offset of the current block relative to the prediction block, a difference between the prediction block and the current block defining a residual block.
The method may include using, preferably by the processor, an entropy coding process to decode the bitstream into a residual block, a motion vector difference, an indication of a motion vector predictor selected by the encoder apparatus, an indication, preferably a binary flag, that the motion vector difference is based on a difference between a motion vector predictor and a global motion compensated motion vector; and, conversion information to convert the compensated motion vector into the motion vector; the compensated motion vector being based on a difference between the motion vector and a motion compensation vector, the motion compensation vector providing an estimate of a part of the motion vector that is associated with global motion.
The method may also include using, preferably by the processor, the indication of the selected motion vector predictor to select a motion vector predictor from motion vectors of one or more already decoded blocks of the current video frame and/or of one or more already decoded blocks of one or more reference video frames, preferably the first reference frame, stored in the memory of the decoder apparatus; The method may further comprise determining, preferably by the processor, a compensated motion vector based on the motion vector difference and the motion vector predictor selected by the processor and converting the compensated motion vector into a motion vector based on the conversion information; and, the processor reconstructing the current block on the basis of the prediction block and the residual block, the reconstruction including using the motion vector to identify the prediction block of a reference video frame stored in the memory of the decoder apparatus.
In a yet further aspect, the invention may relate to an encoding apparatus configured to execute steps for providing a bitstream as described above. In an embodiment, the invention may relate to an encoding apparatus comprising: a computer readable storage medium having at least part of a program embodied therewith; and, a computer readable storage medium having computer readable program code embodied therewith, and a processor, preferably a microprocessor, coupled to the computer readable storage medium, wherein responsive to executing the computer readable program code, the processor may be configured to perform executable operations comprising one or more of the following steps: determining a motion vector of a current block of a video frame of a sequence of video frames comprising video data captured by a video capturing device, the motion vector defining an offset of the current block relative to a prediction block of an already encoded first reference video frame stored in a memory of the encoder apparatus, wherein at least a part of the offset defined by the motion vector is associated with global motion in the video data if the video capturing device is moving relative to a scene; a difference between the current block and the prediction block defining a residual block; a difference between the current block and the prediction block defining a residual block; determining a motion vector predictor for predicting the motion vector, the motion vector predictor being selected by the processor from motion vectors of one or more already encoded blocks of the current video frame and/or of one or more already encoded blocks of one or more reference video frames, preferably the first reference video frame, stored in the memory of the encoder apparatus; determining or receiving a motion compensation vector for the motion vector of the current block, the motion compensation vector representing an estimate of the part of the motion vector that is associated with global motion; determining a global motion compensated motion vector based on a difference between the motion vector and motion compensation vector; and, determining a motion vector difference based on the motion vector predictor and the compensated motion vector; and, using an entropy coding algorithm to code the residual block, the motion vector difference, an indication of the selected motion vector predictor, an indication, preferably a binary flag, that the motion vector difference is based on a difference between the motion vector and a global motion compensated motion vector; and, conversion information for converting the compensated motion vector into the motion vector, into a bitstream.
In an aspect, the invention may also relate to a decoder apparatus configured to execute steps for reconstructing a block of a video frame from a bitstream as described above. In an embodiment, the invention may relate to a decoding apparatus which may comprise: a computer readable storage medium having at least part of a program embodied therewith; and, a computer readable storage medium having computer readable program code embodied therewith, and a processor, preferably a microprocessor, coupled to the computer readable storage medium, wherein responsive to executing the computer readable program code, the processor is configured to perform executable operations which may comprise: receiving the bitstream comprising a current block of a video frame to be reconstructed by the decoder apparatus based an already decoded block of a first reference video frame stored in the memory of the decoder apparatus and based on a motion vector defining an offset of the current block relative to the prediction block, a difference between the prediction block and the current block defining a residual block; using an entropy coding process to decode the bitstream into a residual block, a motion vector difference, an indication of a motion vector predictor selected by the encoder apparatus, an indication, preferably a binary flag, that the motion vector difference is based on a difference between a motion vector predictor and a global motion compensated motion vector; and, conversion information to convert the compensated motion vector into the motion vector; the compensated motion vector being based on a difference between the motion vector and a motion compensation vector, the motion compensation vector providing an estimate of a part of the motion vector that is associated with global motion; using the indication of the selected motion vector predictor to select a motion vector predictor from motion vectors of one or more already decoded blocks of the current video frame and/or of one or more already decoded blocks of one or more reference video frames, preferably the first reference frame, stored in the memory of the decoder apparatus; determining a compensated motion vector based on the motion vector difference and the motion vector predictor selected by the processor and converting the compensated motion vector into a motion vector based on the conversion information; reconstructing the current block on the basis of the prediction block and the residual block, the reconstruction including using the motion vector to identify the prediction block of a reference video frame stored in the memory of the decoder apparatus.
The invention may also relate to a computer program product comprising software code portions configured for, when run in the memory of a computer, executing the method steps according to any of process steps described above. In this application the following abbreviations and terms are used:
The invention will be further illustrated with reference to the attached drawings, which schematically will show embodiments according to the invention. It will be understood that the invention is not in any way restricted to these specific embodiments.
Spherical video data of a panorama composition may be transformed and formatted by projection and mapping operations (step 106) into 2D rectangular video frames which are encoded by a state-of-the-art video encoder (step 108). The encoded video data may be encapsulated into a transport container so that the video data can be transmitted to a playout device comprising a video decoder, which is configured to decode the video data (step 110) into 2D rectangular frames. For presentation of the content to the user, the playout device renders a 3D (polyhedronic) object, and textures it with video data of decoded video frames (step 114). Depending on the projection that was used, decoded video frames are transformed back into omnidirectional video data by reversing the packing, mapping and projection operations (step 112). The encoding process 108 may be implemented in a video encoder apparatus and steps 110-114 may be implemented in a media playback device connected to or integrated in e.g. a head mounted display device (HMD).
The transformation of the spherical video data by projection and mapping operations into 2D rectangular video frames is described in more detail with reference to
Depending on the projection model, after mapping, a projected video frame may include some areas 307 that do not comprise any video data. In order to improve compression efficiency, the pixel regions in the projected video frame may be rearranged and resized, hence removing the areas that do not comprise any video data. This process may be referred to as packing. The packing process results in a packed projected video frame 310 including rearranged pixel regions 312 and horizontally and vertically arranged region boundaries 314,316. Similarly,
In the context of 360 video, it is very likely that the video content will not be captured or computer-generated using a camera rotating around one of its axes. This is because motion in the video that is caused by a rotational camera displacement may trigger motion sickness to the viewer. Translational motion however, in particular slow translational motion, is acceptable for most of the users. Hence, camera motion in 360 video is predominantly translational camera motion. If camera translation is possible, typically a scene in the video content allows the camera to move in a given direction for a good amount time, e.g. a scene captured by a moving drone. This way an “immersive” video experience can be provided to the viewer. This means that a scene world as a function of time is not a small closed 3D geometry like a cube (as may be the case when using a static 360 camera). On the contrary, the scene world may include at least two vertical planes (“walls”) on the left and right parallel to the camera motion and two horizontal planes top and bottom, “sky” and “ground” respectively. In some cases, such as large indoor warehouse, the world scene may be further simplified and can be characterized by only two planes, top and bottom. In yet another case, e.g. outdoor footage, the top plane (sky) can be considered at an infinite distance from the camera and thus can be omitted.
It is well known that in case of translational camera motion, there is a corresponding change in the images captured by the camera. If a camera moves with a certain velocity, a point of a 3D scene world imaged on the image plane of a camera can be assigned a vector indicating a magnitude and direction of the movement of the point on the image plane due to camera movement. The collection of the motion vectors for each point (e.g. pixel or collection of pixels such as a video block) in a video frame may form a motion vector field associated with the video frame. The motion vector field thus forms a representation of 3D motion as it is projected onto a camera image wherein the 3D motion causes a (relative) movement between (parts of) the real-world scene and the camera. The motion vector field can be represented as a function which maps image coordinates to a 2-dimensional vector. The motion fields in projected spherical video due to translational movement of a 360-video camera will exhibit a motion field of a distinct pattern depending on the type of projection that is used to project spherical video onto a rectangular 2D plane.
In addition, the trigonometric relationship in the triangle OPH gives:
Here, by definition angle θ for all the points of the top plane is within the range]0;π[ since dtop≠0. The motion visible on the sphere surface is given by an angular velocity of the point P′ intersecting the sphere and the segment OP. Within the frame of reference of the camera, point P is moving, i.e. point P is associated with a non-zero motion vector. In order to determine a displacement of the point P′ on the circle while point P moved by δl, a tangent equation (providing a relation between the position of point P and the angle θ), may be evaluated:
By deriving an equation with respect to the time, the following expressions of the motion field for the plane world scene may be derived (dtop is kept constant with respect to time):
These equations are valid when {right arrow over (νp)} and {right arrow over (νc)} are in the same plane OXZ, i.e. P is in the plane OXZ. When P is not in this plane, the point P can be defined in a spherical coordinate system by (r, θ, φ) with φ being the azimuth angle and θ the polar angle in the spherical coordinate system and O its origin.
In the case P is not in the plane OXZ, then the previous equation can be generalized by substituting νp with the projection of {right arrow over (νp)} onto the line (HP) hence falling back in the case of {right arrow over (νP)} and {right arrow over (νC)} are aligned which is:
νP=−νC sin φ
This expression provides a horizontal component (an x-component) of the motion field of an EPR projection due camera motion (see also
In a similar way, the vertical y-component of the motion field can be determined. These expressions indicate that the motion field produced by translational motion in a plane world model is characterized by a specific set of properties and can be analytically modelled using a simple parametric function (parametric algorithm) as described above. As will be shown in the figures, the motion field is either globally zero or characterized by a focus of expansion (an expansion point) and a focus of contraction (contraction point) which are separated by 180 degrees. Moreover, any flow that is present is parallel to the geodesics connecting a focus of expansion to a focus of contraction.
For example, the motion field depicted in video frames as shown in
The motion vector associated with a certain video block in a video frame represents a shift in (blocks of) pixels due to motion in the video, including motion caused by camera motion. Therefore, the motion field in a projected video frame (which can be accurately modelled) at the position of a video block provides an effective measure of the contribution of the camera motion to the motion vector. As shown in
Hence, in the white and black areas of
Although the effect of translational camera movement is explained above with reference to an ERP projection, the described effect, i.e. the distinctive pattern of the motion field, will also appear in other projections such as cube map. This is because each of these projections will introduce a characteristic pattern in the video.
Projected video frames that include motion fields due to a moving camera need to be encoded by a state of the art video coding system, e.g. HEVC, AV1, VP10, etc., These video coding systems rely on inter-prediction techniques in order to increase the coding efficiency. These techniques rely on temporal correlations between video blocks in different video frames, wherein the correlation between these blocks can be expressed on the basis of a motion vector. Such motion vector provides an offset of a video block in a decoded picture relative to the same video block in a reference picture (either an earlier video frame or a further video frame). For each video block in the video frame a motion vector can be determined. The motion vectors of all video blocks of a video frame may form a motion vector field. When examining the motion vector field of projected video frames, e.g. video frames comprising ERP or cubic projected video, the motion field at a position of a certain video block provides a measure of the motion of the pixels of that block wherein the motion includes global motion due to translational camera movement as described with reference to
Experimental data of motion vector fields of decoded video frames is depicted in
As shown in
The mean MV values for the vertical, Y direction acquired for each of the 60×120 blocks by averaging over the motion vectors of the video frames are shown in
The effect of camera motion causing a motion vector field of a distinct pattern in the video and affecting the direction and/or magnitude of the motion vectors determined by a motion estimation module of a video coding system not only occurs in spherical video but also in (conventional) 2D video. For example,
Hence, from the statistical analysis of the motion vector fields as depicted in
State of the art video coding systems such as HEVC, VP9 and AV1, use inter-prediction techniques to reduce the temporal redundancy in a sequence of video pictures in order to achieve efficient data compression. Inter-prediction uses a motion estimation technique to determine motion vectors (MVs), wherein a motion vector identifies a video block in a reference video frame that is suitable for predicting a video block in a current video frame that needs to be encoded. The difference between a predictive video block and a current video block may define a residual video block, which can be encoded together with metadata, such as the MV and transmitted to a video playout device that includes a video decoder for decoding the encoded information using the metadata. MVs may be further compressed by exploiting correlations between motion vectors. Translational moving objects in video pictures typically cover many blocks that have similar motion vectors in directions and length. Video coding standards typically exploit this redundancy.
For example, HEVC uses a so-called Advanced Motion Vector Prediction (AMVP) algorithm which aims to improve compression by using motion vectors that have already been calculated as references for predicting a current motion vector. In this scheme, a motion vector predictor (MVP) for a block may be generated by determining candidate motion vectors of already encoded blocks of the current video frame or co-located blocks of a reference video frame and selecting a candidate motion vector as the best predictor for the current block based on an optimization scheme such as a well-known rate distortion and optimization (RDO) scheme. The motion vector difference MVD between the motion vector predictor and the motion vector and information about the selected motion vector predictor is entropy coded into a bitstream. The decoder uses the information of the selected motion vector predictor and the motion vector difference to reconstruct a motion vector of a block that needs to be decoded.
A problem associated with inter-prediction algorithms used by most coding standards is that these inter-prediction algorithms are based on the assumption that the motion relates to translational movement of objects in the video, which is sometimes referred to as local motion compensation. Motion vectors however provide an estimate of all motion in video blocks of a video frame, including local motion associated with moving objects and global motion associated with a moving background caused by a moving camera. Conventional inter-prediction schemes are optimized for local motion when the spatial correlation between motion vectors is an identity function, i.e. neighbour motion vectors tend to have the same amplitude and direction but they are not designed to deal with global motion effects with a non-uniform motion field, especially in cases where global motion effects are dominant, such as cases where 360-video is captured by a moving camera. The embodiments in this application aim to solve this problem by compensating global motion effects during the coding process. The invention relies at least in part on the insight that global motion effects due to camera movement introduce a distinct pattern in video frames which can be accurately modelled using a parametric function (parametric algorithm).
The general concept of the invention is schematically depicted in
To counter the problem of the global motion, a simple parametric function (also referred to as parametric algorithm throughout this application) is used that provides an accurate estimate of the global motion of video blocks in video frames. The parametric function may depend on the projection model and camera parameters, e.g. translational velocity of the camera, camera height, etc. and produces motion compensation information that can be used to remove global motion from motion vectors or motion vector predictors that are used by the inter-prediction scheme to compress the video. For each block, the parametric function may determine a motion compensation vector, wherein the x-component provides an estimate of the global motion in the x-direction and the y-component an estimate of the global motion in the y-direction. The motion compensation vectors, one for each video block or groups of video blocks in a video frame, may be organized in a rectangular grid, which may be referred to as a motion compensation map. The motion compensation vectors can be easily approximated using a parametric function of the type of described with reference to
Hence, when the x-components of the first motion compensation submap are applied (e.g. added and/or subtracted) to the x-components of the MVs (first graph of
On the basis of the planar world model, a motion compensation map 808 may be constructed which comprises motion compensation vectors 8101,2,8121,2 which—when applied to the motion vectors of the MV field—results in a compensated MV field 814 in which the global motion in the areas 8161,2,8181,2 are removed or at least substantially reduced.
It can be experimentally proven that the entropy of the compensated MV field is lower than the entropy of the original, non-compensated MV field. The reduced entropy will result in improved motion vector compression. An estimate of the entropy of the MV field may be based on the variance of motion vector components, which may be calculated in the following way:
wherein μ is the average value of the motion vector components of the video blocks in a video frame. Here, xij represents the motion vector value in the X direction of video block i,j and pi represents the weight associated with the motion value of video block i,j. In this case, the weight of video blocks in a video frame is simply 1/N wherein N is the number of video blocks in a video frame. The variance may be calculated using μ, xij and pi. Hence, reduction of the value of the variance of the MV components of a MV field after the application of the MV compensation map may indicate that a video frame may be compressed more efficiently.
The main insight of the solution depicted in
The video encoder receives video data 902 to be encoded. In the example of
The mode select unit 904 may select one of the coding modes (e.g. intra-prediction or inter-prediction modes based on error results of an optimization function such as a rate-distortion optimization function), and provides the resulting intra- or inter-coded block to summer 906 to generate a block of residual video data (a residual block) to summer 928 to reconstruct the encoded block for use as a reference picture. During the encoding process, video encoder 900 receives a picture or slice to be coded. The picture or slice may be partitioned into multiple video blocks. An inter-prediction unit 920 in the mode selection unit 904 may perform inter-predictive coding of the received video block relative to one or more blocks in one or more reference pictures to provide temporal compression. Alternatively, an intra-prediction unit 918 in the mode selection unit may perform intra-predictive coding of the received video block relative to one or more neighbouring blocks in the same picture or slice as the block to be coded to provide spatial compression. Video encoder may perform multiple coding passes, e.g., to select an appropriate coding mode for each block of video data.
The partition unit 903 may further partition video blocks into sub-blocks, based on evaluation of previous partitioning schemes in previous coding passes. For example, the partition unit may initially partition a picture or slice into LCUs, and partition each of the LCUs into sub-CUs based on rate-distortion analysis (e.g., rate-distortion optimization). The partitioning unit may further produce a quadtree data structure indicative of partitioning of an LCU into sub-CUs. Leaf-node CUs of the quadtree may include one or more PUs and one or more TUs.
The motion vector estimation unit 916 executes a process of determining motion vectors for video blocks. A motion vector, for example, may indicate a displacement Dx,Dy of a predictive block (a prediction unit or PU) of a video block within a reference picture (or other coded unit) relative to the current block being coded within the current picture (or other coded unit). Motion estimation unit calculates a motion vector by comparing the position of the video block to the position of a predictive block of a reference picture that approximates the pixel values of the video block. Accordingly, in general, data for a motion vector may include a reference picture list (i.e. a list of already decoded pictures (frames) stored in the memory of the encoder apparatus), an index into the reference picture list, a horizontal (x) component and a vertical (y) component of the motion vector. The reference picture may be selected from one or more reference picture lists, e.g. a first reference picture list, a second reference picture list, or a combined reference picture list, each of which identify one or more reference pictures stored in reference picture memory 914.
MV motion estimation unit 916 may generate and send a motion vector that identifies the predictive block of the reference picture to entropy encoding unit 912 and the inter-prediction unit 920. That is, motion estimation unit 916 may generate and send motion vector data that identifies a reference picture list containing the predictive block, an index into the reference picture list identifying the picture of the predictive block, and a horizontal and vertical component to locate the predictive block within the identified picture.
Instead of sending the actual motion vector, a motion vector prediction unit 922 may predict the motion vector to further reduce the amount of data needed to communicate the motion vector. In that case, rather than encoding and communicating the motion vector itself, motion vector prediction unit 922 may generate a motion vector difference (MVD) relative to a known (or knowable) motion vector. The known motion vector, which may be used with the MVD to define the current motion vector, may be defined by a so-called motion vector predictor (MVP). In general, to be a valid MVP, the motion vector being used for prediction points to the same reference picture as the motion vector currently being coded. Otherwise, further processing of the motion vector is required to be a valid MVP, component clipping, interpolation, etc. . . . .
The motion vector prediction unit 922 may build a MVP candidate list that includes several neighbouring blocks in spatial and/or temporal directions as candidates for a MVP. When multiple MVP candidates are available (from multiple candidate blocks), MV prediction unit 922 may determine a MVP for a current block according to predetermined selection criteria. For example, MV prediction unit 922 may select the most accurate predictor from the candidate list based on analysis of encoding rate and distortion (e.g., using a rate-distortion cost analysis or other coding efficiency analysis). Other methods of selecting a motion vector predictor are also possible. Upon selecting a MVP, MV prediction unit may determine a MVP index, which may be used to inform a decoder apparatus where to locate the MVP in a reference picture list comprising MVP candidate blocks. MV prediction unit 922 may also determine the MVD between the current block and the selected MVP. The MVP index and MVD may be used to reconstruct the motion vector of a current block. Typically, the partition unit and mode selection unit (including the intra- and inter-prediction unit), the motion vector estimation unit and the motion compensation unit may be highly integrated. These units are illustrated separately in the figures for conceptual purposes.
The inter-prediction unit 920 may comprise a global motion compensation unit 924 comprising a global motion compensation function f configured to generate motion compensation information for removing global motion from the x and y components of motion vectors. For example, the x and y component of a motion vector MV=(Dx,Dy) associated with a block in a video frame describes the motion associated with pixels in that block. This motion may include local motion, global motion or both local and global motion. The function may be configured to determine an accurate estimation of the global motion in blocks of a video frame. In an embodiment, such estimate may be in the form of a motion compensation vector MCV=(dx,dy), which can be used to remove the global motion components from a motion vector or a motion vector predictor before the encoder determines an optimal motion vector difference MVD based on an optimization scheme (e.g. rate distortion optimization (RDO) scheme which is described below in more detail).
In an embodiment, the global motion may be removed or at least substantially reduced by subtracting the x and y component of the global motion vector from the x and y component of the motion vector. The resulting motion vector may be referred to as a compensated motion vector CMV=(Dx−dx,Dy−dy). The CMV may then be used by the encoder to determine an optimal motion vector difference. This way, negative effects on the compression of the motion vectors caused by global motion may be substantially reduced.
In an embodiment, the motion vector MV may be compensated based on a motion compensation vector and the resulting global motion compensated motion vector CMV may be used to determine a motion vector difference MVD. To that end, the encoder may use a motion compensation vector generated by the global motion compensation function to compensate a motion vector for global motion: f: MV->CMV. The MV prediction unit 922 may produce a motion vector predictor candidate list MVP[i] and a rate distortion optimization process may be used to select the best candidate from the list of motion vector predictor candidates MVP[i]. The selection may be signalled as an index in list, e.g. i=0 if MVP[0] is selected by the RDO process. The MV prediction unit thereafter determines a MVD as MVP[0]−CMV and the MVD and the index are subsequently coded into a bitstream. In an embodiment, also the non-compensated motion vectors may be taken into account during the RDO process. This way, compensation of the global motion is only used if it provides an improvement in the RD costs.
Processes executed by the motion compensation unit of the encoder will be described hereunder in more detail with reference to
A residual video block may be formed by an adder 906 subtracting a predicted video block (as identified by a motion vector) received from mode select unit 904 from the original video block being coded. The transform processing unit 909 may be used to apply a transform, such as a discrete cosine transform (DCT) or a conceptually similar transform, to the residual video block in order to form a block of residual transform coefficient values. Transforms that are conceptually similar to DCT may include for example wavelet transforms, integer transforms, sub-band transforms, etc. The transform processing unit 909 applies the transform to the residual block, producing a block of residual transform coefficients. The transform may convert the residual information from a pixel value domain to a transform domain, such as a frequency domain. Transform processing unit 909 may send the resulting transform coefficients to a quantization unit 910, which quantizes the transform coefficients to further reduce bit rate.
A controller 910 may provide syntax elements (metadata) of the encoding process, such as inter-mode indicators, intra-mode indicators, partition information, and syntax information, to entropy coding unit 914. Here the syntax elements may include information for signalling (selected) motion vector predictors, motion vector differences and metadata associated with the motion compensation process as described in the embodiments of this application. This metadata may include an indication that the motion vector difference is based on a difference between the motion vector and a global motion compensated motion vector. Such indication may be implemented as a (binary) flag or the like. This metadata may further include information for converting the compensated motion vector into the motion vector, e.g. parameters for a parametric algorithm in the video decoder or motion compensation vectors.
Entropy coding unit 912 entropy then encodes the quantized transform coefficients and the syntax elements. For example, entropy coding unit may perform context adaptive variable length coding (CAVLC), context adaptive binary arithmetic coding (CABAC), syntax-based context-adaptive binary arithmetic coding (SBAC), probability interval partitioning entropy (PIPE) coding or another entropy coding technique. In the case of context-based entropy coding, context may be based on neighbouring blocks. Following the entropy coding by entropy coding unit, the encoded bitstream may be transmitted to another device (e.g., a video decoder) or stored for later transmission or retrieval.
Inverse quantization and inverse transform unit 915 apply inverse quantization and inverse transformation, respectively, to reconstruct the residual block in the pixel domain, e.g., for later use as a reference block. Inter-prediction unit 920 may calculate a reference block by adding the residual block to a predictive block of one of the pictures of reference picture memory 914. Inter-prediction unit 920 may also apply one or more interpolation filters to the reconstructed residual block to calculate sub-integer pixel values for use in motion estimation. The reconstructed residual block is added to the motion prediction block produced by the inter-prediction unit 920 to produce a reconstructed video block for storage in reference picture memory 914. The reconstructed video block may be used by motion vector estimation unit 916 and inter-prediction unit 920 as a reference block to inter-coding a block in a subsequent picture.
The encoder may perform a known rate-distortion optimisation (RDO) process in order to find the best coding parameters for coding blocks in a picture. Here, the best coding parameters (including mode decision (intra-prediction; inter-prediction without motion compensation or inter-prediction with motion-compensation); intra prediction mode estimation; motion estimation; and quantization) refer to the set of parameters that provide the best trade-off between a number of bits used for encoding a block versus the distortion that is introduced by using the number of bits for encoding.
The term rate-distortion optimization is sometimes also referred to as RD optimization or simply “RDO”. RDO schemes that are suitable for AVC and HEVC type coding standards are known as such, see for example, Sze et al. “High efficiency video coding (HEVC).” Integrated Circuit and Systems, Algorithms and Architectures. Springer (2014): 1-375; Section: 9.2.7 RD Optimization. RDO can be implemented in many ways. In one well-known implementation, the RDO problem can be expressed as a minimization of a Lagrangian cost function J with respect to a Lagrangian multiplier:
Here, the parameter R represents the rate (i.e. the number of bits required for coding) and the parameter D represents the distortion of the video signal that is associated with a certain rate R. The distortion D may be regarded a measure of the video quality. Known metrics for objectively determining the quality (objectively in the sense that the metric is content agnostic) include means-squared error (MSE), peak-signal-to-noise (PSNR) and sum of absolute differences (SAD).
In the context of HEVC, the rate-distortion cost may require that the video encoder computes a predicted video block using each or at least part of the available prediction modes, i.e. one or more intra-prediction modes and/or one or more inter-prediction modes. The video encoder then determines a difference video signal between each of the predicted blocks and the current block (here the difference signal may include a residual video block) and transforms each residual video block of the determined residual video blocks from the spatial domain to the frequency domain into a transformed residual block. Next, the video encoder may quantize each of the transformed residual blocks to generate corresponding encoded video blocks. The video encoder may decode the encoded video blocks and compare each of the decoded video blocks with the current block to determine a distortion metric D. Moreover, the rate-distortion analysis involves computing the rate R for each encoded video block associated with of one of the prediction modes, wherein the rate R includes an amount of bits used to signal an encoded video block. The thus determined RD costs, the distortion D and the rate R of the encoded blocks for each of the prediction modes, are then used to select an encoded video block that provides the best trade-off between the number of bits used for encoding the block versus the distortion that is introduced by using the number of bits for encoding.
In an embodiment, the invention provides an encoding optimization scheme for video data based on an RD optimization scheme. The optimization scheme takes into account that:
An initial global motion parameter set may be used by the function to determine initial motion vector compensation values for video blocks of a video frame. The motion vector compensation values for all video blocks of a video frame may be referred to as a motion vector compensation map. The initial global motion parameter set may be used to provide a first approximation of motion compensation values (a first candidate map) for each of at least part of the video blocks in a video frame. Then, a number of derived global motion parameters sets may be generated by introducing one or more small deviations in global motion parameters of the initial global motion parameter set. These different global motion parameter sets may be used to determine different motion compensation maps (one or more further candidate motion compensation maps). Each of these candidate motion compensation maps may be used to compensate (minimize) the contribution of the global motion field to the motion vector components of a video frame that needs to be encoded.
The candidate motion compensation map that provides the most accurate model of the motion field in a sequence of video frames may be used to remove or at least substantially reduce the global motion field from a motion vector or a motion vector predictor. This way an improved RD cost may be achieved when compared to the RD cost of the original video frame wherein the motion vectors are not compensated for the global motion field. This way the RD optimization scheme can be used to determine a global motion parameter set comprising motion vector compensation that provides the best coding efficiency.
Hence, the encoding optimization scheme according to the invention includes the generation of several candidate motion compensation maps. Each candidate map may be used to determine compensated motion vectors associated with video blocks of a video frame. Here a compensated motion vector (predictor) represents a motion vector (predictor) in which contribution of the global motion field is eliminated or at least substantially reduced. Each candidate map may be used in a RD optimization process, e.g. a known RD optimization process, in which the conventional encoding parameters (intra-prediction, inter-prediction and motion compensation) are optimized per coding block using minimization of a cost function. The encoded candidate video frame that exhibits the lowest RD costs is used in the formation of the output bitstream that is generated by the encoder apparatus.
During the decoding process, video decoder 1000 receives an encoded video bitstream 1002 that comprises encoded video blocks and associated syntax elements from a video encoder. Entropy decoding unit 1004 decodes the bitstream to generate quantized coefficients associated with residual blocks, motion vector differences, and syntax elements (metadata) for enabling the video decoder to decode the bitstream. Parser unit 1006 forwards the motion vector differences and associated syntax elements to prediction unit 1018.
The syntax elements may be received at video slice level and/or video block level. For example, by way of background, video decoder 1000 may receive compressed video data that has been compressed for transmission via a network into so-called network abstraction layer (NAL) units. Each NAL unit may include a header that identifies a type of data stored to the NAL unit. There are two types of data that are commonly stored to NAL units. The first type of data stored to a NAL unit is video coding layer (VCL) data, which includes the compressed video data. The second type of data stored to a NAL unit is referred to as non-VCL data, which includes additional information such as parameter sets that define header data common to a large number of NAL units and supplemental enhancement information (SEI).
When video blocks of a video frame are intra-coded (I), intra-prediction unit 1022 of prediction unit 1018 may generate prediction data for a video block of the current video slice based on a signalled intra-prediction mode and data from previously decoded blocks of the current picture. When video blocks of a video frame are inter-coded (e.g. B or P), inter-prediction unit 1020 of prediction unit 1018 produces predictive blocks for a video block of the current video slice based on motion vector differences and other syntax elements received from entropy decoding unit 1004. The predictive blocks may be produced from one or more of the reference pictures within one or more of the reference picture lists stored in the memory of the video decoder. The video decoder may construct the reference picture lists, using default construction techniques based on reference pictures stored in reference picture memory 1016.
Inter-prediction unit 1020 may determine prediction information for a video block of the current video slice by parsing the motion vector differences and other syntax elements and using the prediction information to produce predictive blocks for the current video block being decoded. For example, inter-prediction unit 1020 uses some of the received syntax elements to determine a prediction mode (e.g., intra- or inter-prediction) which was used to code the video blocks of the video slice, an inter-prediction slice type (e.g., B slice or a P slice), construction information for one or more of the reference picture lists for the slice, motion vector predictors for each inter-encoded video block of the slice, inter-prediction status for each inter-coded video block of the slice, and other information to decode the video blocks in the current video slice. In some examples, inter-prediction unit 1020 may receive certain motion information from motion vector prediction unit 1022.
The inter-prediction unit 1020 may include global motion compensation unit 1024 comprising motion compensation function for converting a compensated motion vector to a motion vector. In an embodiment, motion conversion function may be a parametric algorithm for determining motion compensation vectors using on one or more parameters in the bitstream.
As encoding by the video encoder was based on motion vector differences MVD that were determined using compensated motion vectors CMVs, the decoder may retrieve a motion vector difference MVD for a current block that needs to be decoded. The video decoder may further determine a list of motion vector predictor candidates MVP[i] associated with the current block. The video decoder may use a decoded index, i.e. i=0, associated with the motion vector difference MVD in order to select from the list of motion vector predictor candidates a motion vector predictor MVP[0] that was used by the encoder to determine the MVD. The video decoder is capable of building the list based on the position of the current block wherein the motion vector predictor candidates are associated with blocks that have a predetermined position (typically neighbouring) relative to the position of the current block. These relative positions are known to the encoder and the decoder apparatus. Then, the video decoder may determine a compensated motion vector CMV based on the selected motion vector predictor MVP[0] and the motion vector difference: CMV=MVP[0]−MVD.
The decoder may then use motion compensation function to generate information to convert a compensated motion vector CMV into a MV. For example, in one embodiment, the motion compensation function may be a parametric algorithm configured to generate motion compensation information on the basis of one or more parameters in the bitstream. The motion compensation information may include e.g. an inverse of the motion compensation vector that was used by the encoder to compensate a motion vector for global motion: f−1 CMV->MV. In another embodiment, in case motion compensation vectors or (part of) a motion compensation map is coded into the bitstream, the motion compensation function may use compensation vector in the bitstream to convert a CMV into a MV. The thus reconstructed MV is subsequently used to determine a prediction block in a reference frame stored in the reference picture memory of the video decoder.
Processes executed by the motion compensation unit of the decoder will be described hereunder in more detail with reference to
Thus, after determining motion information for the current block, motion vector prediction unit 1022 may generate the predictive block for the current block.
Inverse quantization and inverse transform unit 1008 inverse quantizes, i.e., de-quantizes, the quantized transform coefficients provided in the bitstream and decoded by entropy decoding unit. The inverse quantization process may include use of a quantization parameter calculated by video encoder for each video block in the video slice to determine a degree of quantization and, likewise, a degree of inverse quantization that should be applied. It may further apply an inverse transform, e.g., an inverse DCT, an inverse integer transform, or a conceptually similar inverse transform process, to the transform coefficients in order to produce residual blocks in the pixel domain.
After inter-prediction unit 1020 generates the predictive block for the current video block, the video decoder forms a decoded video block by summing a residual block determined by inverse transform process with the corresponding predictive block generated by inter-prediction unit 1020. The adder 1009 represents the component or components that perform this summation operation. If desired, a deblocking filter may also be applied to filter the decoded blocks in order to remove blocking artefacts. Other loop filters (either in the coding loop or after the coding loop) may also be used to smooth pixel transitions, or otherwise improve the video quality. The decoded video blocks in a given picture are then stored in reference picture memory 1016, which stores reference pictures used for subsequent motion compensation. Reference picture memory 1016 also stores decoded video for later presentation on a display device.
In a first step 1104, the encoder may determine a motion vector (MV) for a current video block that needs to be encoded. A well-known motion vector estimation process may be used to determine the motion vector wherein each motion vector may indicate the displacement (offset) of a video block within a current picture relative to a video block within a decoded reference picture stored in the memory of the encoder apparatus (e.g. a decoded video frame preceding or succeeding the current video frame). The video block in the reference frame the motion vector is pointing to may be referred to as a prediction block. Then a residual video block may be determined based on the current block and the prediction block (step 1106). A residual block may be determined based on a difference of video samples (e.g. pixel values) in a video block in the current frame and a video block in a reference frame that is identified by a motion vector. In an embodiment, the video frames may be projected video frames, i.e. video frames generated by mapping spherical video onto a rectangular 2D frame using a projection model as e.g. described with
Further, the encoder may use a function to determine an estimate of the contribution of the global motion field to motion vectors of a video frame. These motion contributions are linked to the camera motion (as e.g. described with reference to
In an embodiment, the function may be one or more parametric functions which is also known by the decoder apparatus. For a particular sequence of video frames, a parametric function may be selected by the encoder apparatus on the basis of a number of parameters, e.g.: type of video (e.g. spherical video and projection model (e.g. ERP or cubic). Further, one or more parameters such as camera speed, camera height, camera direction, etc. may be used to allow a parametric function to determine motion compensation vectors that provide an accurate estimate for the global motion in the sequence of video frames. In that case, the function type and the parameters are transmitted to the decoder apparatus that may use these parameters to reproduce the motion compensation vectors.
In another embodiment, the function may be an image processing function which is configured to determine motion vectors for blocks in video frames of the sequence of video frames and classify the motion vectors into motion vectors associated with local motion, i.e. moving objects, and global motion, i.e. motion of a scene that is caused by a moving camera. The motion vectors that represent global motion may be used as motion compensation vectors, which may be transmitted in the bitstream to the decoder apparatus. Hence, in that case, the decoder apparatus can directly use the motion compensation vectors and no parametric function (parametric algorithm) is necessary (step 1108).
In a further step 1110, at least one list of motion vector predictor candidates may be determined by the encoder apparatus. The MVP list may be an indexed list of MVP candidates. The list of candidates may be generated using any suitable MV prediction process, e.g. an AMVP scheme known from the HEVC standard, the Dynamic Reference Motion Vector Prediction (REFMV) used by AV1. The process to produce the list is both known to the encoder and decoder apparatus. Typically, the motion vector predictor candidates include motion vectors of already decoded blocks in a reference frame (typically blocks that are co-located with the current block) or motion vectors of already decoded blocks in the current frame (typically blocks neighbouring the current block). An optimization process, e.g. a rate-distortion optimization process, may be used to determine an optimal motion vector predictor from the candidate list. The selection of the optimal motion vector predictor may be signalled in the bitstream based on an index in the indexed MVP list. This index may be referred to as an MVP index. The selected motion vector predictor and the compensated MV may be used to determine a motion vector difference (MVD) (step 1112). Thereafter, the residual block, the MVD and metadata, i.e. all other information that is needed by the decoder to reconstruct the block, such as the MVP index, may be further processed and encoded. One of the further encoding steps may include transforming the residual block, the MVD and metadata into a formatted bitstream using an entropy coding algorithm (step 1114). As the motion vector compensation vectors take away or at least reduce the detrimental effects of global motion on the compression efficiency, a state-of-the-art video coding system may be used to efficiently compress all information into a bitstream. The bitstream generated by the encoder may then be transmitted to a decoder apparatus or stored in a non-transitory memory for later transmission to a decoder apparatus.
A decoder apparatus receiving the bitstream may execute a process to decode the bitstream and construct video frames based on the decoded information and decoded reference video frames stored in the reference picture memory of the decoder apparatus. To that end, the decoder apparatus may first use an entropy decoding process to decode the bitstream into a residual video block, a MVD and metadata including a MVP index (step 1116).
Further, the decoder apparatus may determine a candidate list of MVPs for the current block that needs to be decoded, wherein the MVP candidates are MVs of already decoded blocks (either from a reference frame stored in the memory of the decoder apparatus or from the current frame). Further, the decoder apparatus may use the decoded MVP index to select a MVP from the indexed MVP list (step 1118). The selected MVP and the decoded MVD may then be used to determine a compensated motion vector CMV: CMV=MVP-MVD (step 1120). The original motion vector MV may be derived from the compensated motion vector by adding global motion associated with the current block to the CMV. To that end, in an embodiment, a parametric decoder algorithm may be used to determine motion compensation information for converting the compensated motion vector CMV into a MV. In an embodiment, the motion compensation information may include a motion compensation vector that is identical to the motion compensation vector used by the encoder to form a compensated motion vector. This motion compensation vector can be added to the compensated motion vector thereby converting the compensated motion vector back into the motion vector (step 1122). The decoder apparatus may use the MV to determine a prediction block in a reference frame stored in the memory of the decoder apparatus (step 1124) and construct a current block based on the prediction block and the decoded residual block (step 1126).
Hence, as shown by the process of
Hence, as illustrated in the embodiments described in this application, a motion vector compensation function may be used to improve the compression efficiency of video, in particular spherical video, that is affected by global motion caused by movement of the camera that is used to capture the video.
A parametric function (also referred to as parametric algorithm throughout this application) may be used to model (estimate) the global motion in video frames. In particular, the parametric function may be used to provide an estimate of the global motion for blocks in a video frame. To that end, the parametric function may be configured to determine motion compensation information for a block in a video frame. The motion compensation information may be in the form of a motion compensation vector, wherein the x-component of the motion compensation vector provides an estimate of the global motion of a block in the x-direction and the y-component of the motion compensation vector provides an estimate of the global motion of a block in the y-direction. The motion vector compensation values may be determined by the function on the basis of parameters, such as a camera direction in a 3D space, a camera height, etc. Hence, when encoding video frames using a predetermined motion vector compensation function, metadata may be inserted into the bitstream in order to enable a decoder apparatus to reverse the motion compensation process used by the encoder apparatus. Table 2 hereunder provides exemplary model parameters that may be used a parametric function that is used in the embodiments of this application:
As described with reference to
Since the model is used both at the encoder and decoder side, it is desirable to signal this data as part of the bitstream payload. In an embodiment, both the encoder and the decoder may be provided with a parametric function (e.g. pre-programmed in their memories) and parameters used by the parametric function of the encoder to determine motion compensation information for one or more video frames may be signalled to the decoder by simply transmitting the parameters or information to determine the parameters into the bitstream to the decoder. In another embodiment, motion compensation vectors or may be sent in the bitstream to the decoder. In that case, the decoder apparatus does not need to have a parameter function for calculating the motion compensation vectors. Such approach may be advantageous if the motion compensation vectors can be used for a relatively large amount of subsequent video frames, e.g. a relatively long scene that is captures using a moving 360 video. In this case, when a long scene comprising global motion starts, a motion compensation map may be transmitted in the bitstream to the decoder apparatus and small changes in the motion compensation map due to e.g. changes in the camera speed and/or camera direction may be updated by only transmitting motion compensation vector differences to the decoder apparatus.
In an embodiment, metadata associated with the motion compensation schemes described in this application, may be transmitted to the decoder apparatus in VCL NAL units as e.g. known from the AVC and HEVC standards. Signalling these parameters in some metadata packet may introduce the risk of decoding failures when this information is not available, for instance due to a transmission error or data loss after transcoding.
For that reason, in one embodiment, metadata including model parameters may be inserted in a VCL NAL unit, preferably a PPS (Picture Parameter Set) as known from the AVC and HEVC standards. Table 3 provides an exemplary embodiment of a PPS including model parameters for a parametric function in the decoder apparatus:
The syntax of the PPS may be adapted from the HEVC standard wherein the descriptor ue(v) specifies an “unsigned integer 0-th order Exp-Golomb-coded syntax element with the left bit first.”. This way each value is not restricted to a certain range of fixed number of bits e.g. 4, 8, etc. . . . . However, implementations may limit the values to such ranges.
In a further embodiment, metadata including model parameters for the parametric function of the decoder apparatus may be signalled in a SEI message. This embodiment provides a possible syntax for a new SEI message as known from the AVC or HEVC standards. Such SEI message is needed for decoding so that the introduction of such message would create a new version of HEVC. Table 4 shows the syntax of the SEI payload which includes a new number payloadType for the SEI message:
In another embodiment, the motion compensation map may be sent along with bitstream. In this case, the map may not be derived from a physical model of the scene but obtained by any other means, as long as the result of the use of the map is to more efficiently compress the video sequence. A suitable use case for not using a parametric function (parametric algorithm), but instead generating a map directly from an image processing algorithm, may be video wherein a lot of local motion due to numerous objects moving in the scene, is present, or wherein a region of the video scene is not adhering to the global motion pattern (e.g. static area at the bottom of a video when the camera is mounted on the moving vehicle). In an embodiment, an image processing algorithm may be configured to determine a motion field in the current video frame, a motion vector field including a motion vector associated with a pixel or a block of pixels of the current video frame. In the computer vision domain, this motion vector field is called the optical flow as defined by James Gibson around 1940. There exist several image processing algorithms to estimate the optical flow, e.g. phase-correlation, block-based matching (what an encoder does for the purpose of block-based motion compensation), differential methods or discrete optimization methods, etc. Once the optical flow is estimated, the motion compensation map can be based on that estimated optical flow and transmitted in the bitstream. Thus an image processing algorithm may be used to analyse video frames, to classify motion vectors into local motion vectors and global motion vectors. The classified global motion vectors may be used as motion compensation vectors for compensating the global motion contribution in motion vectors during video coding. In an embodiment, the determination of the motion compensation map by the encoder may be performed via rate distortion loop such that the obtained motion compensation map ensures a gain in compression efficiency. When the map is transmitted explicitly in the bitstream it is important that the syntax allows a sufficient compression of the map otherwise the compression gain obtained by using the map may be cancelled out by the bits needed to transmit the map. To efficiently transmit a motion compensation map, one may observe that the map is symmetrical with respect to the vertical and/or horizontal axes. If both symmetries are present, only one quarter of the map needs to be transmitted and the rest can be derived from these values based on the symmetry properties. Hence, in an embodiment, if the motion compensation map exhibits symmetry properties, e.g. one or more symmetries with respect to the coordinate system the vectors are defined, only a part of the motion compensation map may be transmitted to the decoder apparatus, wherein an algorithm in the decoder apparatus may expand the map based on the symmetry properties of the map. In addition, the motion compensation map may contain similar values which can be efficiently encoded with known encoding algorithms such as run-length encoding. An example syntax for transmitting the map in the bitstream is provided below in table 5:
Where ue(v) is unsigned integer 0-th order Exp-Golomb-coded syntax element with the left bit first as defined in the HEVC standard and se(v) is signed integer 0-th order Exp-Golomb-coded syntax element as defined in the HEVC standard. As mentioned above, the map can be further compressed by only transmitting a part, e.g. one or two quadrants of the map, the rest being derived by symmetry. An example syntax for transmitting only a quadrant of the map in the bitstream is provided below in table 6:
In practice, it means that:
In an embodiment, the motion compensation map or a part thereof may be transmitted as SEI message, in the non-VCL NAL unit such as the Picture Parameter Set, for HEVC or related video coding standards or similar data unit in other video coding standards.
Problems associated with global motion as discussed in this application may arise when using state of the art video codecs such as HEVC or other coding systems wherein already encoded motion vectors cannot efficiently a current block of a video frame because of global motion. Therefore, the embodiments in this application may be used in a similar manner to other video coding standards such as VP9 or AV1 as these video coding standards rely on compression of motion vectors based on motion vector predictors associated with blocks that have been already encoded previously. Hence, in an embodiment, model parameters for a parametric algorithm in a decoder apparatus may be signalled in a message that has a syntax that is compliant with the VP9 coding standard. Table 7 provides an example of such message syntax:
Additionally, according to the AV1 draft specification, the AV1 coding system uses well-known motion compensation techniques wherein motion vectors are signalled in order to achieve reduction of the of the redundancy between a block of pixels that moved from one frame to another. Additionally, AV1 may also use reduction of the motion vector signalling by predicting the motion vectors and then only signal a delta (a difference) compared to the real motion vector. The draft specification further teaches that the prediction relies on motion vectors associated with blocks that are close to the block for which the motion vector needs to be predicted. Thus, the embodiments described in this this application may also be used in the AV1 standard or any further codec standards that use the well-known concept of motion vectors and motion vector predictors.
In a further embodiment, the signalled model parameters or the explicit MV compensation map and its applicability to each frame can be disabled by a flag in metadata related to each frame. For instance, a flag in a slice header of a HEVC bitstream can signal whether the explicit or implicit signalled MV compensation map was used for a given frame. This way, the encoder may choose to use the technique for several frames and then not use it for few frames without the need remove the signalled model parameters or the explicit MV compensation map from the bitstream. A syntax of a flag in a slice header is provided in table 8:
The second video processing device may receive the encoded video data to be decoded through a transmission channel 1306 or any type of medium or device capable of moving the encoded video data from the first video processing device to the second video processing device. In one example, the transmission channel may include a communication medium to enable the first video processing device to transmit encoded video data directly to the second video processing device in real-time. The encoded video data may be transmitted based on a communication standard, such as a wireless communication protocol, to the second video processing device. The communication medium may comprise any wireless or wired communication medium, such as a radio frequency (RF) spectrum or one or more physical transmission lines. The communication medium may form part of a packet-based network, such as a local area network, a wide-area network, or a global network such as the Internet. The communication medium may include routers, switches, base stations, servers or any other equipment that may be useful to facilitate communication between first and second video processing devices.
Alternatively, encoded data may be sent via an I/O interface 1308 of the first video processing device to a storage device 1310. Encoded data may be accessed by input an I/O interface 1312 of the second video processing device. Storage device 1310 may include any of a variety of distributed or locally accessed data storage media such as a hard drive, Blu-ray discs, DVDs, CD-ROMs, flash memory, volatile or non-volatile memory, or any other suitable digital storage media for storing encoded video data. In a further example, the storage device may correspond to a file server or another intermediate storage device that may hold the encoded video generated by the first video processing device. The second video processing device may access stored video data from storage device via streaming or downloading. The file server may be any type of server capable of storing encoded video data and transmitting that encoded video data to the second video processing device. Example file servers include a web server (e.g., for a website), an FTP server, network attached storage (NAS) devices, or a local disk drive. The second video processing device may access the encoded video data through any standard data connection, including an Internet connection. This may include a wireless channel (e.g., a Wi-Fi connection), a wired connection (e.g., DSL, cable modem, etc.), or a combination of both that is suitable for accessing encoded video data stored on a file server. The transmission of encoded video data from storage device 36 may be a streaming transmission, a download transmission, or a combination of both.
The techniques of this disclosure are not necessarily limited to wireless applications or settings. The techniques may be applied to video coding in support of any of a variety of multimedia applications, such as over-the-air television broadcasts, cable television transmissions, satellite television transmissions, streaming video transmissions, e.g., via the Internet, encoding of digital video for storage on a data storage medium, decoding of digital video stored on a data storage medium, or other applications. In some examples, system 1300 may be configured to support one-way or two-way video transmission to support applications such as video streaming, video playback, video broadcasting, and/or video telephony.
In the example of
The captured, pre-captured, or computer-generated video may be encoded by video encoder 1316. The encoded video data may be transmitted directly to the second video processing device via I/O interface 1308. The encoded video data may also (or alternatively) be stored onto storage device 1310 for later access by the second video processing device or other devices, for decoding and/or playback.
The second video processing device may further comprise a video decoder 1318, and a display device 1320. In some cases, I/O interface 1312 may include a receiver and/or a modem. I/O interface 1412 of the second video processing device may receive the encoded video data. The encoded video data communicated over the communication channel, or provided on storage device 1310, may include a variety of syntax elements generated by video encoder 1316 for use by a video decoder, such as video decoder 1318, in decoding the video data. Such syntax elements may be included with the encoded video data transmitted on a communication medium, stored on a storage medium, or stored a file server.
Display device 1320 may be integrated with, or external to, the second video processing device. In some examples, second video processing device may include an integrated display device and also be configured to interface with an external display device. In other examples, second video processing device may be a display device. In general, display device displays the decoded video data to a user, and may comprise any of a variety of display devices such as a liquid crystal display (LCD), a plasma display, an organic light emitting diode (OLED) display, or another type of display device.
Video encoder 1316 and video decoder 1318 may operate according to a video compression standard, such as the High Efficiency Video Coding (HEVC), VP9 or AV1. Alternatively, video encoder 1316 and video decoder 1318 may operate according to other proprietary or industry standards, such as the ITU-T H.264 standard, alternatively referred to as MPEG-4, Part 10, Advanced Video Coding (AVC), or extensions of such standards. The techniques of this disclosure, however, are not limited to any particular coding standard.
Although not shown in
Video encoder 1316 and video decoder 1318 each may be implemented as any of a variety of suitable encoder circuitry, such as one or more microprocessors, digital signal processors (DSPs), application specific integrated circuits (ASICs), field programmable gate arrays (FPGAs), discrete logic, software, hardware, firmware or any combinations thereof. When the techniques are implemented partially in software, a device may store instructions for the software in a suitable, non-transitory computer-readable medium and execute the instructions in hardware using one or more processors to perform the techniques of this disclosure. Each of video encoder 1316 and video decoder 1318 may be included in one or more encoders or decoders, either of which may be integrated as part of a combined encoder/decoder (CODEC) in a respective device.
This disclosure may generally refer to video encoder “signaling” certain information to another device, such as video decoder. The term “signaling” may generally refer to the communication of syntax elements and/or other data (metadata) used to decode the compressed video data. Such communication may occur in real- or near-real-time. Alternately, such communication may occur over a span of time, such as might occur when storing syntax elements to a computer-readable storage medium in an encoded bitstream at the time of encoding, which then may be retrieved by a decoding device at any time after being stored to this medium.
The techniques of this disclosure may be implemented in a wide variety of devices or apparatuses, including a wireless handset, an integrated circuit (IC) or a set of ICs (e.g., a chip set). Various components, modules, or units are described in this disclosure to emphasize functional aspects of devices configured to perform the disclosed techniques, but do not necessarily require realization by different hardware units. Rather, as described above, various units may be combined in a codec hardware unit or provided by a collection of interoperative hardware units, including one or more processors as described above, in conjunction with suitable software and/or firmware.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a,” “an,” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Number | Date | Country | Kind |
---|---|---|---|
18194471.1 | Sep 2018 | EP | regional |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2019/074327 | 9/12/2019 | WO | 00 |