TW201939954A - Apparatus and method for palette decoding - Google Patents

Apparatus and method for palette decoding Download PDF

Info

Publication number
TW201939954A
TW201939954A TW108107348A TW108107348A TW201939954A TW 201939954 A TW201939954 A TW 201939954A TW 108107348 A TW108107348 A TW 108107348A TW 108107348 A TW108107348 A TW 108107348A TW 201939954 A TW201939954 A TW 201939954A
Authority
TW
Taiwan
Prior art keywords
palette
color
storage device
pixel
decoding
Prior art date
Application number
TW108107348A
Other languages
Chinese (zh)
Other versions
TWI709330B (en
Inventor
陳啟民
邱銘豪
鄭佳韻
張永昌
Original Assignee
聯發科技股份有限公司
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by 聯發科技股份有限公司 filed Critical 聯發科技股份有限公司
Publication of TW201939954A publication Critical patent/TW201939954A/en
Application granted granted Critical
Publication of TWI709330B publication Critical patent/TWI709330B/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/42Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/169Methods 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/186Methods 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 a colour or a chrominance component
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/102Methods 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/119Adaptive subdivision aspects, e.g. subdivision of a picture into rectangular or non-rectangular coding blocks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/157Assigned coding mode, i.e. the coding mode being predefined or preselected to be further used for selection of another element or parameter
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/169Methods 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/182Methods 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 a pixel
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/169Methods 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/184Methods 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 bits, e.g. of the compressed video stream
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/44Decoders specially adapted therefor, e.g. video decoders which are asymmetric with respect to the encoder
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/593Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving spatial prediction techniques
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/90Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using coding techniques not provided for in groups H04N19/10-H04N19/85, e.g. fractals
    • H04N19/91Entropy coding, e.g. variable length coding [VLC] or arithmetic coding

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)

Abstract

A palette decoding apparatus includes a palette color storage device which stores palette colors, a color index storage device which stores color indices of pixels, and a palette value processing circuit which generates a palette value for each pixel by reading data from the color index storage device and the palette color storage device. A frame is divided into first coding units, and each first coding unit is sub-divided into one or more second coding units. Before a palette value of a last pixel in a first coding unit is generated by the palette value processing circuit, a palette value of a non-last pixel in the first coding unit is generated by the palette value processing circuit and used by a reconstruction circuit of the video decoder.

Description

調色板解碼的裝置和方法Device and method for color palette decoding

交叉引用:cross reference:

本申請要求2018年3月6日提交的美國臨時申請案62/639,025的優先權,其內容一併引用在此。This application claims priority from US Provisional Application 62 / 639,025, filed March 6, 2018, the contents of which are incorporated herein by reference.

本發明有關於視訊解碼,更具體而言,有關於調色板解碼的裝置和方法。The present invention relates to video decoding, and more specifically, to a device and method for palette decoding.

傳統的視訊編解碼標準通常採用基於塊的編解碼技術來利用空間和時間冗餘。例如,基本方法是將源幀劃分為多個塊(或編解碼單元),對每個塊執行幀內預測/幀間預測,變換每個塊的殘差,以及執行量化和熵編碼。此外,生成重構幀以提供用於編解碼後續塊的參考像素資料。對於某些視訊編解碼標準,可以使用環路濾波器來增強重構幀的圖像品質。視訊解碼器用於執行由視訊編碼器執行的視訊編碼操作的逆操作。Traditional video codec standards usually use block-based codec technology to take advantage of spatial and temporal redundancy. For example, the basic method is to divide the source frame into multiple blocks (or codec units), perform intra / inter prediction on each block, transform the residuals of each block, and perform quantization and entropy coding. In addition, a reconstructed frame is generated to provide reference pixel data for encoding and decoding subsequent blocks. For some video codec standards, a loop filter can be used to enhance the image quality of the reconstructed frame. The video decoder is used to perform the inverse operation of the video encoding operation performed by the video encoder.

屏幕內容可以是計算機生成的包括文本、圖形和動畫的內容。例如,屏幕內容可以用在諸如桌面共享、視訊會議、社交網路和遠程教育的應用中。由於提出的用於捕獲的圖像內容編解碼技術不能為屏幕內容提供最佳編解碼效率,因此屏幕內容的編解碼應該與攝影內容的編解碼不同。當通過使用不同的編解碼工具(例如,調色板編解碼)在視訊編碼器處對屏幕內容進行編碼而不是將其用於捕獲的圖像內容時,在視訊解碼器中需要適當的解碼方案(例如,調色板解碼)以重構屏幕內容。Screen content can be computer-generated content including text, graphics, and animation. For example, screen content can be used in applications such as desktop sharing, video conferencing, social networking, and distance education. Because the proposed image content encoding and decoding technology cannot provide the best encoding and decoding efficiency for screen content, the encoding and decoding of screen content should be different from the encoding and decoding of photographic content. When encoding screen content at the video encoder instead of using it for captured image content by using different codecs (for example, palette codec), an appropriate decoding scheme is required in the video decoder (For example, palette decoding) to reconstruct screen content.

要求保護的發明的一個目的是提供一種用於調色板解碼的裝置和方法。It is an object of the claimed invention to provide an apparatus and method for palette decoding.

根據本發明的第一方面,公開了示例性視訊解碼器。示例性視訊解碼器包括調色板解碼設備,其具有調色板顏色存儲設備、顏色索引存儲設備和調色板值處理電路。調色板顏色存儲設備被配置為存儲從位元流解碼的調色板顏色。顏色索引存儲設備被佈置為存儲像素的顏色索引,其中顏色索引從位元流解碼。調色板值處理電路被配置為通過從顏色索引存儲設備讀取該每個像素的顏色索引,搜索存儲在調色板顏色存儲設備中的調色板顏色,並通過調色板顏色設置該每個像素的調色板值,為多個像素的每個像素生成調色板值,其中調色板顏色存儲設備由該每個像素的顏色索引來索引。幀被劃分為多個第一編解碼單元,並且每個第一編解碼單元被細分為一個或多個第二編解碼單元。在調色板值處理電路生成第一編解碼單元中的最後一個像素的調色板值之前,調色板值處理電路生成第一編解碼單元中的非最後像素的調色板值,並由視訊解碼器的重構電路使用。According to a first aspect of the invention, an exemplary video decoder is disclosed. An exemplary video decoder includes a palette decoding device having a palette color storage device, a color index storage device, and a palette value processing circuit. The palette color storage device is configured to store palette colors decoded from a bit stream. The color index storage device is arranged to store a color index of a pixel, wherein the color index is decoded from a bit stream. The palette value processing circuit is configured to search the palette color stored in the palette color storage device by reading the color index of each pixel from the color index storage device, and set the each color by the palette color. The palette value of each pixel generates a palette value for each pixel of a plurality of pixels, where the palette color storage device is indexed by the color index of each pixel. A frame is divided into a plurality of first codec units, and each first codec unit is subdivided into one or more second codec units. Before the palette value processing circuit generates the palette value of the last pixel in the first codec unit, the palette value processing circuit generates the palette value of the non-last pixel in the first codec unit, and The video decoder's reconstruction circuit is used.

根據本發明的第二方面,公開了示例性視訊解碼方法。示例性視訊解碼方法包括:將從位元流解碼的調色板顏色存儲到調色板顏色存儲設備中;將像素的顏色索引存儲到顏色索引存儲設備中,其中顏色索引從位元流中解碼;通過從顏色索引存儲設備讀取所述每個像素的顏色索引,搜索存儲在調色板顏色存儲設備中的調色板顏色,並通過調色板顏色設置所述每個像素的調色板值,為每個像素生成調色板值,其中調色板顏色存儲設備由所述每個像素的顏色索引來索引。幀被劃分為多個第一編解碼單元,並且每個第一編解碼單元被細分為一個或多個第二編解碼單元。在生成第一編解碼單元中的最後像素的調色板值之前,生成第一編解碼單元中的非最後像素的調色板值,並通過重構非最後像素來使用調色板值。According to a second aspect of the present invention, an exemplary video decoding method is disclosed. An exemplary video decoding method includes: storing a palette color decoded from a bit stream into a palette color storage device; storing a color index of a pixel into a color index storage device, wherein the color index is decoded from the bit stream ; By reading the color index of each pixel from the color index storage device, searching for the palette color stored in the palette color storage device, and setting the palette of each pixel by the palette color Value, a palette value is generated for each pixel, where the palette color storage device is indexed by the color index of each pixel. A frame is divided into a plurality of first codec units, and each first codec unit is subdivided into one or more second codec units. Before generating the palette value of the last pixel in the first codec unit, a palette value of the non-last pixel in the first codec unit is generated, and the palette value is used by reconstructing the non-last pixel.

根據本發明的第三方面,公開了示例性視訊解碼器。示例性視訊解碼器包括調色板解碼裝置,其具有調色板顏色存儲設備、顏色索引存儲設備和調色板值處理電路。調色板顏色存儲設備被配置為存儲從位元流解碼的調色板顏色。顏色索引存儲設備被配置為存儲像素的顏色索引,其中顏色索引從位元流解碼。調色板值處理電路被配置為通過從顏色索引存儲設備讀取所述每個像素的顏色索引,搜索存儲在調色板顏色存儲設備中由每個像素的顏色索引索引的調色板顏色,並通過調色板顏色設置所述每個像素的調色板值,為多個像素的每個像素生成調色板值。幀被劃分為多個第一編碼單元,並且第一編碼單元中的每一個被細分為一個或多個第二編碼單元。直到該第一組的調色板解碼所需的所有調色板顏色存儲在該調色板顏色存儲設備中以及該第一組的所有像素的顏色索引存儲在該顏色索引存儲設備中,調色板值處理電路才開始生成至少一個第一編解碼單元的第一組中的第一像素的調色板值。根據從調色板顏色存儲設備和顏色索引存儲設備讀取的資料生成第一組中的像素的調色板值的處理時間與將至少一個第一編解碼單元的第二組的調色板解碼所需的調色板顔色寫入調色板顏色存儲裝置和將第二組像素的顏色索引寫入顏色索引存儲設備的處理時間重疊。According to a third aspect of the invention, an exemplary video decoder is disclosed. An exemplary video decoder includes a palette decoding device having a palette color storage device, a color index storage device, and a palette value processing circuit. The palette color storage device is configured to store palette colors decoded from a bit stream. The color index storage device is configured to store a color index of a pixel, wherein the color index is decoded from a bit stream. The palette value processing circuit is configured to search a palette color indexed by the color index of each pixel stored in the palette color storage device by reading the color index of each pixel from a color index storage device, The palette value of each pixel is set by a palette color, and a palette value is generated for each pixel of a plurality of pixels. A frame is divided into a plurality of first coding units, and each of the first coding units is subdivided into one or more second coding units. All palette colors required until the palette decoding of the first group are stored in the palette color storage device and the color indexes of all pixels of the first group are stored in the color index storage device. Only the board value processing circuit starts to generate the palette value of the first pixel in the first group of the at least one first codec unit. Processing time for generating the palette value of the pixels in the first group according to the data read from the palette color storage device and the color index storage device and decoding the palette of the second group of at least one first codec unit The processing time for writing the required palette color into the palette color storage device and writing the color index of the second group of pixels into the color index storage device overlaps.

在閱讀了在各個附圖和圖示中示出的優選實施例的以下詳細描述之後,本發明的這些和其他目的無疑將對所屬領域具有通常知識者變得顯而易見。These and other objects of the present invention will no doubt become apparent to those having ordinary knowledge in the art after reading the following detailed description of the preferred embodiments shown in the various drawings and illustrations.

貫穿以下描述和申請專利範圍使用某些術語,其涉及特定組件。如所屬領域具有通常知識者將理解的,電子設備製造商可以通過不同的名稱來指代組件。本文檔無意區分名稱不同但功能不同的組件。在以下描述和申請專利範圍中,術語“包括”和“包含”以開放式的方式使用,因此應該被解釋為表示“包括但不限於......”。而且,術語“耦合”旨在表示間接或直接電連接。因此,如果一個設備耦合到另一個設備,則該連接可以通過直接電連接,或通過經由其他設備和連接的間接電連接。Certain terms are used throughout the following description and scope of patent applications, which refer to specific components. As one of ordinary skill in the art will appreciate, electronic device manufacturers may refer to a component by different names. This document is not intended to distinguish between components with different names but different functions. In the following description and the scope of the patent application, the terms "including" and "comprising" are used in an open-ended fashion and should therefore be interpreted to mean "including but not limited to ..." Moreover, the term "coupled" is intended to mean an indirect or direct electrical connection. Thus, if one device is coupled to another device, the connection may be through a direct electrical connection, or through an indirect electrical connection via the other device and the connection.

調色板編碼利用屏幕內容中幾乎沒有唯一顏色的事實,並嘗試發送這些唯一顏色的調色板。本發明在視訊解碼器中提出了一種高性能和低成本的調色板解碼方案。第1圖是示出根據本發明的實施例的調色板解碼裝置的圖。調色板解碼裝置100可以在諸如AV1解碼器的視訊解碼器中實現。調色板解碼裝置100包括調色板值處理電路102、顏色索引存儲設備104和調色板顏色存儲設備106。顏色索引存儲設備104和調色板顏色存儲設備106中的任何一個可以通過以下實現: 諸如靜態隨機存取記憶體(SRAM)的片上記憶體,諸如動態隨機存取記憶體(DRAM)的片外記憶體,或其組合。Palette coding takes advantage of the fact that there are few unique colors in the screen content and attempts to send a palette of these unique colors. The invention proposes a high-performance and low-cost palette decoding scheme in a video decoder. FIG. 1 is a diagram showing a palette decoding device according to an embodiment of the present invention. The palette decoding device 100 may be implemented in a video decoder such as an AV1 decoder. The palette decoding device 100 includes a palette value processing circuit 102, a color index storage device 104, and a palette color storage device 106. Any of the color index storage device 104 and the palette color storage device 106 may be implemented by: On-chip memory such as static random access memory (SRAM), Off-chip such as dynamic random access memory (DRAM) Memory, or a combination thereof.

視訊解碼器中的熵解碼器10接收從視訊編碼器產生的位元流BS。熵解碼器10對位元流BS進行解碼以獲得發送的(signaled)調色板相關資訊,並將解碼的調色板相關資訊提供給調色板解碼裝置100。例如,從位元流BS導出的調色板相關資訊可包括調色板大小(size)資料D_IN1、調色板顏色資料D_IN2和顏色索引資料D_IN3。在該實施例中,調色板顏色存儲設備106被佈置為存儲從位元流BS解碼的調色板顏色,顏色索引存儲設備104被佈置為存儲從位元流BS解碼的像素的顏色索引,並且調色板值處理電路 102通過從顏色索引存儲設備104讀取像素的顏色索引,搜索存儲在調色板顏色存儲設備106中的調色板顏色(通過像素的顏色索引來索引),以及通過調色板顏色存儲設備106中找到的調色板顏色來設置像素的調色板值,來生產每個像素的調色板值。調色板值處理電路102還用於產生調色板值輸出D_OUT到視訊解碼器的重構電路20,其中調色板值輸出D_OUT包括重構像素所需的調色板值。The entropy decoder 10 in the video decoder receives a bit stream BS generated from the video encoder. The entropy decoder 10 decodes the bit stream BS to obtain the transmitted palette-related information, and provides the decoded palette-related information to the palette decoding device 100. For example, the palette-related information derived from the bit stream BS may include palette size data D_IN1, palette color data D_IN2, and color index data D_IN3. In this embodiment, the palette color storage device 106 is arranged to store the palette colors decoded from the bit stream BS, and the color index storage device 104 is arranged to store the color indexes of the pixels decoded from the bit stream BS, And the palette value processing circuit 102 reads the color index of the pixel from the color index storage device 104, searches for the palette color stored in the palette color storage device 106 (indexed by the color index of the pixel), and The palette color found in the palette color storage device 106 sets the palette value of the pixels to produce the palette value of each pixel. The palette value processing circuit 102 is further configured to generate a palette value output D_OUT to the reconstruction circuit 20 of the video decoder, wherein the palette value output D_OUT includes a palette value required for reconstructing pixels.

為了實現高性能和低成本的調色板解碼,調色板解碼裝置100被設計為以基於小尺寸編解碼單元的方式而不是基於大尺寸編解碼單元的方式執行調色板解碼。例如,一個幀可以被劃分為多個模式資訊(mode info,簡寫為MI)單元,並且每個MI單元可以被劃分為一個或多個變換單元(transform unit,簡寫為TU)。在確定另一個小尺寸編解碼單元(例如,另一個TU)中的像素的調色板值之前,調色板解碼裝置100可以開始在一個小尺寸編解碼單元(例如,一個TU)中輸出像素的調色板值以用於在重構電路20處重構。換句話說,在調色板值處理電路102生成大尺寸編解碼單元(例如,一個MI單元)中的最後一個像素的調色板值之前,大尺寸編解碼單元(例如,一個MI單元)中的非最後像素的調色板值由調色板值處理電路102生成,並由視訊解碼器的重構電路20使用。以這種方式,調色板解碼裝置100不需要大尺寸緩衝器來將所有像素的調色板值保持在一個大尺寸編解碼單元(例如,一個MI單元)中,從而放寬了緩衝器要求。此外,重構電路20可以在調色板解碼裝置100獲得大尺寸編碼單元(例如,一個MI單元)中的所有像素的調色板值之前,開始重構一個大尺寸編解碼單元(例如,一個MI單元)中的像素,從而提高整體解碼性能。In order to achieve high-performance and low-cost palette decoding, the palette decoding device 100 is designed to perform palette decoding in a manner based on a small-size codec unit instead of a large-size codec unit. For example, a frame may be divided into multiple mode info (abbreviated as MI) units, and each MI unit may be divided into one or more transform units (abbreviated as TU). Before determining a palette value of a pixel in another small-size codec unit (for example, another TU), the palette decoding device 100 may start outputting pixels in a small-size codec unit (for example, one TU). For the reconstruction at the reconstruction circuit 20. In other words, before the palette value processing circuit 102 generates the palette value of the last pixel in the large-size codec unit (for example, one MI unit), the large-size codec unit (for example, one MI unit) The palette value of the non-last pixel is generated by the palette value processing circuit 102 and used by the reconstruction circuit 20 of the video decoder. In this way, the palette decoding device 100 does not need a large-sized buffer to keep the palette values of all pixels in one large-sized codec unit (for example, one MI unit), thereby relaxing the buffer requirements. In addition, the reconstruction circuit 20 may start to reconstruct a large-size codec unit (for example, one MI units) to improve overall decoding performance.

第2圖是示出根據本發明實施例的在幀的一個MI單元中重構像素的像素值所涉及的調色板解碼處理的流程圖。假設結果基本相同,則不需要以第2圖所示的確切順序執行步驟。在步驟202,調色板解碼裝置100從熵解碼器10獲得調色板大小資料D_IN1。在步驟204,調色板解碼裝置100從熵解碼器10獲得調色板顏色資料D_IN2。在步驟206,調色板解碼裝置100從熵解碼器10獲得顏色索引資料D_IN3。在步驟208,在視訊解碼器處開始對殘差資料的解碼。在步驟210,調色板解碼裝置100通過參考經由位元流BS信令的語法元素來檢查MI單元是否使用調色板模式。如果MI單元未使用調色板模式,則中止MI單元的調色板解碼處理。如果MI單元使用調色板模式,則流程進行到步驟212。調色板解碼裝置100根據調色板大小資料D_IN1、調色板顏色資料D_IN2和顏色索引資料D_IN3給出的資訊確定MI單元中的像素的調色板值。在步驟214,重構電路20使用MI單元中的像素的調色板值來重構像素。FIG. 2 is a flowchart illustrating a palette decoding process involved in reconstructing a pixel value of a pixel in one MI unit of a frame according to an embodiment of the present invention. Assuming the results are essentially the same, the steps need not be performed in the exact order shown in Figure 2. In step 202, the palette decoding device 100 obtains palette size data D_IN1 from the entropy decoder 10. In step 204, the palette decoding device 100 obtains the palette color data D_IN2 from the entropy decoder 10. In step 206, the palette decoding device 100 obtains the color index data D_IN3 from the entropy decoder 10. In step 208, decoding of the residual data is started at the video decoder. In step 210, the palette decoding device 100 checks whether the MI unit uses the palette mode by referring to syntax elements via bit stream BS signaling. If the MI unit does not use the palette mode, the palette decoding process of the MI unit is suspended. If the MI unit uses the palette mode, the flow proceeds to step 212. The palette decoding device 100 determines the palette value of the pixels in the MI unit according to the information given by the palette size data D_IN1, the palette color data D_IN2, and the color index data D_IN3. In step 214, the reconstruction circuit 20 reconstructs the pixels using the color palette values of the pixels in the MI unit.

如上所述,調色板解碼裝置100被設計為以基於小尺寸編解碼單元的方式執行調色板解碼,以實現高性能和低成本的調色板解碼。例如,調色板值處理電路102執行步驟212以基於TU的方式計算像素的調色板值。第3圖是示出根據本發明的實施例的調色板解碼處理中涉及的基於TU的調色板值計算處理的流程圖。假設結果基本相同,則不需要以第3圖所示的確切順序執行步驟。在步驟302,調色板值處理電路102檢查顏色索引存儲設備104中是否存在多於“N”個顏色索引,其中N是整數,M是要在當前TU中計算的所有調色板值的數量,1≤N≤M。在步驟302檢查的條件滿足之前,流程不進行到步驟304。在步驟304,調色板值處理電路102從顏色索引存儲設備104獲得“O”顏色索引,並從調色板顏色存儲設備106獲得相應的調色板顏色,其中O是整數且1≤O≤N。另外,重構電路200獲得相應的殘差資料。在步驟306,調色板值處理電路102根據“O”顏色索引和相應的調色板顏色計算“O”調色板值。另外,重構電路200根據調色板值處理電路102確定的調色板值計算重構結果。在步驟308,調色板值處理電路102檢查計算的調色板值計數是否達到M。當計算的調色板值計數達到M時,這意味著調色板值處理電路102已經確定了與當前TU相關的所有調色板值。因此,完成了當前TU的調色板值計算處理。當計算的調色板值計數尚未達到M時,流程進行到步驟302。所提出的基於編解碼單元的調色板解碼方案(例如,基於TU的調色板解碼方案)的進一步細節描述如下。As described above, the palette decoding device 100 is designed to perform palette decoding in a manner based on a small-sized codec unit to achieve high-performance and low-cost palette decoding. For example, the palette value processing circuit 102 performs step 212 to calculate a palette value of a pixel in a TU-based manner. FIG. 3 is a flowchart showing a TU-based palette value calculation process involved in a palette decoding process according to an embodiment of the present invention. Assuming the results are essentially the same, the steps need not be performed in the exact order shown in Figure 3. In step 302, the palette value processing circuit 102 checks whether there are more than "N" color indexes in the color index storage device 104, where N is an integer and M is the number of all palette values to be calculated in the current TU. , 1≤N≤M. The flow does not proceed to step 304 until the conditions checked in step 302 are satisfied. In step 304, the palette value processing circuit 102 obtains an “O” color index from the color index storage device 104 and obtains the corresponding palette color from the palette color storage device 106, where O is an integer and 1 ≦ O ≦ N. In addition, the reconstruction circuit 200 obtains corresponding residual data. In step 306, the palette value processing circuit 102 calculates an "O" palette value based on the "O" color index and the corresponding palette color. In addition, the reconstruction circuit 200 calculates a reconstruction result based on the palette value determined by the palette value processing circuit 102. In step 308, the palette value processing circuit 102 checks whether the calculated palette value count reaches M. When the calculated palette value count reaches M, this means that the palette value processing circuit 102 has determined all the palette values related to the current TU. Therefore, the palette value calculation processing of the current TU is completed. When the calculated palette value count has not reached M, the flow proceeds to step 302. Further details of the proposed codec unit-based palette decoding scheme (eg, a TU-based palette decoding scheme) are described below.

如上所述,調色板顏色存儲設備106被佈置為存儲從位元流BS解碼的調色板顏色。在該實施例中,調色板值處理電路102以基於TU的方式計算像素的調色板值。當一個MI單元使用調色板模式時,MI單元中包括的每個TU的調色板解碼共享用於調色板編碼MI單元的相同調色板顏色(即,基色(base color))。第4圖是示出根據本發明實施例的存儲在調色板顏色存儲設備106中的多個調色板顏色表的圖。一個MI單元的調色板編碼可以建立Y平面的亮度調色板顏色表TB_Y、U平面的色度調色板顏色表TB_U和V平面的色度調色板顏色表TB_V。具有調色板大小N + 1的亮度調色板顏色表TB_Y具有分別由顏色索引(調色板索引)0-N索引的8位元調色板顏色Y0 -YN ,其中2≤N+1≤8。在該示例中,色度調色板顏色表TB_U和TB_V可以具有相同的調色板大小M + 1但是具有不同的調色板顏色,其中2≤M+1≤8。具有調色板大小M的色度調色板顏色表TB_U具有分別由顏色索引(調色板索引)0-M索引的8位元調色板顏色U0 -UM 。具有調色板大小M的色度調色板顏色表TB_V具有分別由顏色索引(調色板索引)0-M索引的8位元調色板顏色V0 -VM 。調色板顏色Y0 -YN 、U0 -UM 、V0 -VM 和一個MI單元的調色板大小N + 1和M + 1被編碼並通過位元流BS發信。因此,在從位元流BS解碼用於一個MI單元的調色板顏色Y0 -YN 、U0 -UM 、V0 -VM 和調色板大小N + 1和M + 1之後,獲得由視訊編碼器處的調色板編碼使用的相同的亮度調色板顏色表TB_Y、色度調色板顏色表TB_U和色度調色板顏色表TB_V,並將其存儲在視訊解碼器處的調色板顏色存儲設備106中。As described above, the palette color storage device 106 is arranged to store the palette colors decoded from the bit stream BS. In this embodiment, the palette value processing circuit 102 calculates a palette value of a pixel in a TU-based manner. When one MI unit uses the palette mode, the palette decoding of each TU included in the MI unit shares the same palette color (ie, base color) used for palette-encoding the MI unit. FIG. 4 is a diagram showing a plurality of palette color tables stored in the palette color storage device 106 according to an embodiment of the present invention. A MI unit's palette coding can establish a luminance palette color table TB_Y in the Y plane, a chromaticity palette color table TB_U in the U plane, and a chromaticity palette color table TB_V in the V plane. Brightness palette color table TB_Y with palette size N + 1 has 8-bit palette colors Y 0 -Y N indexed by color indexes (palette index) 0-N respectively, where 2≤N + 1≤8. In this example, the chromaticity palette color tables TB_U and TB_V may have the same palette size M + 1 but have different palette colors, where 2 ≦ M + 1 ≦ 8. The chromaticity palette color table TB_U having a palette size M has 8-bit palette colors U 0 -U M indexed by color indexes (palette index) 0-M, respectively. The chromaticity palette color table TB_V having a palette size M has 8-bit palette colors V 0 -V M indexed by color indexes (palette index) 0-M, respectively. The palette colors Y 0 -Y N , U 0 -U M , V 0 -V M and the palette sizes N + 1 and M + 1 of an MI unit are encoded and transmitted via the bit stream BS. Therefore, after decoding the palette colors Y 0 -Y N , U 0 -U M , V 0 -V M and the palette sizes N + 1 and M + 1 for one MI unit from the bit stream BS, Obtain the same luma palette color table TB_Y, chroma palette color table TB_U, and chroma palette color table TB_V used by the palette encoding at the video encoder and store them at the video decoder The color palette is stored in the device 106.

如上所述,顏色索引存儲設備104被佈置為存儲從位元流BS解碼的顏色索引。關於視訊編碼器處的調色板編碼,通過使用代表調色板顏色Y0 -YN 之一的顏色索引(調色板索引)0-N之一對像素的Y通道值進行調色板編碼,通過使用代表調色板顏色U0 -UM 之一的顏色索引(調色板索引)0-M之一對像素的U通道值進行調色板編碼,並且通過使用代表調色板顏色V0 -VM 之一的顏色索引(調色板索引)0-M之一對像素的V通道值進行調色板編碼。對於在調色板模式下編碼的一個TU中包括的每個像素,像素的YUV顏色索引被編碼並經由位元流BS發信。因此,在從位元流BS解碼像素的YUV顏色索引之後,獲得像素的YUV顏色索引並將其存儲在視訊解碼器處的顏色索引存儲設備104中。As described above, the color index storage device 104 is arranged to store a color index decoded from the bit stream BS. Regarding the palette encoding at the video encoder, the Y-channel value of the pixel is palette-encoded by using one of the color indexes (palette index) 0-N representing one of the palette colors Y 0 -Y N , By using one of the color indexes (palette index) 0-M representing one of the palette colors U 0 -U M to palette-encode the U-channel value of the pixel, and by using the representative palette color V Color index (palette index) of one of 0- V M One of 0-M color-codes the V-channel value of the pixel. For each pixel included in one TU encoded in the palette mode, the YUV color index of the pixel is encoded and transmitted via the bit stream BS. Therefore, after the YUV color index of a pixel is decoded from the bit stream BS, the YUV color index of the pixel is obtained and stored in the color index storage device 104 at the video decoder.

根據調色板模式,可以以波前順序在視訊編碼器處預測一個TU中的像素以允許並行計算。因此,可以以波前順序(wavefront order)對相同TU中的像素的Y顏色索引進行編碼和發送,可以以波前順序對相同TU中的像素的U顏色索引進行編碼和發送,並且可以以波前順序對相同TU中的像素的V顏色索引進行編碼和發送。在該實施例中,熵解碼器10可以以波前順序解碼和輸出相同TU中的像素的Y顏色索引,可以以波前順序解碼和輸出相同TU中的像素的U顏色索引,並且可以以波前順序解碼和輸出相同TU中的像素的V顏色索引。第5圖是示出根據本發明實施例的將像素的顏色索引寫入顏色索引存儲設備104以創建一個TU的顏色索引圖的操作的圖。假設要調色板解碼的當前TU的大小是8x8。通過以與解碼順序相同的寫緩衝器順序依次寫入TU中的像素的Y顏色索引,在顏色索引存儲設備104中創建TU的Y平面的亮度顏色索引圖M_CB_Y。如第5圖所示,寫緩衝器順序是波前順序,如附圖標記所示。Depending on the palette mode, pixels in one TU can be predicted at the video encoder in wavefront order to allow parallel computation. Therefore, the Y color index of pixels in the same TU can be encoded and transmitted in wavefront order, the U color index of pixels in the same TU can be encoded and transmitted in wavefront order, and the wave can be encoded and transmitted in wavefront order. The preceding sequence encodes and transmits the V color indexes of pixels in the same TU. In this embodiment, the entropy decoder 10 may decode and output the Y color index of pixels in the same TU in wavefront order, may decode and output the U color index of pixels in the same TU in wavefront order, and may The previous order decodes and outputs the V color index of pixels in the same TU. FIG. 5 is a diagram illustrating an operation of writing a color index of a pixel into a color index storage device 104 to create a color index map of a TU according to an embodiment of the present invention. Assume that the size of the current TU to be palette-decoded is 8x8. By sequentially writing the Y color indexes of the pixels in the TU in the same write buffer order as the decoding order, a luminance color index map M_CB_Y of the Y plane of the TU is created in the color index storage device 104. As shown in FIG. 5, the write buffer order is a wavefront order, as indicated by reference numerals.

一個像素的Y顏色索引用於指示亮度調色板顏色表TB_Y中的調色板顏色。因此,從顏色索引存儲設備104讀取亮度顏色索引圖M_CB_Y中的Y顏色索引,用於計算用於重構TU中的像素的Y通道值的調色板值。第6圖是示出根據本發明實施例的從顏色索引存儲設備104讀取顏色索引圖的顏色索引的操作的圖。由於亮度顏色索引圖M_CB_Y中的Y顏色索引用於計算用於重構TU中的像素的Y通道值的調色板值,因此排列在亮度顏色索引圖M_CB_Y中的Y顏色索引以與殘差資料輸出順序相同的讀緩衝器順序從顏色索引存儲設備104讀取。在第6圖中,讀緩衝器順序是由附圖標記指示的逐列(column-by-column)順序。The Y color index of one pixel is used to indicate the palette color in the brightness palette color table TB_Y. Therefore, the Y color index in the luminance color index map M_CB_Y is read from the color index storage device 104 for calculating a palette value for reconstructing the Y channel values of the pixels in the TU. FIG. 6 is a diagram illustrating an operation of reading a color index of a color index map from a color index storage device 104 according to an embodiment of the present invention. Since the Y color index in the luminance color index map M_CB_Y is used to calculate the palette value used to reconstruct the Y channel values of the pixels in the TU, the Y color index in the luminance color index map M_CB_Y is aligned with the residual data The read buffers in the same output order are read from the color index storage device 104. In FIG. 6, the read buffer order is a column-by-column order indicated by a reference numeral.

類似地,通過以與解碼順序相同的寫緩衝器順序依次將TU中的像素的U顏色索引寫入至寫緩衝器,在顏色索引存儲設備104中創建TU的U平面的色度顏色索引圖M_CB_U,排序在色度顏色索引圖M_CB_U中的U顏色索引以與殘差資料輸出順序相同的讀緩衝器順序從顏色索引存儲設備104讀取。此外,通過以與解碼順序相同的寫緩衝器順序依次寫入TU中的像素的V顏色索引,在顏色索引存儲設備104中創建TU的V平面的色度顏色索引圖M_CB_V,並且以與殘差資料輸出順序相同的讀緩衝器順序從顏色索引存儲設備104讀取在亮度顏色索引圖M_CB_V中排列的V顏色索引。由於所屬領域具有通常知識者在閱讀上述針對亮度顏色索引圖M_CB_Y的段落之後可以容易地理解寫入緩衝區順序的細節和色度顏色索引圖M_CB_U和M_CB_V的讀取緩衝區順序,因此為了簡潔起見,在此省略進一步的描述。Similarly, by sequentially writing the U color indexes of the pixels in the TU to the write buffer in the same write buffer order as the decoding order, the chromaticity color index map M_CB_U of the U plane of the TU is created in the color index storage device 104 The U color indexes sorted in the chromaticity color index map M_CB_U are read from the color index storage device 104 in the same read buffer order as the residual data output order. In addition, by sequentially writing the V color indexes of the pixels in the TU in the same write buffer order as the decoding order, a chromaticity color index map M_CB_V of the V plane of the TU is created in the color index storage device 104, and is compared with the residual The reading buffer sequence in the same material output order reads the V color indexes arranged in the luminance color index map M_CB_V from the color index storage device 104. Since ordinary knowledgeable persons in the field can easily understand the details of the write buffer order and the read buffer order of the chroma color index maps M_CB_U and M_CB_V after reading the above paragraphs for the luminance color index map M_CB_Y, for the sake of simplicity See, further description is omitted here.

當調色板顏色存儲設備106中的亮度調色板顏色表TB_Y和色度調色板顏色表TB_U和TB_V可用,且顏色索引存儲設備104中的亮度顏色索引圖M_CB_Y和色度顏色索引圖M_CB_U和M_CB_V可用時,調色板值處理電路102根據從顏色索引存儲設備104讀取的顏色索引和存儲在調色板顏色存儲設備106中的調色板顏色,計算一個TU中的像素的調色板值。When the luma palette color table TB_Y and chroma palette color tables TB_U and TB_V in the palette color storage device 106 are available, and the luma color index map M_CB_Y and chroma color index map M_CB_U in the color index storage device 104 When M_CB_V is available, the palette value processing circuit 102 calculates the color palette of the pixels in one TU based on the color index read from the color index storage device 104 and the palette color stored in the palette color storage device 106. Board value.

第7圖是示出根據本發明實施例的調色板值處理電路102執行的調色板值生成處理的圖。調色板值處理電路102將控制信號CS輸出到調色板顏色存儲設備106,用於選擇亮度調色板顏色表TB_Y和色度調色板顏色表TB_U和TB_V中的一個,並進一步將控制信號CS輸出到顏色索引存儲設備 104,用於選擇亮度顏色索引圖M_CB_Y和色度顏色索引圖M_CB_U和M_CB_V中的一個,其中控制信號CS用作平面選擇信號。調色板值處理電路102將索引位址ADR_IDX輸出到顏色索引存儲設備104,用於從所選擇的顏色索引圖(即,由控制信號CS選擇的顏色索引圖)中選擇像素的顏色索引,搜索所選擇的調色板顏色表(即,由控制信號CS選擇的調色板顏色表),用於由存儲在索引位址ADR_IDX處的所選顏色索引來索引的調色板顏色,並通過在選定的調色板顏色表中找到的調色板顏色設置像素的調色板值PV。FIG. 7 is a diagram illustrating a palette value generation process performed by the palette value processing circuit 102 according to the embodiment of the present invention. The palette value processing circuit 102 outputs a control signal CS to the palette color storage device 106 for selecting one of the brightness palette color table TB_Y and the chroma palette color table TB_U and TB_V, and further controls The signal CS is output to a color index storage device 104 for selecting one of a luminance color index map M_CB_Y and a chrominance color index map M_CB_U and M_CB_V, where the control signal CS is used as a plane selection signal. The palette value processing circuit 102 outputs the index address ADR_IDX to the color index storage device 104 for selecting the color index of the pixel from the selected color index map (ie, the color index map selected by the control signal CS), and searches for The selected palette color table (ie, the palette color table selected by the control signal CS) is used for the palette colors indexed by the selected color index stored at the index address ADR_IDX, and is passed through The palette color found in the selected palette color table sets the pixel's palette value PV.

例如,當此時需要重構像素的Y通道值時,調色板值處理電路102更新控制信號CS以選擇亮度調色板顏色表TB_Y和亮度顏色索引圖M_CB_Y 並且更新索引位址ADR_IDX以選擇存儲在亮度顏色索引圖M_CB_Y中的像素的Y顏色索引。因此,由調色板值處理電路102確定並輸出與像素的Y通道值的重構相關聯的調色板值PV。For example, when the Y channel value of the pixel needs to be reconstructed at this time, the palette value processing circuit 102 updates the control signal CS to select the brightness palette color table TB_Y and the brightness color index map M_CB_Y and updates the index address ADR_IDX to select storage The Y color index of the pixel in the brightness color index map M_CB_Y. Therefore, the palette value PV associated with the reconstruction of the Y-channel value of the pixel is determined and output by the palette value processing circuit 102.

作為另一示例,當此時需要重構像素的U通道值時,調色板值處理電路102更新控制信號CS以選擇色度調色板顏色表TB_U和色度顏色索引圖 M_CB_U,並更新索引位址ADR_IDX以選擇存儲在色度顏色索引圖M_CB_U中的像素的U顏色索引。因此,由調色板值處理電路102確定並輸出與重構像素的U通道值相關聯的調色板值PV。As another example, when the U-channel value of the pixel needs to be reconstructed at this time, the palette value processing circuit 102 updates the control signal CS to select the chroma palette color table TB_U and the chroma color index map M_CB_U, and updates the index Address ADR_IDX to select the U color index of the pixels stored in the chromaticity color index map M_CB_U. Therefore, the palette value processing circuit 102 determines and outputs a palette value PV associated with the U-channel value of the reconstructed pixel.

再例如,當此時需要重構像素的V通道值時,調色板值處理電路102更新控制信號CS以選擇色度調色板顏色表TB_V和色度顏色索引圖M_CB_V,並更新索引位址ADR_IDX以選擇存儲在色度顏色索引圖M_CB_V中的像素的V顏色索引。因此,由調色板值處理電路102確定並輸出與重構像素的V通道值相關聯的調色板值PV。As another example, when the V-channel value of the pixel needs to be reconstructed at this time, the palette value processing circuit 102 updates the control signal CS to select the chroma palette color table TB_V and the chroma color index map M_CB_V, and updates the index address. ADR_IDX selects the V color index of the pixels stored in the chromaticity color index map M_CB_V. Therefore, the palette value PV associated with the V-channel value of the reconstructed pixel is determined and output by the palette value processing circuit 102.

在該實施例中,調色板值處理電路102被佈置為執行基於TU的調色板值計算處理。因此,顏色索引存儲設備104可以由具有足以緩衝基於TU的調色板值計算處理所需的顏色索引的存儲容量的小尺寸緩衝器實現,和/或調色板顏色存儲設備106可以通過其存儲容量足以緩衝基於TU的調色板值計算處理所需的調色板顏色的小尺寸緩衝器實現。In this embodiment, the palette value processing circuit 102 is arranged to perform a TU-based palette value calculation process. Therefore, the color index storage device 104 may be implemented by a small-sized buffer having a storage capacity sufficient to buffer the color index required for the TU-based palette value calculation process, and / or the palette color storage device 106 may store therethrough A small-sized buffer implementation with sufficient capacity to buffer the palette colors required for TU-based palette value calculation processing.

如第7圖所示,調色板顏色存儲設備106存儲單個MI單元的亮度調色板顏色表TB_Y和色度調色板顏色表TB_U、TB_V,其中同一MI單元中的每個TU的調色板解碼共享相同的亮度調色板顏色表TB_Y和色度調色板顏色表TB_U、TB_V。在一個示例性設計中,調色板顏色存儲設備106存儲在幀的第一MI單元中的每個TU的調色板解碼所需的調色板顏色(例如,由第一MI單位的調色板模式使用的亮度調色板顏色表TB_Y和色度調色板顏色表TB_U、TB_V),然後,通過重寫第一MI單元中每個TU的調色板解碼所需的調色板顏色的至少一部分(即,部分或全部),在幀的第二MI單元中存儲每個TU的調色板解碼所需的調色板顏色(例如,第二MI單元的調色板模式使用的亮度調色板顏色表TB_Y和色度調色板顏色表TB_U、TB_V)。由於調色板顏色存儲設備106的存儲容量等於一個MI單元的調色板解碼所需的調色板顏色的最大大小,調色板顏色存儲設備106的有限存儲容量用於緩沖一個MI單元的調色板模式使用的調色板顏色表,並重新用於緩衝另一個MI單元的調色板模式使用的調色板顏色表。As shown in FIG. 7, the palette color storage device 106 stores a brightness palette color table TB_Y and a chromaticity palette color table TB_U, TB_V of a single MI unit, where each TU in the same MI unit has a color palette The board decoding shares the same brightness palette color table TB_Y and chroma palette color table TB_U, TB_V. In one exemplary design, the palette color storage device 106 stores the palette colors required for the palette decoding of each TU in the first MI unit of the frame (eg, the color palette by the first MI unit). The luma palette color table TB_Y and chroma palette color table TB_U, TB_V used by the panel mode, and then decode the required palette color by rewriting the palette of each TU in the first MI unit. At least a part (ie, part or all) of the palette color required for palette decoding of each TU in the second MI unit of the frame (for example, the brightness adjustment used by the palette mode of the second MI unit Swatch color table TB_Y and chroma palette color table TB_U, TB_V). Since the storage capacity of the palette color storage device 106 is equal to the maximum size of palette colors required for palette decoding of one MI unit, the limited storage capacity of the palette color storage device 106 is used to buffer the adjustment of one MI unit. The palette color table used by the swatch mode and reused to buffer the palette color table used by the palette mode of another MI unit.

如第7圖所示,顏色索引存儲設備104存儲單個TU的亮度顏色索引圖M_CB_Y和色度顏色索引圖M_CB_U、M_CB_V,其中相同TU中的所有像素的Y顏色索引排列在亮度顏色索引圖M_CB_Y中,相同TU中的所有像素的U顏色索引排列在色度顏色索引圖M_CB_U中,並且相同TU中的所有像素的V顏色索引排列在色度顏色索引圖M_CB_V中。在一個示例性設計中,顏色索引存儲設備104存儲包括在第一TU中的像素的顏色索引(例如,第一TU的亮度顏色索引圖M_CB_Y和色度顏色索引圖M_CB_U、M_CB_V),然後通過重寫包括在第一TU中的像素顏色索引的至少一部分(即部分或全部)來存儲包括在第二TU中的像素的顏色索引(例如,第二TU的亮度顏色索引圖M_CB_Y和色度顏色索引圖M_CB_U、M_CB_V)。由於顏色索引存儲設備104的存儲容量等於一個TU中所有像素的顏色索引的最大大小,因此顏色索引存儲設備104的有限存儲容量用於緩沖一個TU中的像素的顏色索引,並重新用於緩衝另一個TU中像素的顏色索引。簡言之,調色板值處理電路102以基於TU的方式計算像素的調色板值,因此允許顏色索引存儲設備104的存儲容量小於一幀中所有像素的顏色索引的大小。As shown in FIG. 7, the color index storage device 104 stores the luminance color index map M_CB_Y and chrominance color index maps M_CB_U, M_CB_V of a single TU, where the Y color indexes of all pixels in the same TU are arranged in the luminance color index map M_CB_Y The U color indexes of all pixels in the same TU are arranged in the chroma color index map M_CB_U, and the V color indexes of all pixels in the same TU are arranged in the chroma color index map M_CB_V. In one exemplary design, the color index storage device 104 stores the color indexes of the pixels included in the first TU (for example, the luminance color index map M_CB_Y and chrominance color index maps M_CB_U, M_CB_V of the first TU), and Write at least a part (ie, part or all) of the pixel color index included in the first TU to store the color index of the pixels included in the second TU (for example, the luminance color index map M_CB_Y and the chrominance color index of the second TU Figures M_CB_U, M_CB_V). Since the storage capacity of the color index storage device 104 is equal to the maximum size of the color index of all pixels in a TU, the limited storage capacity of the color index storage device 104 is used to buffer the color index of the pixels in one TU and reused to buffer another Color index of a pixel in a TU. In short, the palette value processing circuit 102 calculates the palette value of a pixel in a TU-based manner, thus allowing the storage capacity of the color index storage device 104 to be smaller than the size of the color index of all pixels in a frame.

關於視訊解碼器中的低成本調色板解碼設計,調色板顏色存儲設備106的最大存儲容量可能能夠緩衝僅由單個MI單元的調色板模式使用的調色板顏色,以及顏色索引存儲設備104的最大存儲容量可能能夠緩衝僅包括在單個TU中的像素的顏色索引。然而,這僅用於說明目的,並不意味著是對本發明的限制。在成本和性能之間存在權衡。在一個替代設計中,調色板顏色存儲設備106的最大存儲容量可以能夠緩衝由要被解碼的幀中包括的K個MI單元(K≥2)的調色板模式所使用的調色板顏色,和/或顏色索引存儲設備104的最大存儲容量可以能夠緩衝要解碼的MI單元的L個TU(L≥2)中包括的像素的顏色索引,其中要解碼的幀可以被劃分為K'個MI單元(K'> K),並且要解碼的MI單元可以被分成L'個TU(L'> L)。例如,調色板顏色存儲設備106可以由乒乓緩衝器(ping-pong buffer)實現,和/或顏色索引存儲設備104可以由乒乓緩衝器實現。Regarding the low-cost palette decoding design in the video decoder, the maximum storage capacity of the palette color storage device 106 may be able to buffer the palette colors used only by the palette mode of a single MI unit, and the color index storage device The maximum storage capacity of 104 may be able to buffer the color index of pixels included in only a single TU. However, this is for illustrative purposes only and is not meant to be a limitation on the present invention. There is a trade-off between cost and performance. In an alternative design, the maximum storage capacity of the palette color storage device 106 may be able to buffer the palette colors used by the palette mode of the K MI units (K≥2) included in the frame to be decoded , And / or the maximum storage capacity of the color index storage device 104 may be able to buffer the color indexes of pixels included in the L TUs (L ≥ 2) of the MI unit to be decoded, where the frames to be decoded may be divided into K ' MI units (K '> K), and the MI units to be decoded can be divided into L' number of TUs (L '> L). For example, the palette color storage device 106 may be implemented by a ping-pong buffer, and / or the color index storage device 104 may be implemented by a ping-pong buffer.

調色板解碼裝置100的調色板值輸出D_OUT包括用於像素重構的調色板值。根據TU的編解碼模式,在TU中重構像素可能需要像素的調色板值,或像素的殘差資料,或像素的調色板值和殘差資料兩者。第8圖是圖示根據本發明的實施例的第一視訊解碼器的圖。例如,視訊解碼器800可以是AV1解碼器。如第8圖所示,視訊解碼器800包括上述熵解碼器(由“熵解碼”表示)10、調色板解碼裝置(由“調色板解碼”表示)100和重構電路(由“REC”表示)20,並且還包括殘差解碼電路(由“IS / IQ / IT”表示)802、加法器電路804、多個多工器電路(由“MUX”表示)806和820、殘差緩衝器808、去塊濾波器( 由“DF”表示)810、至少一個參考幀緩衝器812、幀內預測電路(由“IP”表示)814、運動向量生成電路(由“MV生成”表示)816,以及運動補償電路( 用“MC”表示)818。The palette value output D_OUT of the palette decoding device 100 includes a palette value for pixel reconstruction. According to the coding and decoding mode of the TU, reconstructing a pixel in the TU may require the palette value of the pixel, or the residual data of the pixel, or both the palette value and the residual data of the pixel. FIG. 8 is a diagram illustrating a first video decoder according to an embodiment of the present invention. For example, the video decoder 800 may be an AV1 decoder. As shown in FIG. 8, the video decoder 800 includes the above-mentioned entropy decoder (represented by “entropy decoding”) 10, a palette decoding device (represented by “palette decoding”) 100, and a reconstruction circuit (represented by “REC ") 20, and also includes residual decoding circuit (represented by" IS / IQ / IT ") 802, adder circuit 804, multiple multiplexer circuits (represented by" MUX ") 806 and 820, residual buffer 808, deblocking filter (represented by "DF") 810, at least one reference frame buffer 812, intra prediction circuit (represented by "IP") 814, motion vector generation circuit (represented by "MV generation") 816 , And a motion compensation circuit (indicated by "MC") 818.

調色板解碼裝置100能夠生成要重構的一個TU中包括的每個像素的調色板值PV。殘差解碼電路802能夠為要重構的一個TU中包括的每個像素生成殘差資料(residue data)RD。例如,殘差解碼電路802可以將逆掃描(IS)、逆量化(IQ)和逆變換(IT)應用於位元流BS的熵解碼結果,以獲得殘差資料RD。加法器電路840被佈置為將調色板值PV添加到殘差資料RD以生成調整後的殘差資料。多工器電路806包括第一輸入埠、第二輸入埠、第三輸入埠和輸出埠,其中第一輸入埠被佈置為接收調色板解碼裝置100的輸出作為模式0資料D_M0(例如,D_M0 = PV),第二輸入埠用於接收加法器電路804的輸出作為模式1資料D_M1(例如,D_M1 = PV + RD),第三輸入埠用於接收殘差解碼電路816的輸出作為模式2資料D_M2(例如,D_M2 = RD),並且輸出埠被佈置為將模式0資料D_M0、模式1資料D_M1和模式2資料D_M1中的一個輸出到殘差緩衝器808。The palette decoding device 100 can generate a palette value PV of each pixel included in one TU to be reconstructed. The residual decoding circuit 802 can generate residual data (RD) for each pixel included in one TU to be reconstructed. For example, the residual decoding circuit 802 may apply inverse scanning (IS), inverse quantization (IQ), and inverse transform (IT) to the entropy decoding result of the bit stream BS to obtain residual data RD. The adder circuit 840 is arranged to add the palette value PV to the residual data RD to generate an adjusted residual data. The multiplexer circuit 806 includes a first input port, a second input port, a third input port, and an output port. The first input port is arranged to receive the output of the palette decoding device 100 as the mode 0 data D_M0 (for example, D_M0 = PV), the second input port is used to receive the output of the adder circuit 804 as the mode 1 data D_M1 (for example, D_M1 = PV + RD), and the third input port is used to receive the output of the residual decoding circuit 816 as the mode 2 data D_M2 (for example, D_M2 = RD), and the output port is arranged to output one of the mode 0 data D_M0, the mode 1 data D_M1, and the mode 2 data D_M1 to the residual buffer 808.

多工器電路806由從調色板解碼裝置100的控制邏輯產生的模式選擇信號MS控制。換句話說,模式選擇信號MS確定調色板解碼裝置100的輸出、加法器電路804的輸出和殘差解碼電路816的輸出中的哪一個被存儲到殘差緩衝器808中。重構器20從殘差緩衝器808讀取存儲的資料,用於在一個TU中重構像素。當重構TU不需要殘差資料時,模式選擇信號MS由模式0(其為“僅調色板值”模式)設置,使得多工器806將TU中像素的調色板值PV傳遞給殘差緩衝器808用於重構。當TU的重構需要調色板值以及殘差資料時,模式選擇信號MS由模式1(其是“調色板值加殘差資料”模式)設置,使得多工器806傳遞組合調色板值PV和殘差資料RD的結果到殘差緩衝器808,以用於重構。當重構TU不需要調色板值時,模式選擇信號MS由模式2設置(其為“僅殘差資料”模式),使得多工器806將殘差資料RD傳遞到殘差緩衝器808以供重構使用。The multiplexer circuit 806 is controlled by a mode selection signal MS generated from the control logic of the palette decoding device 100. In other words, the mode selection signal MS determines which of the output of the palette decoding device 100, the output of the adder circuit 804, and the output of the residual decoding circuit 816 is stored in the residual buffer 808. The reconstructor 20 reads the stored data from the residual buffer 808 for reconstructing pixels in a TU. When the residual data is not needed for reconstructing the TU, the mode selection signal MS is set by mode 0 (which is a "palette value only" mode), so that the multiplexer 806 passes the palette value PV of the pixels in the TU to the residual The difference buffer 808 is used for reconstruction. When palette values and residual data are required for the reconstruction of the TU, the mode selection signal MS is set by mode 1 (which is a "palette value plus residual data" mode), so that the multiplexer 806 passes the combined palette The results of the values PV and the residual data RD are passed to the residual buffer 808 for reconstruction. When the palette value is not required for reconstructing the TU, the mode selection signal MS is set by mode 2 (which is the "residual data only" mode), so that the multiplexer 806 passes the residual data RD to the residual buffer 808 to For refactoring.

第9圖是示出根據本發明的實施例的解碼幀的MI單元中的TU所涉及的控制流程的流程圖。假設結果基本相同,則不需要以第9圖所示的確切順序執行步驟。在步驟902,開始MI單元的解碼。在步驟904,檢查MI單元是否使用調色板模式。如果MI單元未使用調色板模式,則不需要執行所提出的基於TU的調色板解碼處理,並且流程前進到步驟918。在步驟918,開始MI單元中的當前TU的解碼。在步驟920,多工器806從殘差解碼電路802獲得殘差資料RD,並將殘差資料RD存儲到殘差緩衝器808中以用於重構。在步驟922,檢查當前TU是否是MI單元中的最後一個TU。當當前TU是MI單元中的最後一個TU時,MI單元的解碼結束。當當前TU不是MI單元中的最後一個TU時,流程前進到步驟918以處理MI單元中的下一個TU。FIG. 9 is a flowchart illustrating a control flow related to a TU in an MI unit of a decoded frame according to an embodiment of the present invention. Assuming the results are essentially the same, the steps need not be performed in the exact order shown in Figure 9. In step 902, decoding of the MI unit is started. In step 904, it is checked whether the MI unit uses the palette mode. If the MI unit does not use the palette mode, the proposed TU-based palette decoding process need not be performed, and the flow proceeds to step 918. At step 918, decoding of the current TU in the MI unit is started. In step 920, the multiplexer 806 obtains the residual data RD from the residual decoding circuit 802, and stores the residual data RD in the residual buffer 808 for reconstruction. In step 922, it is checked whether the current TU is the last TU in the MI unit. When the current TU is the last TU in the MI unit, the decoding of the MI unit ends. When the current TU is not the last TU in the MI unit, the flow proceeds to step 918 to process the next TU in the MI unit.

當步驟904指示MI單元使用調色板模式時,流程前進到步驟906。在步驟906,開始解碼MI單元中的當前TU。在步驟908,檢查當前TU是否使用跳過模式。當當前TU使用跳過模式時,沒有資訊從視訊編碼器發送到視訊解碼器。例如,位元流BS不具有編解碼變換係數,沒有報頭(header),並且沒有用於跳過模式TU的幀內/幀間預測資訊。因此,對於當前TU是跳過模式TU,沒有從殘差解碼電路802生成殘差資料RD。在步驟910,多工器806從調色板解碼裝置100獲得調色板值PV,並將調色板值PV存儲到殘差緩衝器808中以用於重構。應當注意,在當前TU是跳過模式TU的條件下,沒有從位元流BS解碼當前TU的殘差資料,並且殘差緩衝器808用作用於緩沖當前TU的調色板值的調色板緩衝器。在步驟916,檢查當前TU是否是MI單元中的最後一個TU。當當前TU是MI單元中的最後一個TU時,MI單元的解碼結束。當當前TU不是MI單元中的最後一個TU時,流程前進到步驟906以處理MI單元中的下一個TU。When step 904 instructs the MI unit to use the palette mode, the flow advances to step 906. At step 906, decoding of the current TU in the MI unit begins. In step 908, it is checked whether the current TU uses skip mode. When the current TU uses skip mode, no information is sent from the video encoder to the video decoder. For example, the bitstream BS does not have codec transform coefficients, has no header, and has no intra / inter prediction information for skip mode TU. Therefore, for the current TU being a skip mode TU, the residual data RD is not generated from the residual decoding circuit 802. In step 910, the multiplexer 806 obtains the palette value PV from the palette decoding device 100, and stores the palette value PV in the residual buffer 808 for reconstruction. It should be noted that under the condition that the current TU is a skip mode TU, the residual data of the current TU is not decoded from the bit stream BS, and the residual buffer 808 is used as a palette for buffering the palette values of the current TU buffer. In step 916, it is checked whether the current TU is the last TU in the MI unit. When the current TU is the last TU in the MI unit, the decoding of the MI unit ends. When the current TU is not the last TU in the MI unit, the flow proceeds to step 906 to process the next TU in the MI unit.

當步驟908指示當前TU未使用跳過模式時,從殘差解碼電路802生成殘差資料RD,以用於為非跳過模式TU的當前TU。在步驟912,加法器電路804從調色板解碼裝置100獲得調色板值PV,並從殘差解碼電路802獲得殘差資料RD。作為示例而非限制,當前TU的所有殘差資料RD準備好時,殘差解碼電路802斷言(assert)殘差資料就緒的信號,並且調色板解碼裝置100不執行用於生成當前TU的調色板值PV的調色板值計算處理,直到殘差解碼電路802斷言殘差資料就緒信號為止。在步驟914,多工器806從加法器電路804接收經調整的殘差資料,並將經調整的殘差資料存儲到殘差緩衝器808中以用於重構。在步驟916,檢查當前TU是否是MI單元中的最後一個TU。當當前TU是MI單元中的最後一個TU時,MI單元的解碼結束。當當前TU不是MI單元中的最後一個TU時,流程前進到步驟906以處理MI單元中的下一個TU。When step 908 indicates that the skip mode is not used for the current TU, the residual data RD is generated from the residual decoding circuit 802 for the current TU of the non-skip mode TU. In step 912, the adder circuit 804 obtains the palette value PV from the palette decoding device 100, and obtains the residual data RD from the residual decoding circuit 802. By way of example and not limitation, when all the residual data RD of the current TU is ready, the residual decoding circuit 802 asserts a signal that the residual data is ready, and the palette decoding device 100 does not perform tuning for generating the current TU. The palette value calculation process of the swatch value PV is performed until the residual decoding circuit 802 asserts the residual data ready signal. At step 914, the multiplexer 806 receives the adjusted residual data from the adder circuit 804 and stores the adjusted residual data into the residual buffer 808 for reconstruction. In step 916, it is checked whether the current TU is the last TU in the MI unit. When the current TU is the last TU in the MI unit, the decoding of the MI unit ends. When the current TU is not the last TU in the MI unit, the flow proceeds to step 906 to process the next TU in the MI unit.

重構電路20在殘差緩衝器808中讀取存儲的資料以用於重構。另外,當使用幀內模式或幀間模式對TU進行編碼時,重構電路20還使用預測值PRED,其中預測值PRED可以是由幀內預測電路814確定的幀內模式預測值或者由運動向量生成電路816和運動補償電路818確定的幀間預測值。具體地,當使用幀內模式對當前TU進行編碼時,多工器820將幀內模式預測值輸出到重構電路20;當使用幀間模式對當前TU進行編碼時,多工器820將幀間模式預測值輸出到重構電路20。去塊濾波器810用於在重構之後執行去塊處理。因此,從重構電路20生成的重構幀通過去塊濾波器810存儲到參考幀緩衝器814中。The reconstruction circuit 20 reads the stored data in the residual buffer 808 for reconstruction. In addition, when the TU is encoded using the intra mode or the inter mode, the reconstruction circuit 20 also uses a prediction value PRED, where the prediction value PRED may be an intra mode prediction value determined by the intra prediction circuit 814 or a motion vector The inter prediction value determined by the generating circuit 816 and the motion compensation circuit 818. Specifically, when the current TU is encoded using the intra mode, the multiplexer 820 outputs the intra mode prediction value to the reconstruction circuit 20; when the current TU is encoded using the inter mode, the multiplexer 820 encodes the frame The inter-mode prediction value is output to the reconstruction circuit 20. The deblocking filter 810 is used to perform a deblocking process after reconstruction. Therefore, the reconstructed frame generated from the reconstruction circuit 20 is stored in the reference frame buffer 814 through the deblocking filter 810.

第8圖中所示的架構包括:使用相同的殘差緩衝器808在不同的時序(timing)來存儲通過在調色板模式MI單元中重構跳過模式TU所使用的模式0資料D_M0,通過在調色板模式MI單元中重構非跳過模式TU而使用的模式1資料D_M1,以及通過在非調色板模式MI單元中重構TU而使用的模式2資料D_M2。以這種方式,可以放寬視訊解碼器的緩衝要求。然而,這僅用於說明目的,並不意味著是對本發明的限制。實際上,使用所提出的高性能和低成本調色板解碼裝置100的任何視訊解碼器都落入本發明的範圍內。在替代設計中,一個調色板緩衝器和一個殘差緩衝器均可以在使用所提出的高性能和低成本調色板解碼裝置100的視訊解碼器中實現。The architecture shown in FIG. 8 includes: using the same residual buffer 808 at different timings to store the mode 0 data D_M0 used by reconstructing the skip mode TU in the palette mode MI unit, Mode 1 data D_M1 used by reconstructing the non-skip mode TU in the palette mode MI unit, and Mode 2 data D_M2 used by reconstructing the TU in the non-palette mode MI unit. In this way, the buffering requirements of the video decoder can be relaxed. However, this is for illustrative purposes only and is not meant to be a limitation on the present invention. In fact, any video decoder using the proposed high-performance and low-cost palette decoding device 100 falls within the scope of the present invention. In an alternative design, both a palette buffer and a residual buffer may be implemented in a video decoder using the proposed high-performance and low-cost palette decoding device 100.

第10圖是圖示根據本發明的實施例的第二視訊解碼器的圖。例如,視訊解碼器1000可以是AV1解碼器。如第10圖所示,視訊解碼器800包括上述熵解碼器10、調色板解碼裝置100、重構電路20、殘差解碼電路802、去塊濾波器810、參考幀緩衝器812、幀內預測電路814、運動向量生成電路816、運動補償電路818、多工器電路820,還包括調色板緩衝器1002、殘差緩衝器1004和選擇電路(用“SEL”表示)1006。調色板緩衝器1002用於存儲從調色板解碼裝置100生成的像素的調色板值PV。殘差緩衝器1004用於存儲從殘差解碼電路802生成的像素的殘差資料RD。選擇器電路1006 由調色板解碼裝置100的控制邏輯產生的模式選擇信號MS控制,並具有第一輸入埠、第二輸入埠和輸出埠,其中第一輸入埠用於接收從調色板緩衝器1002中讀取的調色板值PV,第二輸入埠用於接收從殘差緩衝器1004讀取的殘差資料RD,輸出埠用於輸出調色板緩衝器1002的資料輸出中的一個或兩個(即,從調色板緩衝器1002讀取的調色板值PV),以及將殘差緩衝器1004的資料輸出(即,從殘差緩衝器1004讀取的殘差資料RD)輸出到重構電路20。FIG. 10 is a diagram illustrating a second video decoder according to an embodiment of the present invention. For example, the video decoder 1000 may be an AV1 decoder. As shown in FIG. 10, the video decoder 800 includes the entropy decoder 10, the palette decoding device 100, the reconstruction circuit 20, the residual decoding circuit 802, the deblocking filter 810, the reference frame buffer 812, and the intra frame. The prediction circuit 814, the motion vector generation circuit 816, the motion compensation circuit 818, and the multiplexer circuit 820 further include a palette buffer 1002, a residual buffer 1004, and a selection circuit (indicated by "SEL") 1006. The palette buffer 1002 stores a palette value PV of pixels generated from the palette decoding device 100. The residual buffer 1004 is used to store residual data RD of pixels generated from the residual decoding circuit 802. The selector circuit 1006 is controlled by a mode selection signal MS generated by the control logic of the palette decoding device 100, and has a first input port, a second input port, and an output port, wherein the first input port is used to receive a buffer from the palette. The palette value PV read by the processor 1002, the second input port is used to receive the residual data RD read from the residual buffer 1004, and the output port is used to output one of the data outputs of the palette buffer 1002 Or two (ie, the palette value PV read from the palette buffer 1002) and outputting the data of the residual buffer 1004 (ie, the residual data RD read from the residual buffer 1004) Output to the reconstruction circuit 20.

在要解碼的當前TU是調色板模式MI單元中的跳過模式TU的第一種情況下,從調色板解碼裝置100生成當前TU的調色板值PV並將其存儲到調色板緩衝器1002中,同時對於當前TU,不從殘差解碼電路802產生殘差資料。由於模式選擇信號MS由模式0(其為“僅調色板值”模式)設置,因此選擇器電路1006將從調色板緩衝器1002讀取的調色板值PV傳遞到重構電路20,以重構當前TU。In the first case where the current TU to be decoded is the skip mode TU in the palette mode MI unit, the palette value PV of the current TU is generated from the palette decoding device 100 and stored in the palette In the buffer 1002, for the current TU, no residual data is generated from the residual decoding circuit 802. Since the mode selection signal MS is set by mode 0 (which is a "palette value only" mode), the selector circuit 1006 passes the palette value PV read from the palette buffer 1002 to the reconstruction circuit 20, To reconstruct the current TU.

在要解碼的當前TU是調色板模式MI單元中的非跳過模式TU的第二種情況下,從調色板解碼裝置100生成當前TU的調色板值PV並將其存儲到調色板緩衝器1002中, 當前TU的殘差資料RD從殘差解碼電路802產生並存儲到殘差緩衝器1004中。由於模式選擇信號MS由模式1設置(其爲“調色板值加殘差資料”模式),選擇器電路1006將從調色板緩衝器1002讀取的調色板值PV和從殘差緩衝器1004讀取的殘差資料RD傳遞到重構電路20,以重構當前TU,其中每個像素的調色板值PV和殘差資料RD的總和在由加法器電路實現的重構電路20處實現。In the second case where the current TU to be decoded is a non-skip mode TU in the palette mode MI unit, the palette value PV of the current TU is generated from the palette decoding device 100 and stored in the color palette In the board buffer 1002, the residual data RD of the current TU is generated from the residual decoding circuit 802 and stored in the residual buffer 1004. Since the mode selection signal MS is set by the mode 1 (which is a "palette value plus residual data" mode), the selector circuit 1006 reads the palette value PV read from the palette buffer 1002 and the buffer from the residual The residual data RD read by the adder 1004 is passed to the reconstruction circuit 20 to reconstruct the current TU, where the sum of the palette value PV of each pixel and the residual data RD is in the reconstruction circuit 20 implemented by the adder circuit. Everywhere.

在要解碼的當前TU是非調色板模式MI單元中的TU的第三種情況下,從殘差解碼電路802生成當前TU的殘差資料RD並將其存儲到殘差緩衝器1004中,同時對於當前TU,不從調色板解碼裝置100生成調色板值。由於模式選擇信號MS由模式2設置(其為“僅殘差資料”模式),因此選擇器電路1006將從殘差緩衝器1004讀取的殘差資料RD傳遞到重構電路20,以重構當前TU。In the third case where the current TU to be decoded is a TU in a non-palette mode MI unit, the residual data RD of the current TU is generated from the residual decoding circuit 802 and stored in the residual buffer 1004, and For the current TU, no palette value is generated from the palette decoding device 100. Since the mode selection signal MS is set by the mode 2 (which is a "residual data only" mode), the selector circuit 1006 passes the residual data RD read from the residual buffer 1004 to the reconstruction circuit 20 to reconstruct The current TU.

在以上實施例中,調色板解碼裝置100可以以基於小尺寸編解碼單元(例如,TU)的方式而不是基於大尺寸編解碼單元(例如,MI)的方式來執行調色板解碼。或者,調色板解碼裝置100可以在基於大尺寸編解碼單元(例如MI)的管線中執行調色板解碼。與在沒有管線的大尺寸編解碼單元(例如MI)中執行的調色板解碼相比,在基於大尺寸編解碼單元(例如MI)的管線中執行的調色板解碼可以具有改進的性能。第11圖是圖示根據本發明的實施例的基於管線的調色板解碼過程的圖。顏色索引存儲設備104可以被配置為具有足以緩衝由一個或多個MI單元組成的一個MI組中的所有像素的顏色索引的存儲容量。另外,調色板顏色存儲設備106可以被配置為具有足以緩衝由一個或多個MI單元組成的一個MI組的調色板解碼所需的調色板顏色的存儲容量。此外,直到MI組的調色板解碼所需的所有調色板顏色存儲在調色板顏色存儲設備106中及MI組的所有像素的顏色索引存儲在顏色索引存儲設備104中,調色板值處理電路102才開始生成由一個或多個MI單元組成的MI組中的第一像素的調色板值。In the above embodiments, the palette decoding device 100 may perform palette decoding in a manner based on a small-size codec unit (for example, TU) instead of a large-size codec unit (for example, MI). Alternatively, the palette decoding device 100 may perform palette decoding in a pipeline based on a large-size codec unit (for example, MI). Compared to palette decoding performed in a large-size codec unit (eg, MI) without a pipeline, palette decoding performed in a pipeline based on a large-size codec unit (eg, MI) may have improved performance. FIG. 11 is a diagram illustrating a pipeline-based palette decoding process according to an embodiment of the present invention. The color index storage device 104 may be configured to have a storage capacity sufficient to buffer the color indexes of all pixels in one MI group composed of one or more MI units. In addition, the palette color storage device 106 may be configured to have a storage capacity sufficient to buffer the palette colors required for palette decoding of one MI group composed of one or more MI units. In addition, all palette colors required until palette decoding of the MI group are stored in the palette color storage device 106 and the color indexes of all pixels of the MI group are stored in the color index storage device 104, and the palette values The processing circuit 102 then starts to generate the palette value of the first pixel in the MI group composed of one or more MI units.

為了清楚和簡單起見,假設每個MI組僅具有單個MI單元。如第11圖所示,第一MI組(由MI單元MI0組成)的調色板解碼所需的調色板顏色在第一時間段T0期間被寫入調色板顏色存儲設備106,並且第一MI組(其由MI單元MI0組成)中的所有像素的顏色索引在第一時間段T0期間被寫入顏色索引存儲設備104中。在第一MI組(其由MI單元MI0組成)的調色板解碼所需的調色板顏色在調色板顏色存儲設備106中可用(are available),並且第一MI組(其由MI單元MI0組成)中的所有像素的顏色索引在顏色索引存儲設備104中可用後,調色板值處理電路102開始生成第一MI組(由MI單元MI0組成)中的像素的調色板值。在第二時間段T1期間,調色板值處理電路102根據從調色板顏色存儲設備106和顏色索引存儲設備104讀取的資料,生成第一MI組(由MI單元MI0組成)中的像素的調色板值。另外,第二MI組(由MI單元MI1組成)的調色板解碼所需的調色板顏色在第二時間段T1期間被寫入調色板顏色存儲設備106,並且第二MI組(其由MI單元MI1組成)中的所有像素的顏色索引,在第二時間段T1期間被寫入顏色索引存儲設備104中。因此,將第二MI組(由MI單元MI1組成)的調色板解碼所需的調色板顏色寫入調色板顏色存儲設備106以及將第二MI組(由MI單元MI1組成)中的所有像素的顏色索引寫入到顏色索引存儲設備104的處理時間,與根據從調色板顏色存儲設備106和顏色索引存儲設備104讀取的資料產生第一MI組(由MI單元MI0組成)中的像素的調色板值的處理時間重疊。For clarity and simplicity, it is assumed that each MI group has only a single MI unit. As shown in FIG. 11, the palette color required for palette decoding of the first MI group (consisting of the MI unit MI0) is written into the palette color storage device 106 during the first time period T0, and the first The color indexes of all pixels in an MI group (which is composed of the MI unit MI0) are written into the color index storage device 104 during the first time period T0. The palette colors required for palette decoding in the first MI group (which consists of MI unit MI0) are available in the palette color storage device 106, and the first MI group (which consists of MI units After the color indexes of all pixels in MI0) are available in the color index storage device 104, the palette value processing circuit 102 starts to generate the palette values of the pixels in the first MI group (consisting of MI unit MI0). During the second time period T1, the palette value processing circuit 102 generates pixels in the first MI group (consisting of the MI unit MI0) according to the data read from the palette color storage device 106 and the color index storage device 104. The palette value. In addition, the palette color required for palette decoding of the second MI group (composed of MI unit MI1) is written into the palette color storage device 106 during the second time period T1, and the second MI group (which The color indexes of all pixels in the MI unit (MI1) are written into the color index storage device 104 during the second time period T1. Therefore, the palette colors required for the palette decoding of the second MI group (consisting of the MI unit MI1) are written into the palette color storage device 106 and the The processing time for writing the color indexes of all pixels into the color index storage device 104 and generating the first MI group (consisting of the MI unit MI0) from the data read from the palette color storage device 106 and the color index storage device 104 The processing time of the palette values of the pixels overlaps.

類似地,在第二MI組(其由MI單元MI1組成)的調色板解碼所需的調色板顏色在調色板顏色存儲設備106中可用,並且第二MI組(其由MI單元MI1組成)中的所有像素的顏色索引在顏色索引存儲設備104中可用後,調色板值處理電路102開始生成第二MI組(由MI單元MI1組成)中的像素的調色板值。在第三時間段T2期間,調色板值處理電路102根據從調色板顏色存儲設備106和顏色索引存儲設備104讀取的資料,生成第二MI組(由MI單元MI1組成)中的像素的調色板值。另外,第三MI組(由MI單元MI2組成)的調色板解碼所需的調色板顏色在第三時間段T2期間被寫入調色板顏色存儲設備106,並且第三MI組(其由MI單元MI2組成)中的所有像素的顏色索引,在第三時間段T2期間被寫入顏色索引存儲設備104中。因此,將第三MI組(由MI單元MI2組成)的調色板解碼所需的調色板顏色寫入調色板顏色存儲設備106以及將第三MI組中的所有像素的顏色索引寫入到顏色索引存儲設備104的處理時間,與根據從調色板顏色存儲設備106和顏色索引存儲設備104讀取的資料產生第二MI組(由MI單元MI1組成)中的像素的調色板值的處理時間重疊。Similarly, the palette colors required for palette decoding in the second MI group (which consists of MI unit MI1) are available in the palette color storage device 106, and the second MI group (which consists of MI unit MI1) After the color indexes of all pixels in the composition) are available in the color index storage device 104, the palette value processing circuit 102 starts to generate the palette values of the pixels in the second MI group (consisting of the MI unit MI1). During the third time period T2, the palette value processing circuit 102 generates pixels in the second MI group (consisting of the MI unit MI1) according to the data read from the palette color storage device 106 and the color index storage device 104. The palette value. In addition, the palette colors required for palette decoding of the third MI group (composed of MI unit MI2) are written to the palette color storage device 106 during the third time period T2, and the third MI group (which The color indexes of all pixels in the MI unit (MI2) are written into the color index storage device 104 during the third time period T2. Therefore, the palette color required for the palette decoding of the third MI group (consisting of the MI unit MI2) is written into the palette color storage device 106 and the color indexes of all pixels in the third MI group are written The processing time to the color index storage device 104 and the palette value of the pixels in the second MI group (consisting of the MI unit MI1) are generated based on the data read from the palette color storage device 106 and the color index storage device 104. Processing time overlaps.

應該注意,第11圖中所示的基於管線的調色板解碼處理僅用於說明目的,並不意味著是對本發明的限制。It should be noted that the pipeline-based palette decoding process shown in FIG. 11 is for illustrative purposes only, and is not meant to limit the present invention.

所屬領域具有通常知識者將容易地觀察到,可以在保留本發明的教導的同時對裝置和方法進行多種修改和更改。因此,上述公開內容應被解釋為僅受所附請求項的範圍和界限的限制。
以上所述僅為本發明之較佳實施例,凡依本發明申請專利範圍所做之均等變化與修飾,皆應屬本發明之涵蓋範圍。
Those of ordinary skill in the art will readily observe that many modifications and changes can be made to the apparatus and method while retaining the teachings of the present invention. Accordingly, the above disclosure should be construed as being limited only by the scope and boundaries of the appended claims.
The above description is only a preferred embodiment of the present invention, and all equivalent changes and modifications made in accordance with the scope of patent application of the present invention shall fall within the scope of the present invention.

10‧‧‧熵解碼器 10‧‧‧ Entropy Decoder

100‧‧‧調色板解碼裝置 100‧‧‧ palette decoding device

102‧‧‧調色板值處理電路 102‧‧‧ Palette value processing circuit

104‧‧‧顏色索引存儲設備 104‧‧‧Color Index Storage Device

106‧‧‧調色板顏色存儲設備 106‧‧‧ Palette Color Storage Device

20‧‧‧重構電路 20‧‧‧ Reconstruction circuit

202~214、302~308、902~922‧‧‧步驟 202 ~ 214, 302 ~ 308, 902 ~ 922‧‧‧ steps

800、1000‧‧‧視訊解碼器 800, 1000‧‧‧ video decoder

802‧‧‧殘差解碼電路 802‧‧‧ residual decoding circuit

804‧‧‧加法器電路 804‧‧‧adder circuit

806、820‧‧‧多工器 806, 820‧‧‧ Multiplexer

808‧‧‧殘差緩衝器 808‧‧‧ Residual buffer

810‧‧‧去塊濾波器 810‧‧‧ Deblocking Filter

812‧‧‧參考幀緩衝器 812‧‧‧Reference frame buffer

814‧‧‧幀內預測電路 814‧‧‧ intra prediction circuit

816‧‧‧運動向量生成電路 816‧‧‧Motion vector generation circuit

818‧‧‧運動補償電路 818‧‧‧Motion compensation circuit

1002‧‧‧調色板緩衝器 1002‧‧‧ Palette Buffer

1004‧‧‧殘差緩衝器 1004‧‧‧ Residual buffer

1006‧‧‧選擇電路 1006‧‧‧Selection circuit

第1圖是示出根據本發明的實施例的調色板解碼設備的圖。FIG. 1 is a diagram showing a palette decoding device according to an embodiment of the present invention.

第2圖是示出根據本發明實施例的在幀的一個MI單元中重構像素的像素值所涉及的調色板解碼處理的流程圖。 FIG. 2 is a flowchart illustrating a palette decoding process involved in reconstructing a pixel value of a pixel in one MI unit of a frame according to an embodiment of the present invention.

第3圖是示出根據本發明的實施例的調色板解碼處理中涉及的基於TU的調色板值計算處理的流程圖。 FIG. 3 is a flowchart showing a TU-based palette value calculation process involved in a palette decoding process according to an embodiment of the present invention.

第4圖是示出根據本發明的一個實施例存儲在第1圖所示的調色板顏色存儲裝置中的多個調色板顏色表的圖。 FIG. 4 is a diagram showing a plurality of palette color tables stored in the palette color storage device shown in FIG. 1 according to an embodiment of the present invention.

第5圖是示出了根據本發明實施例的將像素的顏色索引寫入第1圖所示的顏色索引存儲設備,以創建一個TU的顏色索引圖的操作的圖。 FIG. 5 is a diagram illustrating an operation of writing a color index of a pixel into the color index storage device shown in FIG. 1 to create a color index map of a TU according to an embodiment of the present invention.

第6圖是示出根據本發明的一個實施例從第1圖所示的顏色索引存儲設備讀取顏色索引圖的顏色索引的操作的圖。 FIG. 6 is a diagram illustrating an operation of reading a color index of a color index map from the color index storage device shown in FIG. 1 according to an embodiment of the present invention.

第7圖是示出示出了根據本發明的一個實施例由第1圖所示的調色板值處理電路執行的調色板值生成處理的圖。 FIG. 7 is a diagram showing a palette value generation process performed by the palette value processing circuit shown in FIG. 1 according to an embodiment of the present invention.

第8圖是圖示根據本發明的實施例的第一視訊解碼器的圖。 FIG. 8 is a diagram illustrating a first video decoder according to an embodiment of the present invention.

第9圖是示出根據本發明的實施例的解碼幀的MI單元中的TU所涉及的控制流程的流程圖。 FIG. 9 is a flowchart illustrating a control flow related to a TU in an MI unit of a decoded frame according to an embodiment of the present invention.

第10圖是圖示根據本發明的實施例的第二視訊解碼器的圖。 FIG. 10 is a diagram illustrating a second video decoder according to an embodiment of the present invention.

第11圖是圖示根據本發明的實施例的基於管線的調色板解碼過程的圖。 FIG. 11 is a diagram illustrating a pipeline-based palette decoding process according to an embodiment of the present invention.

Claims (22)

一種視訊解碼器,包括: 調色板解碼裝置,包括: 調色板顏色存儲設備,用於存儲從位元流解碼的多個調色板顏色; 顏色索引存儲設備,用於存儲多個像素的多個顏色索引,其中該多個顏色索引從該位元流中解碼;以及 調色板值處理電路,用於通過以下方式為該多個像素的每個像素生成調色板值: 從該顏色索引存儲設備讀取該每個像素的顏色索引; 搜索存儲在該調色板顏色存儲設備中的調色板顏色,該調色板顏色由該每個像素的該顏色索引來索引;以及 通過該調色板顏色設置該每個像素的該調色板值; 其中,幀被劃分為多個第一編解碼單元,該多個第一編解碼單元的每個被細分為一個或多個第二編解碼單元,並且在該調色板值處理電路生成該第一編解碼單元中的最後一個像素的調色板值之前,該第一編解碼單元中的非最後像素的調色板值由該調色板值處理電路生成,並由該視訊解碼器的重構電路使用。A video decoder includes: Palette decoding device, including: Palette color storage device, used to store multiple palette colors decoded from the bitstream; A color index storage device for storing a plurality of color indexes of a plurality of pixels, wherein the plurality of color indexes are decoded from the bit stream; and The palette value processing circuit is configured to generate a palette value for each pixel of the plurality of pixels in the following manner: Read the color index of each pixel from the color index storage device; Searching for a palette color stored in the palette color storage device, the palette color being indexed by the color index of each pixel; and Set the palette value of each pixel by the palette color; The frame is divided into a plurality of first codec units, each of the plurality of first codec units is subdivided into one or more second codec units, and the first value is generated by the palette value processing circuit. Before the palette value of the last pixel in a codec unit, the palette value of the non-last pixel in the first codec unit is generated by the palette value processing circuit and is repeated by the video decoder.建 电路 用。 Use circuit. 如申請專利範圍第1項所述之視訊解碼器,其中,該顏色索引存儲設備存儲包括在該多個第二編解碼單元之一中的多個像素的多個顏色索引,然後通過重寫包括在該多個第二編解碼單元中的該一個中的多個像素的該多個顔色索引的至少一部分,來存儲包括在該多個第二編解碼單元中的另一個中的多個像素的多個顔色索引。The video decoder according to item 1 of the patent application scope, wherein the color index storage device stores a plurality of color indexes of a plurality of pixels included in one of the plurality of second codec units, and then includes At least a part of the plurality of color indexes of a plurality of pixels in the one of the plurality of second codec units to store a plurality of pixels included in another one of the plurality of second codec units Multiple color indexes. 如申請專利範圍第2項所述之視訊解碼器,其中,該顏色索引存儲設備的存儲容量等於一個第二編解碼單元中的所有像素的顏色索引的最大大小。The video decoder according to item 2 of the patent application scope, wherein a storage capacity of the color index storage device is equal to a maximum size of a color index of all pixels in a second codec unit. 如申請專利範圍第2項所述之視訊解碼器,其中每個第一編解碼單元是模式資訊(MI)單元,並且每個第二編解碼單元是變換單元(TU)。The video decoder according to item 2 of the scope of patent application, wherein each first codec unit is a mode information (MI) unit, and each second codec unit is a transform unit (TU). 如申請專利範圍第1項所述之視訊解碼器,其中,該顏色索引存儲設備的存儲容量小於一個第一編解碼單元中的所有像素的顏色索引的大小。The video decoder according to item 1 of the patent application scope, wherein a storage capacity of the color index storage device is smaller than a size of a color index of all pixels in a first codec unit. 如申請專利範圍第1項所述之視訊解碼器,其中,該調色板顏色存儲裝置存儲該多個第一編解碼單元其中一個中的每個第二編解碼單元的調色板解碼所需的多個調色板顏色,然後通過重寫該多個第一編解碼單元之一中的每個第二編解碼單元的調色板解碼所需的該多個調色板顏色的至少一部分,來存儲該多個第一編解碼單元中的另一個中的每個第二編解碼單元的調色板解碼所需的多個調色板顔色。The video decoder according to item 1 of the patent application scope, wherein the palette color storage device stores a palette decoding required for each second codec unit in one of the plurality of first codec units. A plurality of palette colors, and then by rewriting at least a portion of the plurality of palette colors required by the palette decoding of each second codec unit of one of the plurality of first codec units, To store a plurality of palette colors required for the palette decoding of each of the second one of the plurality of first codec units. 如申請專利範圍第6項所述之視訊解碼器,其中,該調色板顏色存儲設備的存儲容量等於一個第一編解碼單元的調色板解碼所需的多個調色板顏色的最大大小。The video decoder according to item 6 of the patent application scope, wherein the storage capacity of the palette color storage device is equal to the maximum size of multiple palette colors required for palette decoding of a first codec unit . 如申請專利範圍第6項所述之視訊解碼器,其中每個第一編解碼單元是模式資訊(MI)單元,並且每個第二編解碼單元是變換單元(TU)。The video decoder according to item 6 of the scope of patent application, wherein each first codec unit is a mode information (MI) unit, and each second codec unit is a transform unit (TU). 如申請專利範圍第1項所述之視訊解碼器,其中,該調色板解碼裝置為一個第二編解碼單元中的每個像素生成調色板值,並為另一個第二編解碼單元中的每個像素生成調色板值;以及該視訊解碼器還包括: 殘差解碼電路,用於解碼該位元流的熵解碼結果,以為該另一個第二編解碼單元中的該每個像素生成殘差資料,並為又一個第二編解碼單元中的每個像素生成殘差資料; 加法器電路,用於將該另一個第二編解碼單元中的該每個像素的該調色板值與該另一個第二編解碼單元中的該每個像素的該殘差資料相加,以生成該另一個第二編解碼單元中的該每個像素的調整後的殘差資料; 存儲設備;以及 多工器電路,具有第一輸入埠、第二輸入埠、第三輸入埠和輸出埠,其中該第一輸入埠用於接收該調色板解碼裝置的輸出,該第二輸入埠用於接收該加法器電路的輸出,該第三輸入埠用於接收該殘差解碼電路的輸出,該輸出埠用於分別在不同時序輸出該調色板解碼裝置的該輸出、該加法器電路的該輸出和該殘差解碼電路的該輸出到該存儲設備; 其中,該重構電路從該存儲設備讀取存儲的資料以進行重構。The video decoder according to item 1 of the patent application scope, wherein the palette decoding device generates a palette value for each pixel in one second codec unit, and generates the palette value in another second codec unit. Generates a palette value for each pixel of the; and the video decoder further includes: A residual decoding circuit for decoding the entropy decoding result of the bit stream to generate residual data for each pixel in the other second codec unit, and for each of the second codec unit Pixel generated residual data; An adder circuit, configured to add the palette value of the each pixel in the other second codec unit and the residual data of the each pixel in the other second codec unit, To generate the adjusted residual data of each pixel in the another second codec unit; Storage devices; and Multiplexer circuit having a first input port, a second input port, a third input port, and an output port, wherein the first input port is used to receive the output of the palette decoding device, and the second input port is used to receive The output of the adder circuit, the third input port is used to receive the output of the residual decoding circuit, and the output port is used to output the output of the palette decoding device and the output of the adder circuit respectively at different timings. And the output of the residual decoding circuit to the storage device; The reconstruction circuit reads the stored data from the storage device for reconstruction. 如申請專利範圍第1項所述之視訊解碼器,還包括: 第一存儲設備,其中,該調色板值處理電路還用於將多個調色板值存儲到該第一存儲設備中; 第二存儲設備; 殘差解碼電路,用於對該位元流的熵解碼結果進行解碼,生成多個殘差資料,並將該多個殘差資料存儲到該第二存儲設備中;以及 選擇器電路,具有第一輸入埠、第二輸入埠和輸出埠,其中該第一輸入埠設置為接收從該第一存儲設備讀取的該多個調色板值,該第二輸入埠設置為接收從該第二存儲設備讀取的多個殘差資料,並且該輸出埠被佈置成將該多個調色板值和該多個殘差資料中的一個或兩個輸出到該重構電路。The video decoder described in item 1 of the patent application scope further includes: A first storage device, wherein the palette value processing circuit is further configured to store a plurality of palette values into the first storage device; Second storage device; A residual decoding circuit for decoding an entropy decoding result of the bit stream, generating a plurality of residual data, and storing the plurality of residual data in the second storage device; and The selector circuit has a first input port, a second input port, and an output port, wherein the first input port is configured to receive the plurality of palette values read from the first storage device, and the second input port is set To receive a plurality of residual data read from the second storage device, and the output port is arranged to output one or two of the plurality of palette values and the plurality of residual data to the reconstruction Circuit. 一種視訊解碼方法,包括: 將從位元流解碼的多個調色板顏色存儲到調色板顏色存儲設備中; 將多個像素的多個顏色索引存儲到顏色索引存儲設備中,其中該多個顏色索引從該位元流中解碼;以及 通過以下方式為該多個像素的每個像素生成調色板值: 從該顏色索引存儲設備讀取該每個像素的顏色索引; 搜索存儲在該調色板顏色存儲設備中的調色板顏色,該調色板顏色由該每個像素的該顏色索引索引;以及 通過該調色板顏色設置該每個像素的該調色板值; 其中,幀被劃分為多個第一編解碼單元,該多個第一編解碼單元的每個被細分為一個或多個第二編解碼單元,並且在生成第一編解碼單元中的最後一個像素的調色板值之前,生成該第一編解碼單元中的非最後像素的調色板值,並用於該非最後像素的重構。A video decoding method includes: Store multiple palette colors decoded from a bit stream into a palette color storage device; Storing multiple color indexes of multiple pixels into a color index storage device, wherein the multiple color indexes are decoded from the bit stream; and Generate a palette value for each of the multiple pixels by: Read the color index of each pixel from the color index storage device; Searching for a palette color stored in the palette color storage device, the palette color being indexed by the color index of each pixel; and Set the palette value of each pixel by the palette color; The frame is divided into a plurality of first codec units, each of the plurality of first codec units is subdivided into one or more second codec units, and the last one of the first codec units is generated Before the palette value of the pixel, the palette value of the non-last pixel in the first codec unit is generated and used for reconstruction of the non-last pixel. 如申請專利範圍第11項所述之視訊解碼方法,其中,將多個像素的多個顏色索引存儲到該顏色索引存儲設備中包括: 存儲包括在該多個第二編解碼單元之一中的多個像素的多個顏色索引;以及 通過重寫包括在該多個第二編解碼單元中的該一個中的多個像素的該多個顔色索引的至少一部分,來存儲包括在該多個第二編解碼單元中的另一個中的多個像素的多個顔色索引。The video decoding method according to item 11 of the scope of patent application, wherein storing multiple color indexes of multiple pixels into the color index storage device includes: Storing a plurality of color indexes of a plurality of pixels included in one of the plurality of second codecs; and By rewriting at least a part of the plurality of color indexes of a plurality of pixels included in the one of the plurality of second codec units, the one included in the other of the plurality of second codec units is stored Multiple color indexes for multiple pixels. 如申請專利範圍第12項所述之視訊解碼方法,其中,該顏色索引存儲設備的存儲容量等於一個第二編解碼單元中的所有像素的顏色索引的最大大小。The video decoding method according to item 12 of the scope of patent application, wherein the storage capacity of the color index storage device is equal to the maximum size of the color indexes of all pixels in a second codec unit. 如申請專利範圍第12項所述之視訊解碼方法,其中,其中每個第一編解碼單元是模式資訊(MI)單元,並且每個第二編解碼單元是變換單元(TU)。The video decoding method according to item 12 of the scope of patent application, wherein each first codec unit is a mode information (MI) unit, and each second codec unit is a transform unit (TU). 如申請專利範圍第11項所述之視訊解碼方法,其中,該顏色索引存儲設備的存儲容量小於一個第一編解碼單元中的所有像素的顏色索引的大小。The video decoding method according to item 11 of the scope of patent application, wherein a storage capacity of the color index storage device is smaller than a size of a color index of all pixels in a first codec unit. 如申請專利範圍第11項所述之視訊解碼方法,其中,將從該位元流解碼的多個調色板顏色存儲到該調色板顏色存儲裝置中包括: 存儲該多個第一編解碼單元之一中的每個第二編解碼單元的調色板解碼所需的多個調色板顏色;以及 通過重寫該多個第一編解碼單元之一中的每個第二編解碼單元的調色板解碼所需的該多個調色板顏色的至少一部分,來存儲該多個第一編解碼單元中的另一個中的每個第二編解碼單元的調色板解碼所需的多個調色板顔色。The video decoding method according to item 11 of the scope of patent application, wherein storing the plurality of palette colors decoded from the bit stream into the palette color storage device includes: Storing a plurality of palette colors required for palette decoding of each of the plurality of first codec units; and Storing the plurality of first codecs by rewriting at least a part of the plurality of palette colors required for palette decoding of each of the plurality of first codec units A plurality of palette colors required for palette decoding of each of the second codec units in the other of the units. 如申請專利範圍第16項所述之視訊解碼方法,其中,該調色板顏色存儲設備的存儲容量等於一個第一編解碼單元的調色板解碼所需的多個調色板顏色的最大大小。The video decoding method according to item 16 of the patent application scope, wherein the storage capacity of the palette color storage device is equal to the maximum size of multiple palette colors required for palette decoding of a first codec unit . 如申請專利範圍第16項所述之視訊解碼方法,其中每個第一編解碼單元是模式資訊(MI)單元,並且每個第二編解碼單元是變換單元(TU)。The video decoding method according to item 16 of the scope of patent application, wherein each first codec unit is a mode information (MI) unit, and each second codec unit is a transform unit (TU). 如申請專利範圍第11項所述之視訊解碼方法,其中,為一個第二編解碼單元中的每個像素生成調色板值,並且為另一個第二編解碼單元中的每個像素生成調色板值,該視訊解碼方法還包括: 解碼該位元流的熵解碼結果,以生成用於該另一個第二編解碼單元中的該每個像素的殘差資料,並生成用於又一個第二編解碼單元中的每個像素的殘差資料; 通過將該另一個第二編解碼單元中的該每個像素的該調色板值與該另一個第二編解碼單元中的該每個像素的該殘差資料相加,生成該另一個第二編解碼單元中的該每個像素的調整後的殘差資料;以及 在不同時序將包括為該一個第二編解碼單元生成的多個調色板值的第一輸入,包括為該另一個第二編解碼單元生成的調整後的殘差資料的第二輸入,以及包括為該又一個第二編解碼單元生成的殘差資料的第三輸入存儲到同一存儲設備中,其中從該存儲設備讀取存儲的資料以重構像素。The video decoding method according to item 11 of the patent application scope, wherein a palette value is generated for each pixel in one second codec unit, and a tone is generated for each pixel in another second codec unit Color plate value, the video decoding method further includes: Decode the entropy decoding result of the bit stream to generate residual data for each pixel in the other second codec unit, and generate the data for each pixel in yet another second codec unit Residual data Generating the other first codec unit by adding the palette value of each pixel in the other second codec unit to the residual data of each pixel in the other second codec unit The adjusted residual data of each pixel in the two codec units; and A first input including multiple palette values generated for the one second codec unit, a second input including adjusted residual data generated for the other second codec unit at different timings, and A third input including residual data generated for the yet another second codec unit is stored in the same storage device, where the stored data is read from the storage device to reconstruct the pixels. 如申請專利範圍第11項所述之視訊解碼方法,還包括: 將多個調色板值存儲到第一存儲設備中; 對該位元流的熵解碼結果進行解碼,生成多個殘差資料,並將該多個殘差資料存儲到第二存儲設備中;以及 通過以下方式執行像素重構: 從該第一存儲設備讀取該多個調色板值;或者 從該第二存儲設備讀取該多個殘差資料;或者 從該第一存儲設備讀取該多個調色板值,並從該第二存儲設備讀取該多個殘差資料。The video decoding method described in item 11 of the patent application scope further includes: Storing multiple palette values in a first storage device; Decoding the entropy decoding result of the bit stream to generate a plurality of residual data, and storing the plurality of residual data in a second storage device; and Perform pixel reconstruction in the following ways: Reading the plurality of palette values from the first storage device; or Reading the plurality of residual data from the second storage device; or The plurality of palette values are read from the first storage device, and the plurality of residual data are read from the second storage device. 一種視訊解碼器,包括: 調色板解碼裝置,包括: 調色板顏色存儲設備,用於存儲從位元流解碼的多個調色板顏色; 顏色索引存儲設備,用於存儲多個像素的多個顏色索引,其中該多個顏色索引從該位元流中解碼;以及 調色板值處理電路,用於通過以下方式為該多個像素的每個像素生成調色板值: 從該顏色索引存儲設備讀取該每個像素的顏色索引; 搜索存儲在該調色板顏色存儲設備中的調色板顏色,該調色板顏色由該每個像素的該顏色索引索引;以及 通過該調色板顏色設置該每個像素的該調色板值; 其中,幀被劃分為多個第一編解碼單元,並且每個第一編解碼單元被細分為一個或多個第二編解碼單元; 其中,該調色板值處理電路不開始生成至少一個第一編解碼單元的第一組中的第一像素的調色板值,直到該第一組的調色板解碼所需的所有調色板顏色存儲在該調色板顏色存儲設備中,以及該第一組的所有像素的顏色索引存儲在該顏色索引存儲設備中;以及 其中,根據從該調色板顏色存儲設備和該顏色索引存儲設備讀取的資料生成該第一組中的多個像素的多個調色板值的處理時間與將至少一個第一編解碼單元的第二組的調色板解碼所需的多個調色板顔色寫入該調色板顏色存儲裝置和將該第二組的多個像素的多個顏色索引寫入該顏色索引存儲設備的處理時間重疊。A video decoder includes: Palette decoding device, including: Palette color storage device, used to store multiple palette colors decoded from the bitstream; A color index storage device for storing a plurality of color indexes of a plurality of pixels, wherein the plurality of color indexes are decoded from the bit stream; and The palette value processing circuit is configured to generate a palette value for each pixel of the plurality of pixels in the following manner: Read the color index of each pixel from the color index storage device; Searching for a palette color stored in the palette color storage device, the palette color being indexed by the color index of each pixel; and Set the palette value of each pixel by the palette color; The frame is divided into multiple first codec units, and each first codec unit is subdivided into one or more second codec units; Wherein, the palette value processing circuit does not start to generate the palette values of the first pixels in the first group of at least one first codec unit until all the palettes required for the palette decoding of the first group Plate colors are stored in the palette color storage device, and color indexes of all pixels of the first group are stored in the color index storage device; and The processing time for generating multiple palette values of multiple pixels in the first group according to data read from the palette color storage device and the color index storage device and converting at least one first codec unit A plurality of palette colors required for palette decoding of the second group are written into the palette color storage device and multiple color indexes of multiple pixels of the second group are written into the color index storage device Processing time overlaps. 如申請專利範圍第21項所述之視訊解碼器,其中每個第一編解碼單元是模式資訊(MI)單元,並且每個第二編解碼單元是變換單元(TU)。The video decoder according to item 21 of the scope of patent application, wherein each first codec unit is a mode information (MI) unit, and each second codec unit is a transform unit (TU).
TW108107348A 2018-03-06 2019-03-06 Apparatus and method for palette decoding TWI709330B (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US201862639025P 2018-03-06 2018-03-06
US62/639,025 2018-03-06

Publications (2)

Publication Number Publication Date
TW201939954A true TW201939954A (en) 2019-10-01
TWI709330B TWI709330B (en) 2020-11-01

Family

ID=67842282

Family Applications (1)

Application Number Title Priority Date Filing Date
TW108107348A TWI709330B (en) 2018-03-06 2019-03-06 Apparatus and method for palette decoding

Country Status (3)

Country Link
US (1) US10659794B2 (en)
CN (1) CN111669597B (en)
TW (1) TWI709330B (en)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2022532444A (en) * 2019-09-07 2022-07-14 ベイジン、ターチア、インターネット、インフォメーション、テクノロジー、カンパニー、リミテッド How to Decrypt Video Data, Computing Devices, Non-Temporary Computer-Readable Storage Media, Decoder-Readable Storage Media, and Computer Program Products
WO2021133529A1 (en) * 2019-12-26 2021-07-01 Alibaba Group Holding Limited Methods for coding video data in palette mode
CN116134820A (en) * 2020-08-04 2023-05-16 现代自动车株式会社 Method and device for encoding and decoding video data based on patch

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9872040B2 (en) * 2014-01-02 2018-01-16 Qualcomm Incorporated Color index coding for palette-based video coding
US10091512B2 (en) * 2014-05-23 2018-10-02 Futurewei Technologies, Inc. Advanced screen content coding with improved palette table and index map coding methods
US10291940B2 (en) * 2014-05-23 2019-05-14 Qualcomm Incorporated Coding runs with escape in palette-based video coding

Also Published As

Publication number Publication date
CN111669597A (en) 2020-09-15
US20190281312A1 (en) 2019-09-12
TWI709330B (en) 2020-11-01
CN111669597B (en) 2022-06-07
US10659794B2 (en) 2020-05-19

Similar Documents

Publication Publication Date Title
US10911754B2 (en) Image coding method using history-based motion information and apparatus for the same
CN110622514A (en) Intra-frame reference filter for video coding
TWI709330B (en) Apparatus and method for palette decoding
US20230247214A1 (en) Configurable maximum transform size
US10812819B2 (en) Method and apparatus for video coding
BR112020027043A2 (en) METHOD AND DECODER FOR INTERPREDICTION
TW202044833A (en) Video coding in triangular prediction unit mode using different chroma formats
TW202034695A (en) Constrained affine motion inheritance for video coding
TW201939952A (en) Intra prediction for 360-degree video
CN114830667A (en) Reference picture scaling for reference picture resampling in video coding and decoding
JP2022132417A (en) Reference Sample Padding and Filtering for Intra Prediction in Video Compression
WO2020143585A1 (en) Video encoder, video decoder, and corresponding method
TW202002654A (en) Coefficient coding with grouped bypass bins
TW202029753A (en) Wide-angle intra prediction for video coding
WO2023274044A1 (en) Encoding method for video data, decoding method for video data, computing device, and medium
KR20230097129A (en) Offset Derivation in Cross-Component Transformation Coefficient Level Reconstruction
TW202236854A (en) Buffers for video coding in palette mode
EP4374573A1 (en) Cross component end of block flag coding
CN115552901A (en) Method and apparatus for frequency dependent joint component quadratic transformation
CN115176461A (en) Video coding and decoding method and device
JP2017069617A (en) Semiconductor device and image encoding method
TWI834269B (en) Video processing method and apparatus thereof
US20230336748A1 (en) Chroma from luma prediction using mapping and different types
US10735757B2 (en) Video decoder and controlling method thereof
TW202402057A (en) Video processing method and apparatus thereof