CN117597923A - Intra-frame block copy with template matching for video encoding and decoding - Google Patents
Intra-frame block copy with template matching for video encoding and decoding Download PDFInfo
- Publication number
- CN117597923A CN117597923A CN202280026677.5A CN202280026677A CN117597923A CN 117597923 A CN117597923 A CN 117597923A CN 202280026677 A CN202280026677 A CN 202280026677A CN 117597923 A CN117597923 A CN 117597923A
- Authority
- CN
- China
- Prior art keywords
- template
- block
- video
- picture
- precision
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 claims abstract description 123
- 239000013598 vector Substances 0.000 claims abstract description 51
- 238000007670 refining Methods 0.000 claims description 4
- 238000011524 similarity measure Methods 0.000 claims description 3
- 238000004590 computer program Methods 0.000 claims description 2
- 230000008569 process Effects 0.000 abstract description 50
- 230000011664 signaling Effects 0.000 abstract description 19
- 238000012804 iterative process Methods 0.000 abstract description 3
- 230000015654 memory Effects 0.000 description 26
- 238000004891 communication Methods 0.000 description 18
- 238000012545 processing Methods 0.000 description 16
- 238000010586 diagram Methods 0.000 description 8
- 230000006870 function Effects 0.000 description 8
- 238000012360 testing method Methods 0.000 description 7
- 238000005457 optimization Methods 0.000 description 6
- 230000006835 compression Effects 0.000 description 5
- 238000007906 compression Methods 0.000 description 5
- 238000001914 filtration Methods 0.000 description 4
- 230000002093 peripheral effect Effects 0.000 description 4
- 238000013139 quantization Methods 0.000 description 4
- 230000009466 transformation Effects 0.000 description 4
- 238000005192 partition Methods 0.000 description 3
- 230000003044 adaptive effect Effects 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 2
- 238000006243 chemical reaction Methods 0.000 description 2
- 238000012937 correction Methods 0.000 description 2
- 230000006872 improvement Effects 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000003936 working memory Effects 0.000 description 2
- 101100493820 Caenorhabditis elegans best-1 gene Proteins 0.000 description 1
- 241000023320 Luma <angiosperm> Species 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 239000002131 composite material Substances 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 229910003460 diamond Inorganic materials 0.000 description 1
- 239000010432 diamond Substances 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000003780 insertion Methods 0.000 description 1
- 230000037431 insertion Effects 0.000 description 1
- OSWPMRLSEDHDFF-UHFFFAOYSA-N methyl salicylate Chemical compound COC(=O)C1=CC=CC=C1O OSWPMRLSEDHDFF-UHFFFAOYSA-N 0.000 description 1
- 239000000203 mixture Substances 0.000 description 1
- 229920001690 polydopamine Polymers 0.000 description 1
- 238000007781 pre-processing Methods 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 238000001228 spectrum Methods 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 230000002123 temporal effect Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/103—Selection of coding mode or of prediction mode
- H04N19/11—Selection of coding mode or of prediction mode among a plurality of spatial predictive coding modes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/103—Selection of coding mode or of prediction mode
- H04N19/105—Selection of the reference unit for prediction within a chosen coding or prediction mode, e.g. adaptive choice of position and number of pixels used for prediction
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/17—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
- H04N19/176—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a block, e.g. a macroblock
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/50—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
- H04N19/503—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
- H04N19/51—Motion estimation or motion compensation
- H04N19/513—Processing of motion vectors
- H04N19/517—Processing of motion vectors by encoding
- H04N19/52—Processing of motion vectors by encoding by predictive encoding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/60—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
- H04N19/61—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding in combination with predictive coding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/70—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by syntax aspects related to video coding, e.g. related to compression standards
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
In video coding systems, it is proposed to improve intra prediction based on intra block copying by allowing decoder side refinement, allowing further refinement of block vectors obtained from IBCs using a template matching process. In the template matching, the decoder searches for the best match of the current block (L-shaped) template within the reconstruction region in an iterative process adjacent to the block vector determined using the IBC 10 prediction. This technique allows to obtain finer precision than is possible with IBC, while minimizing the amount of encoded information. In at least one embodiment, where coarse precision is used for IBC, it allows benefiting at the same time from the significant coding gain provided by IBC, while providing much finer precision with reduced signaling of the block vector.
Description
Technical Field
The present disclosure is in the field of video compression, and at least one embodiment more particularly relates to intra block copying using template matching.
Background
To achieve high compression efficiency, image and video coding schemes typically employ prediction and transformation to exploit spatial and temporal redundancy in video content. Generally, intra or inter prediction is used to utilize intra or inter correlation, and then transform, quantize, and entropy encode the differences (commonly denoted as prediction errors or prediction residuals) between the original image block and the predicted image block. During encoding, for example, the original image block is typically divided/divided into sub-blocks using various division means such as a quadtree. To reconstruct video, the compressed data is decoded by an inverse process corresponding to prediction, transformation, quantization, and entropy coding.
Existing methods for encoding and decoding show some limitations, for example when using intra prediction. Thus, there is a need for improvements in the art.
Disclosure of Invention
The shortcomings and drawbacks of the prior art are addressed and addressed by the general aspects described herein.
A first aspect relates to a method for a block of a picture of a video, the method comprising: determining a template based on samples adjacent to the block; selecting a matching template from a set of template candidates in a reconstructed block of the picture; and reconstructing the block by copying samples of the selected template into the block. In another embodiment of the first aspect, the selecting step further comprises: determining the position of the template and the searching precision; determining a set of template candidates based on the location and the accuracy, wherein the template candidates further comprise templates at a current location; similarity between the sample of the template and the sample of the template candidate is measured, and the template with the best similarity is selected.
A second aspect relates to a method comprising: obtaining data representing blocks of a picture of a video; reconstructing a block of a picture of a video according to any one of the first aspects or variations thereof; and decoding the picture data using the reconstructed block.
A third aspect relates to a method comprising: obtaining data representing blocks of a picture of a video; reconstructing a block of a picture of a video according to any one of the first aspects or variations thereof; and encoding the picture data using the reconstructed block.
A fourth aspect relates to an apparatus, the apparatus comprising a decoder configured to: obtaining data representing blocks of a picture of a video; reconstructing a block of a picture of a video according to any one of the first aspects or variations thereof; and decoding the picture data using the reconstructed block.
A fifth aspect relates to an apparatus, the apparatus comprising an encoder configured to: obtaining data representing blocks of a picture of a video; reconstructing a block of a picture of a video according to any one of the first aspects or variations thereof; and encoding the picture data using the reconstructed block.
According to a general aspect of at least one embodiment, there is provided a computer program product comprising instructions which, when the program is executed by a processor, cause the processor to perform any of the encoding/decoding embodiments or variants.
According to a general aspect of at least one embodiment, there is provided a non-transitory computer readable medium storing program code instructions for implementing the steps of a method according to any of the described coding embodiments or variants.
Drawings
Fig. 1 shows a block diagram of a video encoder according to an embodiment.
Fig. 2 shows a block diagram of a video decoder according to an embodiment.
FIG. 3 illustrates a block diagram of an example of a system in which various aspects and embodiments are implemented.
Fig. 4A illustrates the principle of intra prediction using intra block copy.
Fig. 4B shows the allowable search range for intra block copy of the current block.
Fig. 4C illustrates the principle of template matching for inter-coding.
Fig. 5 illustrates the principles of intra prediction based on intra block copy using template matching in accordance with at least one embodiment.
Fig. 6 shows an embodiment using IBC AMVP mode with 4-pixel precision.
Fig. 7 shows an embodiment using IBC AMVP mode with 1 pixel precision.
Fig. 8A-8J illustrate examples of cross-mode based IBC (TM) refinement in accordance with at least one embodiment.
Fig. 9A depicts a block reconstruction method according to an embodiment.
Fig. 9B depicts a template matching method including refinement according to an embodiment.
Fig. 10 shows the correspondence between blocks and templates.
Detailed Description
Various embodiments relate to a video coding system in which, in at least one embodiment, it is proposed to improve the intra prediction part of video compression by extending the block matching process of Intra Block Copy (IBC) using further refinement based on template matching in order to find L-shaped neighboring pixels (called templates) within the reconstructed block of the picture that best match the template of the current block.
An encoding method, a decoding method, an encoding device, and a decoding device based on this principle are proposed.
Furthermore, while principles are described in relation to particular drafts of VVC (versatile video coding) or HEVC (high efficiency video coding) specifications, aspects of the invention are not limited to VVC or HEVC and may be applied to, for example, other standards and recommendations (whether pre-existing or developed in the future) and extensions of any such standards and recommendations (including VVC and HEVC). The aspects described in this application may be used alone or in combination unless otherwise indicated or technically excluded.
Fig. 1 shows a block diagram of a video encoder 100 according to an embodiment. Variations of this encoder 100 are contemplated, but for clarity, the encoder 100 is described below without describing all contemplated variations. Prior to encoding, the video sequence may undergo a pre-encoding process (101), e.g., applying a color transform to the input color picture (e.g., conversion from RGB 4:4 to YCbCr 4:2: 0), or performing remapping of the input picture components, in order to obtain a more resilient signal distribution for compression (e.g., histogram equalization using one of the color components). Metadata may be associated with the preprocessing and attached to the bitstream.
In the encoder 100, pictures are encoded by encoder elements, as described below. The pictures to be encoded are partitioned (102) and processed in units such as CUs. For example, each unit is encoded using an intra mode or an inter mode. When a unit is encoded in intra mode, the encoder performs intra prediction (160). In inter mode, motion estimation (175) and motion compensation (170) are performed. The encoder decides (105) which of the intra mode or inter mode is used to encode the unit and indicates the intra/inter decision by e.g. a prediction mode flag. For example, a prediction residual is calculated by subtracting (110) the predicted block from the initial image block.
The prediction residual is then transformed (125) and quantized (130). The quantized transform coefficients, as well as motion vectors and other syntax elements, are entropy encoded (145) to output a bitstream. The encoder may skip the transform and directly apply quantization to the untransformed residual signal. The encoder may bypass both transformation and quantization, i.e. directly encode the residual without applying a transformation or quantization process.
The encoder decodes the encoded block to provide a reference for further prediction. The quantized transform coefficients are dequantized (140) and inverse transformed (150) to decode the prediction residual. The decoded prediction residual and the predicted block are combined (155) to reconstruct the image block. An in-loop filter (165) is applied to the reconstructed slice to perform, for example, deblocking/SAO (sample adaptive offset) filtering, adaptive Loop Filter (ALF) filtering to reduce coding artifacts. The filtered image is stored at a reference picture buffer (180).
Fig. 2 shows a block diagram of a video decoder 200 according to an embodiment. In decoder 200, the bit stream is decoded by a decoder element, as described below. The video decoder 200 generally performs a decoding step that is the inverse of the encoding step. Encoder 100 also typically performs video decoding as part of encoding video data. In particular, the input to the decoder comprises a video bitstream, which may be generated by the video encoder 100. First, the bitstream is entropy decoded (230) to obtain transform coefficients, motion vectors, and other encoded information. The picture partition information indicates how to partition the picture. Thus, the decoder may divide (235) the pictures according to the decoded picture partition information. The transform coefficients are dequantized (240) and inverse transformed (250) to decode the prediction residual. The decoded prediction residual and the predicted block are combined (255) to reconstruct the image block. The predicted block may be obtained (270) from intra prediction (260) or motion compensated prediction (i.e., inter prediction) (275). An in-loop filter (265) is applied to the reconstructed image. The filtered image is stored at a reference picture buffer (280).
The decoded picture may further undergo post-decoding processing (285), such as an inverse color transform (e.g., conversion from YCbCr 4:2:0 to RGB 4:4:4), or performing an inverse remapping of the remapping process performed in the pre-encoding processing (101). The post-decoding process may use metadata derived in the pre-encoding process and signaled in the bitstream.
FIG. 3 illustrates a block diagram of an example of a system in which various aspects and embodiments are implemented. The system 1000 may be embodied as a device including the various components described below and configured to perform one or more of the aspects described in this document. Examples of such devices include, but are not limited to, various electronic devices such as personal computers, laptops, smartphones, tablets, digital multimedia set-top boxes, digital television receivers, personal video recording systems, connected home appliances, and servers. The elements of system 1000 may be embodied in a single Integrated Circuit (IC), multiple ICs, and/or discrete components, alone or in combination. For example, in at least one embodiment, the processing and encoder/decoder elements of system 1000 are distributed across multiple ICs and/or discrete components. In various embodiments, system 1000 is communicatively coupled to one or more other systems or other electronic devices via, for example, a communication bus or through dedicated input ports and/or output ports. In various embodiments, system 1000 is configured to implement one or more of the aspects described in this document.
The system 1000 includes at least one processor 1010 configured to execute instructions loaded therein for implementing various aspects such as those described in this document. The processor 1010 may be a general purpose processor, a special purpose processor, a conventional processor, a Digital Signal Processor (DSP), a plurality of microprocessors, one or more microprocessors in association with a DSP core, a controller, a microcontroller, application Specific Integrated Circuits (ASICs), field Programmable Gate Arrays (FPGAs) circuits, any other type of Integrated Circuit (IC), a state machine, or the like. The processor 1010 may include an embedded memory, an input-output interface, and various other circuitry known in the art. The system 1000 includes at least one memory 1020 (e.g., volatile memory device and/or non-volatile memory device). The system 1000 includes a storage device 1040, which may include non-volatile memory and/or volatile memory, including, but not limited to, electrically erasable programmable read-only memory (EEPROM), read-only memory (ROM), programmable read-only memory (PROM), random Access Memory (RAM), dynamic Random Access Memory (DRAM), static Random Access Memory (SRAM), flash memory, a magnetic disk drive, and/or an optical disk drive. By way of non-limiting example, storage 1040 may include internal storage, attached storage (including removable and non-removable storage), and/or network-accessible storage.
The system 1000 includes an encoder/decoder module 1030 configured to process data to provide encoded video or decoded video, for example, and the encoder/decoder module 1030 may include its own processor and memory. Encoder/decoder module 1030 represents one or more modules that may be included in a device to perform encoding and/or decoding functions. As is well known, an apparatus may include one or both of an encoding module and a decoding module. Additionally, the encoder/decoder module 1030 may be implemented as a stand-alone element of the system 1000 or may be incorporated within the processor 1010 as a combination of hardware and software as known to those skilled in the art.
Program code to be loaded onto processor 1010 or encoder/decoder 1030 to perform various aspects described in this document may be stored in storage device 1040 and subsequently loaded onto memory 1020 for execution by processor 1010. According to various implementations, one or more of the processor 1010, memory 1020, storage 1040, and encoder/decoder module 1030 may store one or more of various items during execution of the processes described in this document. Such storage items may include, but are not limited to, input video, decoded video or partially decoded video, bitstreams, matrices, variables, and intermediate or final results of processing equations, formulas, operations, and arithmetic logic.
In some embodiments, memory internal to the processor 1010 and/or encoder/decoder module 1030 is used to store instructions as well as to provide working memory for processing as needed during encoding or decoding. However, in other embodiments, memory external to the processing device (e.g., the processing device may be the processor 1010 or the encoder/decoder module 1030) is used for one or more of these functions. The external memory may be memory 1020 and/or storage device 1040, such as dynamic volatile memory and/or non-volatile flash memory. In several embodiments, external non-volatile flash memory is used to store an operating system such as a television. In at least one embodiment, a fast external dynamic volatile memory such as RAM is used as a working memory for video encoding and decoding operations, such as MPEG-2 (MPEG refers to moving picture experts group, MPEG-2 is also known as ISO/IEC 13818, and 13818-1 is also known as h.222, 13818-2 is also known as h.262), HEVC (HEVC refers to high efficiency video encoding, also known as h.265 and MPEG-H part 2), or VVC (universal video encoding, a new standard developed by the joint video experts group (jfet)).
Input to the elements of system 1000 may be provided through various input devices as indicated in block 1130. Such input devices include, but are not limited to: (i) A Radio Frequency (RF) section that receives an RF signal transmitted over the air, for example, by a broadcaster; (ii) A Component (COMP) input terminal (or set of COMP input terminals); (iii) a Universal Serial Bus (USB) input terminal; and/or (iv) a High Definition Multimedia Interface (HDMI) input terminal. Other examples not shown in fig. 3 include composite video.
In various embodiments, the input device of block 1130 has associated respective input processing elements as known in the art. For example, the RF section may be associated with elements suitable for: (i) select the desired frequency (also referred to as a select signal, or band limit the signal to one frequency band), (ii) down-convert the selected signal, (iii) band limit again to a narrower frequency band to select a signal band that may be referred to as a channel in some embodiments, for example, (iv) demodulate the down-converted and band limited signal, (v) perform error correction, and (vi) de-multiplex to select the desired data packet stream. The RF portion of the various embodiments includes one or more elements for performing these functions, such as a frequency selector, a signal selector, a band limiter, a channel selector, a filter, a down-converter, a demodulator, an error corrector, and a demultiplexer. The RF section may include a tuner that performs various of these functions including, for example, down-converting the received signal to a lower frequency (e.g., intermediate or near baseband frequency) or to baseband. In one set-top box embodiment, the RF section and its associated input processing elements receive RF signals transmitted over a wired (e.g., cable) medium and perform frequency selection by filtering, down-converting and re-filtering to a desired frequency band. Various embodiments rearrange the order of the above (and other) elements, remove some of these elements, and/or add other elements that perform similar or different functions. Adding components may include inserting components between existing components, such as an insertion amplifier and an analog-to-digital converter. In various embodiments, the RF section includes an antenna.
Additionally, the USB and/or HDMI terminals may include respective interface processors for connecting the system 1000 to other electronic devices across a USB and/or HDMI connection. It should be appreciated that various aspects of the input processing (e.g., reed-Solomon error correction) may be implemented as necessary, for example, within a separate input processing IC or within the processor 1010. Similarly, aspects of USB or HDMI interface processing may be implemented within a separate interface IC or within the processor 1010, if desired. The demodulated, error corrected, and demultiplexed streams are provided to various processing elements including, for example, a processor 1010 and an encoder/decoder 1030 that operate in conjunction with memory and storage elements to process the data streams as needed for presentation on an output device.
The various elements of system 1000 may be provided within an integrated housing within which the various elements may be interconnected and data transferred therebetween using a suitable connection arrangement 1140 (e.g., internal buses, including inter-IC (I2C) buses, wiring, and printed circuit boards, as is known in the art).
The system 1000 includes a communication interface 1050 that enables communication with other devices via a communication channel 1060. Communication interface 1050 may include, but is not limited to, a transceiver configured to transmit and receive data over communication channel 1060. Communication interface 1050 may include, but is not limited to, a modem or network card, and communication channel 1060 may be implemented within a wired and/or wireless medium, for example.
In various embodiments, data is streamed or otherwise provided to system 1000 using a wireless network, such as a Wi-Fi network, for example IEEE 802.11 (IEEE refers to institute of electrical and electronics engineers). Wi-Fi signals of these embodiments are received through a communication channel 1060 and a communication interface 1050 suitable for Wi-Fi communication. The communication channel 1060 of these embodiments is typically connected to an access point or router that provides access to external networks, including the internet, for allowing streaming applications and other communications across operators. Other embodiments provide streamed data to the system 1000 using a set top box that delivers the data over an HDMI connection of input block 1130. Still other embodiments provide streamed data to system 1000 using an RF connection of input block 1130. As described above, various embodiments provide data in a non-streaming manner. Additionally, various embodiments use wireless networks other than Wi-Fi, such as cellular networks or bluetooth networks.
The system 1000 may provide output signals to various output devices including a display 1100, speakers 1110, and other peripheral devices 1120. The display 1100 of various embodiments includes, for example, one or more of a touch screen display, an Organic Light Emitting Diode (OLED) display, a curved display, and/or a collapsible display. The display 1100 may be used in a television, tablet computer, laptop computer, cell phone (mobile phone), or other device. The display 1100 may also be integrated with other components (e.g., as in a smart phone), or may be a stand-alone display (e.g., an external monitor for a laptop). In various examples of implementations, other peripheral devices 1120 include one or more of a stand-alone digital video disc (or digital versatile disc) (DVR, which may be referred to by both terms), a disc player, a stereo system, and/or a lighting system. Various embodiments use one or more peripheral devices 1120 that provide functionality based on the output of the system 1000. For example, a disk player performs the function of playing the output of system 1000.
In various embodiments, control signals are communicated between the system 1000 and the display 1100, speakers 1110, or other peripheral 1120 using signaling such as av.link, consumer Electronics Control (CEC), or other communication protocol that allows device-to-device control with or without user intervention. Output devices may be communicatively coupled to system 1000 via dedicated connections through respective interfaces 1070, 1080, and 1090. Alternatively, the output device may be connected to the system 1000 via the communication interface 1050 using a communication channel 1060. In an electronic device (such as, for example, a television), the display 1100 and speaker 1110 may be integrated in a single unit with other components of the system 1000. In various embodiments, the display interface 1070 includes a display driver, such as, for example, a timing controller (tcon) chip.
For example, if the RF portion of input 1130 is part of a stand-alone set-top box, display 1100 and speaker 1110 may alternatively be independent with respect to one or more of the other components. In various implementations where display 1100 and speaker 1110 are external components, the output signals may be provided via dedicated output connections, including, for example, HDMI ports, USB ports, or COMP outputs.
The implementation may be performed by computer software implemented by the processor 1010, or by hardware, or by a combination of hardware and software. As a non-limiting example, these embodiments may be implemented by one or more integrated circuits. As a non-limiting example, memory 1020 may be of any type suitable to the technical environment and may be implemented using any suitable data storage technology such as optical memory devices, magnetic memory devices, semiconductor-based memory devices, fixed memory and removable memory. As a non-limiting example, the processor 1010 may be of any type suitable to the technical environment, and may encompass one or more of microprocessors, general purpose computers, special purpose computers, and processors based on a multi-core architecture.
The technical field of the present invention relates to the intra prediction phase of video compression schemes.
Fig. 4A illustrates the principle of intra prediction using intra block copy. Intra Block Copy (IBC) is a tool that is particularly suitable for so-called screen content coding, i.e. non-natural computer-generated sequences comprising large identical areas such as user interface screens. IBC is based on finding a matching reference block within the reconstructed region 400 of the current frame. When a match between the current block 410 and the reconstructed block 411 is found at the time of encoding, a so-called block vector 420 (similar to a motion vector) between the current block and the matched block is selected for the reconstructed block. In one example of IBC mode, the current block 410 is reconstructed by copying the samples of block 411.
IBC AMVP mode proposes motion correlation techniques using conventional AMVP mode inter prediction limited to reconstructing samples. More specifically, at the encoder, IBC AMVP mode selects a number of used input vectors as predictors (or zeros) and performs a process similar to motion estimation for each to find the block most similar to the current block within a window in reconstructed samples. The RDO process then allows the selection of the best predictor. The index of the best predictor is signaled and the vector difference is the difference between the estimated vector and the input vector. At the decoder, IBC AMVP mode selects the same input vector. It adds the transmitted vector difference to the input vector indicated by the signaled index and reconstructs the current block by using the resulting vector.
IBC merge mode proposes motion correlation techniques using conventional merge mode inter prediction limited to reconstructing samples. More specifically, at the encoder, the IBC merge mode selects a number of used input vectors as predictors. The RDO process then allows the selection of the best predictor. The index of the best predictor is signaled. At the decoder, the IBC merge mode selects the same input vector and reconstructs the current block using the input vector indicated by the transmitted index.
Fig. 4B shows the allowable search range for intra block copy of the current block. Indeed, in an exemplary implementation using VVC, the search range is extended to pixels outside the current Coding Tree Unit (CTU), to the left CTU, depending on the block location. However, some block locations are not allowed and cannot be used for IBC. In this figure, the current block within the current CTU is identified by "curr" while the disallowed blocks are identified by white forks.
Fig. 4C illustrates the principle of template matching for inter-coding. The idea of motion vector refinement can be used to improve inter-coding. In particular, a 16×16 search window may be defined around the reference block, wherein a template matching process is performed between the template of the current block and the reference block template. This process is hereinafter referred to as TM search. Since the template matching operation is performed at both the encoder side and the decoder side, this results in improved motion accuracy without further signaling. However, this technique is being used for inter prediction.
The embodiments described below take the foregoing into consideration in designing. The encoder 100 of fig. 1, the decoder 200 of fig. 2, and the system 1000 of fig. 3 are adapted to implement at least one of the embodiments described below, and more particularly, the intra-prediction element 160 of the encoder 100 and the intra-prediction element 260 of the decoder 200.
In at least one embodiment, it is proposed to improve intra prediction based on intra block copy by allowing decoder side refinement, in other words, allowing further refinement of block vectors obtained from IBCs using a template matching process. In this template matching, the decoder searches for the best match of the current block (L-shaped) template within the reconstruction region in an iterative process in the neighborhood of the block vector determined using IBC prediction. This technique allows to obtain finer precision than is possible with IBC, while minimizing the amount of encoded information. In at least one implementation where coarse precision is used for IBC, it allows benefiting at the same time from the significant coding gain provided by IBC, while providing much finer precision with reduced signaling of block vectors.
Fig. 5 illustrates the principles of intra prediction based on intra block copy using template matching in accordance with at least one embodiment. Similar to the intra block coding of fig. 4A, the idea is to reconstruct the current block by copying samples of the already reconstructed block. However, it is proposed to perform a template matching operation based on already decoded L-shaped neighboring pixels of the current block, so that this operation can be done at the decoder side without additional signaling. The IBC process is first performed to generate a block vector so that the decoder determines the coordinates of the reference block (within the current frame). A search range area is defined around the reference block and L-shaped neighboring pixels of the current block (current template) are used to find the best matching template within the defined search range. This results in improved bit rate savings, as finer block vectors can be used without additional signaling on the decoder side. When a matching L-shaped template is found, the samples of the corresponding block may be copied into the current block. The reconstructed region 510 of the current frame is shown. The already reconstructed upper and left neighboring pixels 502 of the current block 501 form an L-shaped template. The IBC first determines a block vector 520. A search range area 515 is then defined. In this area, an L-shaped template 512 is found. For this purpose, a metric for measuring the similarity between samples of the L-shape, such as the Sum of Average Differences (SAD), may be used. The search range area is then sampled according to the determined accuracy and/or using different techniques to determine a set of L-shaped template candidates. The similarity between the L-shaped template candidates and L-shaped template 502 is then measured. The candidate with the best similarity is then selected. As described further below, the process may iterate multiple times to potentially cover the search range area with different levels of precision. When a match between an L-template candidate and L-template 502 is determined, the samples corresponding to block 511 of the matching template are then copied directly into block 501. This process applies to both encoding and decoding and may be implemented, for example, in the intra-prediction module 160 of the encoder of fig. 1 or in the intra-prediction module 260 of the decoder of fig. 2 and more generally in the encoder/decoder module 1030 of the apparatus 1000 of fig. 3.
In at least one embodiment, the template matching of fig. 5 is based on IBC merge mode. In this mode, a conventional merge mode inter prediction motion correlation technique using a reconstructed sample is proposed. IBC merge predictor candidates are chosen for conventional IBC merge, but then used as input vectors for TM searches. The TM cost of each input candidate is determined (in other words, the similarity measure introduced above, e.g., based on SAD), and the input candidate with the smallest TM cost is refined towards the smallest TM cost within the search window (to be defined). The refined IBC merge predictor candidate is then used as an IBC merge vector for prediction. Index signaling is not required because candidates are selected based on their TM cost, and thus the same candidates will be selected at the time of encoding and decoding.
Since the IBC mode uses only 1-pixel or 4-pixel vector precision, the IBC merge refinement process may be performed toward 1-pixel, but may also be performed with finer precision.
In at least one embodiment, the template matching of fig. 5 is based on IBC AMVP mode. In this mode, a conventional AMVP mode inter prediction motion related technique using a reconstructed sample limited is proposed. IBC AMVP predictor candidates (as in conventional IBC AMVP) are chosen and used as input vectors for TM searches. The TM cost for each input candidate is calculated, refining the input candidate with the smallest TM cost towards the smallest TM cost within the search window (to be defined). After rounding with the required precision, the refined IBC AMVP predictor is then used as input to the Motion Estimation (ME) process. Rounding is based on AMVR. When AMVR is enabled, the precision is defined by the index in the signaling. When AMVR is disabled, the precision is set to 1 pixel.
Since the IBC mode uses only 1-pixel or 4-pixel vector precision, the IBC AMVP refinement process may be performed towards 1-pixel, but may also be performed with finer precision (even though it must be rounded at AMVR).
Fig. 6 shows an embodiment using IBC AMVP mode with 4-pixel precision. The arrows show IBC block vectors. In IBC AMVP mode, TM may also be used after ME, where the estimated vector is refined towards minimum TM cost within a search window (e.g., a 16-pixel or 32-pixel window) around the current location. But in this case there is a way to reduce the number of test locations, as some are already tested by the ME. For example, if the IBC AMVR precision is 4 pixels and the refinement is performed with a 1 pixel precision, then the 4 pixel location may be removed from the search (as already tested by ME and worse). This is illustrated in fig. 6, where the 4-pixel positions identified by circles can be removed from the TM test with a 1-pixel accuracy.
In at least one embodiment, template matching is used to refine the vector with finer precision, hereinafter referred to as TM refinement. The aim is to determine samples that better match the template by overcoming the precision limitations of the block vector. As already mentioned, IBC uses only 1 pixel or 4 pixel precision for IBC block vector and IBC block vector difference (if AMVR is on, otherwise only 1 pixel is used). The TM may then be used in another way to refine the vector with finer precision in both IBC merge mode and IBC AMVP mode. In this case, after normal processing, the obtained vector may be further refined towards finer precision within the TM search window that must depend on the precision: if the precision is 1 pixel, the window cannot be larger than 2 pixels around the current vector, or if the precision is 4 pixels, the window cannot be larger than 8 pixels around the current vector.
Fig. 7 shows an embodiment using IBC AMVP mode with 1 pixel precision. The arrows show IBC block vectors. In this example, if the precision is 1 pixel, all surrounding (i.e., adjacent) 1 pixel locations (dashed points) have been tested by ME and are worse than the current (black point) locations, so refinement can only be done within this 2 pixel large square search range area. If the precision is 4 pixels, all surrounding 4 pixel positions (white points) have been tested by ME and are worse than the current position (black points), so refinement can only be done within the 8 pixel large square.
In all previous cases, the precision of the refinement process must be defined (from 1 pixel or 4 pixels to 1 pixel, 1/2 pixel, 1/4 pixel, 1/8 pixel, 1/16 pixel). Different alternatives may be used:
in a variant embodiment, the precision of the refinement process depends on the input precision, for example from 1 pixel to 1/16 pixel and from 4 pixels to 1/4 pixel to limit the number of refinement steps; or alternatively
In a variant embodiment, the precision of the refinement process is fixed, for example reducing the IBC precision to only 4 pixels (only IBC 4 pixels are used), and the template matching allows vector refinement with 1 pixel or finer precision to avoid AMVR signaling, reducing the number of motion estimation steps and vector differential signaling costs; or alternatively
In a variant embodiment, the precision of the refinement procedure uses a coarser precision (such as 8 pixels or 16 pixels) for IBC, then TM allows retrieving 1 pixel precision or finer precision in order to avoid AMVR signaling as well, but also reduces the number of motion estimation steps and vector differential signaling costs even more.
It is important to note that some sub-pixel interpolation is required whenever the final precision is finer than 1 pixel. Such sub-pixel interpolation is currently avoided in IBCs (only 4 pixels and 1 pixel are used).
In at least one embodiment, IBC TM refinement is performed by testing all locations within the TM search window.
In at least one implementation, IBC (TM) refinement is performed by testing a number of locations N (e.g., 4 or 8) around the current location and then repeating this process a number of times M until a minimum TM cost is reached. The overall process may refine the accuracy of each iteration step.
In at least one embodiment, the IBC TM refinement uses a cross (4 positions: x or y +/-1) or diamond (not shown), 8 positions: x/-2 of x or y or x and y +/-1) pattern with a certain precision, then repeats the pattern in a direction that reduces the TM cost until a minimum cost is reached, and finally repeats one step by reducing the precision until the required precision. For example, one implementation performs multiple steps with 1 pixel precision to obtain a 1 pixel location that minimizes TM costs, then performs one step around the location with 1/2 pixel, then performs one step with 1/4 pixel, then performs one step with 1/8 pixel, etc.
Fig. 8A-8J illustrate examples of cross-mode based IBC (TM) refinement in accordance with at least one embodiment. As introduced above, it is based on minimizing TM costs for a given precision, after which another refinement is tried with finer precision. In the example of fig. 8A-8J, the process starts from a black dot and performs 6 refinement steps (fig. 8A-8F, respectively) with 1 pixel precision to obtain the best 1 pixel dot (i.e., the dot at 1 pixel with the minimum TM cost). The figure specifically shows that the process reduces the number of test locations in each step, as some locations have been tested in previous steps (or outside the TM search window, not shown). For example, at the first step of fig. 8A, all four locations are tested. Since the location with the smallest TM cost is the correct location, the process iterates from that location. However, the left position need not be tested, as it is the starting point for the previous step. In the further steps of fig. 8B to 8F, the number of positions tested is 3, 2, 3 and 2, respectively. Then, in FIG. 8F, neither test site improves the TM cost. Therefore, as shown in fig. 8G, the accuracy (from 1 pixel to 1/2 pixel) is improved, and finer search is performed. The same principle applies again and a 1/4 pixel search is performed in fig. 8H. Fig. 8I shows a continuous refinement step, where the final location with minimum TM cost is the fork filled circle. Fig. 8J shows how the refinement process maps onto the original grid.
Fig. 9A depicts a block reconstruction method according to an embodiment. The method is used for both encoding and decoding and may be implemented, for example, in the intra prediction module 160 of the encoder of fig. 1 or in the intra prediction module 260 of the decoder of fig. 2 and more generally in the encoder/decoder module 1030 of the apparatus 1000 of fig. 3. The method is applied to the current block. In step 910, a block vector of the current block is determined. At the decoder side, the block vector is determined by obtaining information representing the block vector from the bitstream. At the encoder side, the block vectors are determined by a Rate Distortion Optimization (RDO) process. In step 920, a template is determined that includes neighboring (or partially surrounding) samples of the current block. In the search range area of the sample that has been reconstructed, the template is searched for and the best matching template of the same shape is determined. In step 930, the current block is reconstructed by copying the samples of the block corresponding to the best matching template.
Fig. 9B depicts a template matching method including refinement according to an embodiment. This corresponds to step 920 of fig. 9A and is an iterative process.
In step 921, a search range area is determined. The search area considers the boundaries of the picture and the reconstruction area. It may be of a fixed size (e.g. 32 x 32), or it may depend on the size of the initial precision (e.g. 8 x 8 if the precision is 4 pixels, 2 x 2 if the precision is 1 pixel), or it may depend on the current block size (e.g. 8 pixels more than the block size, so if the block size is 16 x 8, the window is 32 x 24).
In step 922, accuracy is determined. In at least one decoding related embodiment, in an initial iteration, an initial accuracy is obtained from information from the bitstream. In at least one decoding related embodiment, in an initial iteration, the initial accuracy is predetermined. The first iteration of the method starts from the position indicated by the block vector and uses the initial precision. Further iterations may move the position to a new position and/or the accuracy may be refined to finer accuracy.
In step 923, the position and accuracy allow for the determination of template candidates. A so-called template candidate is a set of samples in the form of a template but located at candidate locations. Different techniques for determining template candidates have been described above. In at least one embodiment, all candidates are selected for which the distance (geometry) to the location in any direction within the search range area is equal to the accuracy. For example, if the precision is 1 pixel, all positions immediately surrounding the position are selected. In at least one embodiment, all candidates within the search range area are selected whose distance to the location in the horizontal or vertical direction is equal to the accuracy. This is the embodiment shown in fig. 8A to 8J. Templates located at the current location are also part of candidates. Candidates outside the search range area are not considered.
In step 924, the best matching template is selected. This is done by first measuring the similarity between the sample values of the template under consideration of the block and the sample values of the different template candidates (previously identified as TM costs). SAD is an example of a metric for measuring similarity, but any other similarity metric may be used, such as SATD (sum of absolute transformed differences) or MSE (mean square error). When one of the template candidates provides a lower TM cost than the template at the current location, then the method iterates 925 again from step 922 from the new location. In at least one embodiment, when no template candidates provide a lower TM cost than the template at the current location, then the method is iterated again from step 921 from the current location with finer accuracy. When there may no longer be an improvement in TM cost and when the maximum accuracy has been reached, the iteration is stopped and the candidate template is selected as the best matching template, in other words the candidate template whose sample is most similar to the sample of the template of the block.
In step 926, the current block is reconstructed by copying samples of the block corresponding to the selected candidate template.
Fig. 10 shows the correspondence between blocks and templates. Such correspondence is made with respect to the position and size of the block and the position, size and width of the template. The template 1010 is adjacent to (or partially surrounds) the corresponding block 1000 and includes rows of pixels 1011 at the top of the block, columns of pixels 1012 on the left side of the block, and rectangular pixels 1013 at the upper left of the block that fill the gaps between the rows and columns. A 4-pixel wide and high template has proven to be an effective choice. Thus, determining blocks from templates is straightforward, and vice versa. The figure shows a template with column width equal to the row height and thus rectangular 1013 is square. Other configurations are possible where these numbers are unequal. In at least one embodiment, the template width is one pixel and thus the template is a single row of adjacent tiles.
Some additional syntax may be used to support the previous embodiments.
According to at least one implementation, information representing internal IBC precision (e.g., 1 pixel, 2 pixels, 4 pixels, or 16 pixels) may be signaled for the entire sequence at the SPS level and appropriate for each frame by additional signaling at the picture or slice level. For example, the internal IBC precision may be set to 8 pixels at the SPS level, then the size of the TM search window is 16 pixels, with its picture header set to refinement toward 1 pixel for one frame, and its picture header set to refinement toward 1/4 pixel for the subsequent frame, etc. In variant embodiments, the internal IBC precision is predefined and therefore no additional syntax is required.
According to at least one implementation, the information item representing the refinement accuracy may be signaled for the entire sequence at the SPS level and adapted for each frame by additional signaling at the picture or slice level. In variant implementations, the refinement accuracy is predefined and therefore no additional syntax is required.
Various aspects are described herein, including tools, features, embodiments, models, methods, and the like. Many of these aspects are described in detail and at least illustrate individual characteristics, often in a manner that may sound limited. However, this is for clarity of description and does not limit the application or scope of these aspects. Indeed, all the different aspects may be combined and interchanged to provide further aspects. Moreover, these aspects may also be combined and interchanged with those described in previous submissions.
The aspects described and contemplated in this application may be embodied in many different forms. Fig. 1, 2, and 3 provide some embodiments, but other embodiments are contemplated, and discussion of these figures does not limit the breadth of the embodiments. At least one of these aspects generally relates to video encoding and decoding, and at least one other aspect generally relates to transmitting a generated or encoded bitstream. These and other aspects may be implemented as a method, an apparatus, a computer-readable storage medium having stored thereon instructions for encoding or decoding video data according to any of the methods, and/or a computer-readable storage medium having stored thereon a bitstream generated according to any of the methods.
Various methods are described herein, and each of the methods includes one or more steps or actions for achieving the method. Unless a particular order of steps or actions is required for proper operation of the method, the order and/or use of particular steps and/or actions may be modified or combined.
Various methods and other aspects described herein may be used to modify modules, such as intra-prediction modules (160, 260) of video encoder 100 and decoder 200, as shown in fig. 1 and 2. Furthermore, aspects of the present invention are not limited to VVC or HEVC, and may be applied to, for example, other standards and recommendations (whether pre-existing or developed in the future) and extensions of any such standards and recommendations (including VVC and HEVC). The aspects described in this application may be used alone or in combination unless otherwise indicated or technically excluded.
Various values are used in this application. The particular values are for illustration purposes and the aspects are not limited to these particular values.
Various implementations participate in decoding. As used in this application, "decoding" may encompass all or part of a process performed on a received encoded sequence, for example, in order to produce a final output suitable for display. In various implementations, such processes include one or more processes that are typically performed by a decoder. In various embodiments, such processes also or alternatively include processes performed by the various embodying decoders described in the present application.
As a further example, in one embodiment, "decoding" refers only to entropy decoding, in another embodiment "decoding" refers only to differential decoding, and in yet another embodiment "decoding" refers to a combination of entropy decoding and differential decoding. The phrase "decoding process" is intended to refer specifically to a subset of operations or broadly to a broader decoding process, as will be clear based on the context of the specific description, and is believed to be well understood by those skilled in the art.
Various implementations participate in the encoding. In a similar manner to the discussion above regarding "decoding," as used in this application, may encompass, for example, all or part of a process performed on an input video sequence to produce an encoded bitstream. In various embodiments, such processes include one or more processes typically performed by an encoder. In various embodiments, such processes also or alternatively include processes performed by the various embodying encoders described in the present application.
As a further example, in one embodiment, "encoding" refers only to entropy encoding, in another embodiment, "encoding" refers only to differential encoding, and in yet another embodiment, "encoding" refers to a combination of differential encoding and entropy encoding. Whether the phrase "encoding process" refers specifically to a subset of operations or broadly refers to a broader encoding process will be apparent based on the context of the specific description and is believed to be well understood by those skilled in the art.
Note that syntax elements used herein are descriptive terms. Thus, they do not exclude the use of other syntax element names.
The present disclosure has described various information, such as, for example, syntax, that may be transmitted or stored. This information can be encapsulated or arranged in a variety of ways, including, for example, in a manner common in video standards, such as placing the information in SPS, PPS, NAL units, headers (e.g., NAL unit headers or slice headers), or SEI messages. Other ways are also available, including for example, a general way for system-level or application-level criteria, such as placing information into one or more of the following:
sdp (session description protocol), which is a format for describing multimedia communication sessions for session notification and session invitation, is used, for example, as described in RFC and in connection with RTP (real-time transport protocol) transport.
DASH MPD (media presentation description) descriptor, e.g. a descriptor associated with a representation or collection of representations to provide additional characteristics to the content representation, as used in DASH and transmitted over HTTP.
RTP header extension, e.g. as used during RTP streaming.
Iso base media file format, for example, as used in OMAF and using a box, which is an object-oriented building block defined by a unique type identifier and length, also referred to as "atom" in some specifications.
e. HLS (HTTP real-time streaming) manifest transmitted over HTTP. For example, a manifest may be associated with a version or set of versions of content to provide characteristics of the version or set of versions.
When the figures are presented as flow charts, it should be understood that they also provide block diagrams of corresponding devices. Similarly, when the figures are presented as block diagrams, it should be understood that they also provide a flow chart of the corresponding method/process.
Various embodiments are directed to rate distortion optimization. In particular, during the encoding process, a balance or trade-off between rate and distortion is typically considered, often taking into account constraints of computational complexity. Rate distortion optimization is typically expressed as minimizing a rate distortion function, which is a weighted sum of rate and distortion. There are different approaches to solving the rate distortion optimization problem. For example, these methods may be based on extensive testing of all coding options (including all considered modes or coding parameter values) and evaluating their coding costs and the associated distortion of the reconstructed signal after encoding and decoding completely. Faster methods may also be used to reduce coding complexity, in particular the calculation of approximate distortion based on prediction or prediction residual signals instead of reconstructed residual signals. A mix of the two methods may also be used, such as by using approximate distortion for only some of the possible coding options, and full distortion for other coding options. Other methods evaluate only a subset of the possible coding options. More generally, many methods employ any of a variety of techniques to perform the optimization, but the optimization is not necessarily a complete assessment of both coding cost and associated distortion.
Various aspects are described herein, including tools, features, embodiments, models, methods, and the like. Many of these aspects are described in detail and at least illustrate individual characteristics, often in a manner that may sound limited. However, this is for clarity of description and does not limit the application or scope of these aspects. Indeed, all the different aspects may be combined and interchanged to provide further aspects. Moreover, these aspects may also be combined and interchanged with those described in previous submissions.
The specific implementations and aspects described herein may be implemented in, for example, a method or process, an apparatus, a software program, a data stream, or a signal. Even if only discussed in the context of a single form of implementation (e.g., discussed only as a method), the implementation of the features discussed may also be implemented in other forms (e.g., an apparatus or program). The apparatus may be implemented in, for example, suitable hardware, software and firmware. The method may be implemented in, for example, a processor, which refers generally to a processing device including, for example, a computer, a microprocessor, an integrated circuit, or a programmable logic device. Processors also include communication devices such as, for example, computers, tablets, smart phones, mobile phones, portable/personal digital assistants ("PDAs"), and other devices that facilitate the transfer of information between end users.
Reference to "one embodiment" or "an embodiment" or "one embodiment" or "an embodiment" and other variations thereof means that a particular feature, structure, characteristic, etc., described in connection with the embodiment is included in at least one embodiment. Thus, the appearances of the phrase "in one embodiment" or "in an embodiment" or "in one embodiment" or "in an embodiment" and any other variations that occur in various places throughout this application are not necessarily all referring to the same embodiment.
Additionally, the present application may be directed to "determining" various information. The determination information may include, for example, one or more of estimation information, calculation information, prediction information, or retrieval information from memory.
Furthermore, the present application may relate to "accessing" various information. The access information may include, for example, one or more of receiving information, retrieving information (e.g., from memory), storing information, moving information, copying information, computing information, determining information, predicting information, or estimating information.
Additionally, the present application may be directed to "receiving" various information. As with "access," receipt is intended to be a broad term. Receiving information may include, for example, one or more of accessing information or retrieving information (e.g., from memory). Further, during operations such as, for example, storing information, processing information, transmitting information, moving information, copying information, erasing information, computing information, determining information, predicting information, or estimating information, the "receiving" is typically engaged in one way or another.
In this application, the terms "reconstruct" and "decode" are used interchangeably, the terms "pixel" and "sample" are used interchangeably, and the terms "image," "picture," "frame," "slice," and "tile" are used interchangeably. Typically, but not necessarily, the term "reconstruction" is used on the encoder side, while "decoding" is used on the decoder side.
It should be understood that, for example, in the case of "a/B", "a and/or B", and "at least one of a and B", use of any of the following "/", "and/or" and "at least one" is intended to cover selection of only the first listed option (a), or selection of only the second listed option (B), or selection of both options (a and B). As a further example, in the case of "A, B and/or C" and "at least one of A, B and C", such phrases are intended to cover selection of only the first listed option (a), or only the second listed option (B), or only the third listed option (C), or only the first and second listed options (a and B), or only the first and third listed options (a and C), or only the second and third listed options (B and C), or all three options (a and B and C). As will be apparent to one of ordinary skill in the art and related arts, this extends to as many items as are listed.
Also, as used herein, the word "signaling" refers to (among other things) indicating something to the corresponding decoder. For example, in some implementations, the encoder signals a particular one of the luma compensation parameters. Thus, in one embodiment, the same parameters are used on both the encoder side and the decoder side. Thus, for example, an encoder may transmit (explicit signaling) certain parameters to a decoder so that the decoder may use the same certain parameters. Conversely, if the decoder already has specific parameters and others, signaling can be used without transmission (implicit signaling) to simply allow the decoder to know and select the specific parameters. By avoiding transmission of any actual functions, bit savings are achieved in various embodiments. It should be appreciated that the signaling may be implemented in various ways. For example, in various implementations, information is signaled to a corresponding decoder using one or more syntax elements, flags, and the like. Although the foregoing relates to the verb form of the word "signal," the word "signal" may also be used herein as a noun.
It will be apparent to one of ordinary skill in the art that implementations may produce various signals formatted to carry, for example, storable or transmittable information. The information may include, for example, instructions for performing a method or data resulting from one of the implementations. For example, the signal may be formatted to carry the bit stream of the described embodiments. Such signals may be formatted, for example, as electromagnetic waves (e.g., using the radio frequency portion of the spectrum) or baseband signals. Formatting may include, for example, encoding the data stream and modulating the carrier with the encoded data stream. The information carried by the signal may be, for example, analog or digital information. It is well known that signals may be transmitted over a variety of different wired or wireless links. The signal may be stored on a processor readable medium.
We describe a number of embodiments. The features of these embodiments may be provided separately or in any combination in the various claim categories and types. Further, embodiments may include one or more of the following features, devices, or aspects, alone or in any combination, across the various claim categories and types:
an apparatus comprising an apparatus according to any one of the decoding embodiments; and at least one of the following: (i) An antenna configured to receive a signal, the signal comprising a video block; (ii) A band limiter configured to limit the received signal to a frequency band including the video block; or (iii) a display configured to display an output representing a video block.
In a variation of the first aspect, the set of template candidates is determined by selecting all possible candidates according to the position and precision, the set of template candidates is determined by selecting candidates according to the position and precision in both the horizontal and vertical directions, the initial position of the template for an initial iteration is determined by modifying the position of the selected template until the similarity of the template candidate at the current position is better than the similarity of the other template candidates, the position is refined by iterating the template candidate at the current position, the precision is refined by iterating the template candidate under the condition that the similarity of the template candidate at the current position is better than the similarity of the other template candidates, the initial position of the template for an initial iteration is determined by a technique such as merge mode or Advanced Motion Vector Prediction (AMVP), and wherein the motion coding mode is applied to a reconstruction block of the picture, the initial position of the template for an initial iteration is determined using a coarse precision of 8 or 16 pixels, and wherein the iteration refines the precision to at most 1 pixel or sub-pixel precision, the information from the initial precision is obtained from the bitstream.
Claims (18)
1. A method for a block of a picture of a video, the method comprising:
-determining a template based on samples adjacent to the block;
-selecting a matching template from a set of template candidates in a reconstructed block of the picture; and
-reconstructing the block by copying samples of the selected template into the block.
2. The method of claim 1, wherein the selecting step further comprises:
-determining the location and accuracy of the search; and
-determining the set of template candidates based on the position and the precision.
3. The method of claim 1 or 2, wherein the matching template is selected based on a similarity measure between a sample of the template and a sample of the template candidate.
4. A method according to claim 3, wherein the template candidate with the best similarity measure is selected.
5. The method of any of claims 1-4, wherein the template candidates further comprise templates at a current location.
6. The method of any of claims 1-5, further comprising refining the selection by iterating the selecting step and modifying the location until the similarity of the template candidate at the modified location is better than the similarity of the other template candidates.
7. The method of any of claims 1-6, further comprising refining the location of the selected template by iterating through the template candidates by refining the precision on condition that the similarity of the template candidate at the current location is better than the similarity of the other template candidates.
8. The method of any of claims 1 to 7, wherein an initial position of a template for an initial iteration is determined by a technique such as merge mode or Advanced Motion Vector Prediction (AMVP) motion coding mode, and wherein the motion coding mode is applied to a reconstructed block of the picture.
9. The method of any of claims 1 to 8, wherein a coarse accuracy of 8 or 16 pixels is used to determine an initial position of a template for an initial iteration, and wherein the iteration refines the accuracy to at most 1 pixel or sub-pixel accuracy.
10. The method of any of claims 1 to 9, wherein an initial precision is obtained from data representing the video.
11. The method of any of claims 1 to 10, wherein the set of template candidates is determined by selecting all possible candidates according to the position and accuracy.
12. The method of any of claims 1 to 10, wherein the set of template candidates is determined by selecting candidates according to the position and accuracy in both horizontal and vertical directions.
13. A method, the method comprising:
-obtaining data representing blocks of pictures of the video;
-reconstructing the block of the picture of the video according to the method of any one of claims 1 to 12; and
-decoding picture data using the reconstructed block.
14. A method, the method comprising:
-obtaining data representing blocks of pictures of the video;
-reconstructing the block of the picture of the video according to the method of any one of claims 1 to 12; and
-encoding picture data using the reconstructed block.
15. An apparatus, the apparatus comprising a decoder configured to:
-obtaining data representing blocks of pictures of the video;
-reconstructing the block of the picture of the video according to the method of any one of claims 1 to 12; and
-decoding picture data using the reconstructed block.
16. An apparatus, the apparatus comprising an encoder for encoding picture data, the encoder configured to:
-obtaining data representing blocks of pictures of the video;
-reconstructing the block of the picture of the video according to the method of any one of claims 1 to 12; and
-encoding picture data using the reconstructed block.
17. A computer program comprising program code instructions for implementing the steps of the method according to at least one of claims 1 to 14 when executed by a processor.
18. A non-transitory computer readable medium comprising program code instructions for implementing the steps of the method according to at least one of claims 1 to 14 when executed by a processor.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP21305470.3 | 2021-04-09 | ||
EP21305470 | 2021-04-09 | ||
PCT/EP2022/055166 WO2022214244A1 (en) | 2021-04-09 | 2022-03-01 | Intra block copy with template matching for video encoding and decoding |
Publications (1)
Publication Number | Publication Date |
---|---|
CN117597923A true CN117597923A (en) | 2024-02-23 |
Family
ID=75690219
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202280026677.5A Pending CN117597923A (en) | 2021-04-09 | 2022-03-01 | Intra-frame block copy with template matching for video encoding and decoding |
Country Status (4)
Country | Link |
---|---|
US (1) | US20240205386A1 (en) |
EP (1) | EP4320860A1 (en) |
CN (1) | CN117597923A (en) |
WO (1) | WO2022214244A1 (en) |
Families Citing this family (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2024131979A1 (en) * | 2022-12-23 | 2024-06-27 | Douyin Vision Co., Ltd. | Method, apparatus, and medium for video processing |
WO2024145394A1 (en) * | 2022-12-27 | 2024-07-04 | Beijing Dajia Internet Information Technology Co., Ltd. | Methods and devices for intra block copy |
US20240223776A1 (en) * | 2023-01-03 | 2024-07-04 | Alibaba (China) Co., Ltd. | Intra template matching prediction mode for motion prediction |
WO2024148066A1 (en) * | 2023-01-04 | 2024-07-11 | Qualcomm Incorporated | Template matching for flipped intra block copy |
WO2024145857A1 (en) * | 2023-01-04 | 2024-07-11 | Oppo广东移动通信有限公司 | Intra-frame template matching prediction method, video coding method, video decoding method, apparatus, and system |
WO2024169970A1 (en) * | 2023-02-14 | 2024-08-22 | Douyin Vision Co., Ltd. | Method, apparatus, and medium for video processing |
WO2024186450A2 (en) * | 2023-03-03 | 2024-09-12 | Qualcomm Incorporated | Applications of intra block copy and intra template matching with fractional-pel block vector |
WO2024199506A1 (en) * | 2023-03-30 | 2024-10-03 | Douyin Vision Co., Ltd. | Method, apparatus, and medium for video processing |
WO2024207132A1 (en) * | 2023-04-03 | 2024-10-10 | Oppo广东移动通信有限公司 | Encoding/decoding method, code stream, encoder, decoder and storage medium |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2019234607A1 (en) * | 2018-06-05 | 2019-12-12 | Beijing Bytedance Network Technology Co., Ltd. | Interaction between ibc and affine |
WO2019234676A1 (en) * | 2018-06-07 | 2019-12-12 | Beijing Bytedance Network Technology Co., Ltd. | Mv precision refine |
TW202025737A (en) * | 2018-09-19 | 2020-07-01 | 大陸商北京字節跳動網絡技術有限公司 | Fast algorithms for adaptive motion vector resolution in affine mode |
-
2022
- 2022-03-01 WO PCT/EP2022/055166 patent/WO2022214244A1/en active Application Filing
- 2022-03-01 CN CN202280026677.5A patent/CN117597923A/en active Pending
- 2022-03-01 US US18/285,935 patent/US20240205386A1/en active Pending
- 2022-03-01 EP EP22712546.5A patent/EP4320860A1/en active Pending
Also Published As
Publication number | Publication date |
---|---|
EP4320860A1 (en) | 2024-02-14 |
WO2022214244A1 (en) | 2022-10-13 |
US20240205386A1 (en) | 2024-06-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20230396805A1 (en) | Template matching prediction for versatile video coding | |
US20240205386A1 (en) | Intra block copy with template matching for video encoding and decoding | |
CN113170146B (en) | Method and apparatus for picture encoding and decoding | |
CN112889287B (en) | Generalized bi-directional prediction and weighted prediction | |
US20220159277A1 (en) | Method and apparatus for video encoding and decoding with subblock based local illumination compensation | |
CN112970264A (en) | Simplification of coding modes based on neighboring sample-dependent parametric models | |
CN117597933A (en) | Spatially localized illumination compensation | |
EP3706421A1 (en) | Method and apparatus for video encoding and decoding based on affine motion compensation | |
EP4399870A1 (en) | Chroma prediction for video encoding and decoding based on template matching | |
CN113424540A (en) | Intra prediction mode extension | |
EP3644612A1 (en) | Method and device for picture encoding and decoding | |
CN112335240B (en) | Multiple reference intra prediction using variable weights | |
EP4082204A1 (en) | Estimating weighted-prediction parameters | |
CN113545047A (en) | Intra prediction mode partitioning | |
EP3641311A1 (en) | Encoding and decoding methods and apparatus | |
EP3654645A1 (en) | Method and device for picture encoding and decoding | |
US20240171731A1 (en) | Geometric partitions with switchable interpolation filter | |
US11991361B2 (en) | Method and device for picture encoding and decoding using position dependent intra prediction combination | |
CN113170153B (en) | Initializing current picture reference block vector based on binary tree | |
CN114930819A (en) | Subblock merging candidates in triangle merging mode | |
WO2024078896A1 (en) | Template type selection for video coding and decoding | |
CN118120228A (en) | Chroma prediction for video encoding and decoding based on template matching | |
CN118975232A (en) | Motion information parameter propagation based on intra prediction direction | |
WO2023046518A1 (en) | Extension of template based intra mode derivation (timd) with isp mode | |
CN118339825A (en) | Video encoding and decoding using reference picture resampling |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |