Nothing Special   »   [go: up one dir, main page]

TW202137764A - High level syntax for video coding and decoding - Google Patents

High level syntax for video coding and decoding Download PDF

Info

Publication number
TW202137764A
TW202137764A TW110109783A TW110109783A TW202137764A TW 202137764 A TW202137764 A TW 202137764A TW 110109783 A TW110109783 A TW 110109783A TW 110109783 A TW110109783 A TW 110109783A TW 202137764 A TW202137764 A TW 202137764A
Authority
TW
Taiwan
Prior art keywords
slice
slices
header
picture
tiles
Prior art date
Application number
TW110109783A
Other languages
Chinese (zh)
Other versions
TWI811651B (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 TW202137764A publication Critical patent/TW202137764A/en
Application granted granted Critical
Publication of TWI811651B publication Critical patent/TWI811651B/en

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/70Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by syntax aspects related to video coding, e.g. related to compression standards
    • 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/167Position within a video image, e.g. region of interest [ROI]
    • 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/17Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
    • H04N19/172Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a picture, frame or field
    • 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/17Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
    • H04N19/174Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a slice, e.g. a line of blocks or a group of blocks

Landscapes

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

Abstract

There is provided a method of decoding video data from a bitstream, the bitstream comprising video data corresponding to one or more slices. Each slice may include one or more tiles. The bitstream comprises a picture header comprising syntax elements to be used when decoding one or more slices, and a slice header comprising syntax elements to be used. Decoding a slice, comprises parsing the syntax elements. In a case where a slice includes multiple tiles, the parsing of a syntax element indicating an address of a slice is omitted if a syntax element is parsed that indicates that a picture header is signalled in the slice header. The bitstream is decoded using said syntax elements.

Description

用於視頻編碼及解碼的高階語法High-level syntax for video encoding and decoding

本發明係關於視頻編碼及解碼,且特別關於用於位元流中之高階語法。The present invention relates to video encoding and decoding, and particularly to high-level syntax used in bitstreams.

近來,聯合視頻專家小組(JVET)(由MPEG及ITU-T研究群組16之VCEG所形成的合作小組)開始對於稱為多樣視頻編碼(VVC)的新視頻編碼標準工作。VVC之目標是提供在壓縮效能上超越現存HEVC標準之顯著增進(亦即,通常為之前的兩倍之多)且被完成於2020。主要目標應用及服務包括─但不限定於─360度且高動態範圍(HDR)視頻。總之,JVET係使用由獨立測試實驗室所執行的正式主觀測試以評估來自32個組織之回應。一些提議係展示通常為40%或更多(當相較於使用HEVC時)的壓縮效率增益。特別有效性被顯示於超高解析度(UHD)視頻測試材料上。因此,我們可預期顯著超越最終標準之目標50%的壓縮效能增益。 JVET探索模型(JEM)使用所有HEVC工具且已引入數個新工具。這些改變已使得對於位元流之結構的改變成為必要,且特別是對於高階語法,其可具有對位元流之整體位元率的影響。Recently, the Joint Video Experts Group (JVET) (a collaborative group formed by MPEG and VCEG of ITU-T Research Group 16) has begun work on a new video coding standard called Multiple Video Coding (VVC). The goal of VVC is to provide a significant improvement over the existing HEVC standard in compression performance (that is, usually twice as much as the previous one) and it will be completed in 2020. The main target applications and services include-but not limited to-360-degree and high dynamic range (HDR) video. In summary, JVET uses formal subjective tests performed by independent testing laboratories to evaluate responses from 32 organizations. Some proposals show a compression efficiency gain of usually 40% or more (when compared to when using HEVC). Particular effectiveness is shown on ultra-high-resolution (UHD) video test materials. Therefore, we can expect a compression performance gain that significantly exceeds the target of the final standard by 50%. The JVET Exploration Model (JEM) uses all HEVC tools and several new tools have been introduced. These changes have necessitated changes to the structure of the bitstream, and especially for high-level grammars, which may have an impact on the overall bitrate of the bitstream.

本發明係有關對於高階語法結構的增進,其導致複雜度的減少而無編碼效能的任何退化。 在依據本發明之一第一態樣中,有提供一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,該方法包含剖析該等語法元素,而在其中一切片(或圖片)包括多數磚的情況下,假如被剖析之一語法元素指示其一圖片標頭被傳訊在該切片標頭中的話則省略指示一切片之一位址的一語法元素之剖析;及使用該等語法元素來解碼該位元流。在依據本發明之另一態樣中,有提供一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,該方法包含剖析該等語法元素,而在其中一切片或圖片包括多數磚的情況下,假如被剖析之一語法元素指示其一圖片標頭被傳訊在該切片標頭中的話則省略指示一切片之一位址的一語法元素之剖析;及使用該等語法元素來解碼該位元流。在依據本發明之另一額外態樣中,有提供一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,該位元流被約束以使得在其中該位元流包括具有指示其一切片或圖片包括多數磚之一值的一語法元素且該位元流包括指示其一圖片標頭被傳訊在該切片標頭中之一語法元素的情況下,該位元流亦包括指示其指示一切片之一位址的一語法元素不被剖析的一語法元素,該方法包含使用該等語法元素來解碼該位元流。 因此,當該圖片標頭係在減少位元率的該切片標頭中時(特別針對低延遲及低位元率應用),該切片位址不被剖析。再者,當該圖片被傳訊在該切片標頭中時,剖析複雜度可被減少。 在一實施例中,(僅)當一光柵掃描切片模式將被用於解碼該切片時,該省略將被履行。如此係減少剖析複雜度但仍容許一些位元率減少。 該省略可進一步包含省略指示該切片中之磚數目的一語法元素之剖析。因此,可獲得位元率之進一步減少。 在一第二態樣中,有提供一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,且該解碼包含:剖析一或多個語法元素,而在其中一切片(或圖片)包括多數磚的情況下,假如被剖析之一語法元素指示其該圖片標頭被傳訊在該切片標頭中的話則省略指示該切片中之磚數目的一語法元素之剖析;及使用該等語法元素來解碼該位元流。在一進一步態樣中,有提供一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,且該解碼包含:剖析一或多個語法元素,而在其中一切片或圖片包括多數磚的情況下,假如被剖析之一語法元素指示其該圖片標頭被傳訊在該切片標頭中的話則省略指示該切片中之磚數目的一語法元素之剖析;及使用該等語法元素來解碼該位元流。在依據本發明之另一進一步態樣中,有提供一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,該位元流被約束以使得在其中該位元流包括具有指示其一切片或圖片包括多數磚之一值的一語法元素且該位元流包括指示其該圖片標頭被傳訊在該切片標頭中之一語法元素的情況下,該位元流亦包括指示其指示該切片中之磚數目的一語法元素不被剖析的一語法元素,該方法包含使用該等語法元素來解碼該位元流。 因此,位元率可被減少,其係有利的,特別針對其中磚數目無須被傳輸的低延遲及低位元率應用。 (僅)當一光柵掃描切片模式將被用於解碼該切片時,該省略可被履行。如此係減少剖析複雜度但仍容許一些位元率減少。 該方法可進一步包含剖析指示該圖片中之磚數目的語法元素並基於由該等經剖析語法元素所指示的該圖片中之該磚數目來判定該切片中之磚數目。此係有利的,因為其容許該切片中之該磚數目被輕易地預測,在其中一圖片標頭被傳訊在該切片標頭中而無須進一步傳訊的情況下。 該省略可進一步包含省略指示一切片之一位址的一語法元素之剖析。因此,位元率可被進一步減少。 在本發明之一第三態樣中,有提供一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,且該解碼包含:剖析一或多個語法元素,而在其中一切片(或圖片)包括多數磚的情況下,假如該切片中之磚數目等於該圖片中之磚數目的話則省略指示一切片位址之一語法元素的剖析;及使用該等語法元素來解碼該位元流。此係利用以下見解:假如切片中之磚數目等於圖片中之磚數目的話則確認其目前圖片僅含有一個切片。因此,藉由省略該切片位址,可增進位元率並減少剖析及/或編碼的複雜度。 (僅)當一光柵掃描切片模式將被用於解碼該切片時,該省略可被履行。因此,可減少複雜度而同時仍提供一些位元率減少。 該解碼可進一步包含在一切片中剖析指示該切片中之該磚數目的一語法元素;及在一圖片參數集中剖析指示該圖片中之該磚數目的語法元素,其中指示該切片位址之該語法元素的該剖析之該省略係基於該等經剖析語法元素。 該解碼可進一步包含在該切片中剖析指示該切片中之該磚數目的該語法元素,在用於傳訊一切片位址之一或多個語法元素前。 該解碼可進一步包含在一切片中剖析指示一圖片標頭是否被傳訊在一切片標頭中之一語法元素,以及假如該經剖析語法元素指示其該圖片標頭被傳訊在該切片標頭中的話判定(推論)其該切片中之該磚數目等於該圖片中之該磚數目。 在一第四態樣中,有提供一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,且該解碼包含:剖析一或多個語法元素,及在其中一語法元素指示其一光柵掃描解碼模式被致能於一切片之情況下,從該等一或多個語法元素解碼該切片中之一切片位址及磚數目的至少一者,其中在該光柵掃描解碼模式被致能於該切片之該情況下從該等一或多個語法元素的該切片中之該切片位址及該磚數目的該至少一者之該解碼並非取決於該圖片中之該磚數目;及使用該等語法元素來解碼該位元流。因此,切片標頭之剖析複雜度可被減少。 在依據本發明之第五態樣中,提供一種包含第一態樣及第二態樣的方法。 在依據本發明之第六態樣中,提供一種包含第一態樣及第二態樣及第三態樣的方法。 依據本發明之一第七態樣中,有提供一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之該視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當編碼一切片時將使用的語法元素,且該編碼包含:判定用於編碼該視頻資料之一或多個語法元素,而在其中一切片(或圖片)包括多數磚的情況下,假如一語法元素指示其一圖片標頭被傳訊在該切片標頭中的話則省略指示一切片之一位址的一語法元素之該編碼;及使用該等語法元素來編碼該視頻資料。依據本發明之另一態樣,有提供一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之該視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當編碼一切片時將使用的語法元素,且該編碼包含:判定用於編碼該視頻資料之一或多個語法元素,而在其中一切片或圖片包括多數磚的情況下,假如一語法元素指示其一圖片標頭被傳訊在該切片標頭中的話則省略指示一切片之一位址的一語法元素之該編碼;及使用該等語法元素來編碼該視頻資料。依據本發明之一額外附加態樣,有提供一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當編碼一切片時將使用的語法元素,該位元流被約束以使得在其中該位元流包括具有指示其一切片或圖片包括多數磚之一值的一語法元素且該位元流包括指示其一圖片標頭被傳訊在該切片標頭中之一語法元素的情況下,該位元流亦包括指示其指示一切片之一位址的一語法元素不被剖析的一語法元素;該方法包含使用該等語法元素來編碼該視頻資料。 在一或多個實施例中,(僅)當一光柵掃描切片模式被用於編碼該切片時,該省略將被履行。 該省略可進一步包含省略指示該切片中之磚數目的一語法元素之編碼。 依據本發明之一第八態樣,有提供一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,且該編碼包含:判定用於編碼該視頻資料之一或多個語法元素,而在其中一切片包括多數磚的情況下,假如經判定用於編碼的一語法元素指示其該圖片標頭被傳訊在該切片標頭中的話則省略指示該切片中之磚數目的一語法元素之該編碼;及使用該等語法元素來編碼該視頻資料。依據本發明之一進一步額外態樣,有提供一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,且該編碼包含:判定用於編碼該視頻資料之一或多個語法元素,而在其中一切片或圖片包括多數磚的情況下,假如經判定用於編碼的一語法元素指示其該圖片標頭被傳訊在該切片標頭中的話則省略指示該切片中之磚數目的一語法元素之該編碼;及使用該等語法元素來編碼該視頻資料。依據本發明之一進一步附加態樣,有提供一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,該位元流被約束以使得在其中該位元流包括具有指示其一切片或圖片包括多數磚之一值的一語法元素且該位元流包括指示其該圖片標頭被傳訊在該切片標頭中之經判定用於編碼的一語法元素之情況下,該位元流亦包括指示其指示該切片中之磚數目的一語法元素不被剖析的一語法元素;該方法包含使用該等語法元素來編碼該視頻資料。 在一實施例中,(僅)當一光柵掃描切片模式將被用於編碼該切片時,該省略將被履行。 該編碼可進一步包含編碼指示該圖片中之磚數目的語法元素,其中該切片中之磚數目係基於由該等經剖析語法元素所指示的該圖片中之該磚數目。 該省略可進一步包含省略指示一切片之一位址的一語法元素之該編碼。 依據本發明之一第九態樣中,有提供一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,且該編碼包含:判定一或多個語法元素,而在其中一切片(或圖片)包括多數磚的情況下,假如該切片中之磚數目等於該圖片中之磚數目的話則省略指示一切片位址之一語法元素的該編碼;及使用該等語法元素來編碼該視頻資料。 在一或多個實施例中,(僅)當一光柵掃描切片模式將被用於編碼該切片時,該省略將被履行。 該編碼可進一步包含在一切片中編碼指示該切片中之該磚數目的一語法元素;及在一圖片參數集中編碼指示該圖片中之該磚數目的語法元素,其中是否省略指示該切片位址之該語法元素的該編碼係基於該等經編碼語法元素之值。 該編碼可進一步包含在該切片中編碼指示該切片中之該磚數目的該語法元素,在用於傳訊一切片位址之一或多個語法元素前。 該編碼可進一步包含在一切片中編碼指示一圖片標頭是否被傳訊在一切片標頭中之一語法元素,以及假如將被編碼之該語法元素指示其該圖片標頭被傳訊在該切片標頭中的話判定其該切片中之該磚數目等於該圖片中之該磚數目。 依據本發明之一第十態樣,有提供一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚,其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,且該編碼包含:判定用於編碼該視頻資料之一或多個語法元素,而在其中經判定用於編碼的一語法元素指示其一光柵掃描解碼模式被致能於一切片之情況下,編碼指示該切片中之一切片位址及磚數目的至少一者之語法元素,其中在該光柵掃描解碼模式被致能於該切片之該情況下從該等一或多個語法元素的該切片中之該切片位址及該磚數目的該至少一者之該編碼並非取決於該圖片中之該磚數目;及使用該等語法元素來編碼該位元流。 在依據本發明之第十一態樣中,提供一種包含第七態樣及第八態樣的方法。 在依據本發明之第十二態樣中,提供一種包含第七態樣及第八態樣及第九態樣的方法。 依據本發明之一第十三態樣,有提供一種用於解碼來自一位元流之視頻資料的解碼器,該解碼器被組態成履行第一至第六態樣之任一者的方法。 依據本發明之一第十四態樣,有提供一種用於編碼視頻資料入一位元流中之編碼器,該編碼器被組態成履行第七至第十二態樣之任一者的方法。 依據本發明之一第十五態樣,有提供一種電腦程式,其在執行時致使第一態樣至第十二態樣之任一者的方法被履行。該程式可由本身所提供或者可由載體媒體所攜載或被攜載於載體媒體中。載體媒體可為非暫態,例如,儲存媒體,特別是電腦可讀取儲存媒體。載體媒體亦可為暫態,例如,信號或其他傳輸媒體。信號可經由任何適當網路來傳輸,包括網際網路。本發明之進一步特徵係由獨立項及附屬項請求項所特徵化。 本發明之一態樣中的任何特徵可被應用至本發明之其他態樣,於任何適當的組合中。特別地,方法態樣可被應用至設備態樣,而反之亦然。 再者,硬體中所實施的特徵可被實施於軟體中,而反之亦然。對於文中之軟體及硬體特徵的任何參考應因此被建構。 如文中所述之任何設備特徵亦可被提供為方法特徵,而反之亦然。如文中所使用,手段功能特徵可被替代地表達以其相應結構,諸如適當地編程的處理器及相關記憶體。 亦應理解:在本發明之任何態樣中所描述及定義的各種特徵之特定組合可被獨立地實施及/或供應及/或使用。The present invention relates to the enhancement of high-level grammatical structures, which leads to a reduction in complexity without any degradation in coding performance. In a first aspect according to the present invention, there is provided a method for decoding video data from a bitstream, the bitstream including video data corresponding to one or more slices, wherein each slice may include one or Multiple tiles, where the bitstream contains a picture header and a slice header, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a slice header that will be used when decoding slices. The syntax element used, the method includes parsing the syntax elements, and in the case where all the slices (or pictures) include many bricks, if one of the parsed syntax elements indicates that one of the picture headers is transmitted in the slice header If in, the analysis of a syntax element indicating the address of all slices is omitted; and the syntax elements are used to decode the bit stream. In another aspect according to the present invention, there is provided a method for decoding video data from a bitstream, the bitstream including video data corresponding to one or more slices, wherein each slice may include one or more A brick, where the bitstream contains a picture header and slice headers, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a picture header that will be used when decoding slices. The method includes parsing the syntax elements, and in the case where all the slices or pictures include many bricks, if one of the parsed syntax elements indicates that one of the picture headers is transmitted in the slice header, then The parsing of a syntax element indicating an address of all slices is omitted; and the syntax elements are used to decode the bit stream. In another additional aspect according to the present invention, there is provided a method of decoding video data from a bitstream, the bitstream including video data corresponding to one or more slices, wherein each slice may include one or Multiple tiles, where the bitstream contains a picture header and a slice header, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a slice header that will be used when decoding slices. The syntax element used in which the bitstream is constrained so that the bitstream includes a syntax element with a value indicating that its slices or pictures include one of the majority of tiles, and the bitstream includes a header indicating that a picture is In the case of transmitting a syntax element in the slice header, the bit stream also includes a syntax element indicating that a syntax element indicating an address of all slices is not to be parsed, and the method includes using the syntax element To decode the bit stream. Therefore, when the picture header is in the slice header with reduced bit rate (especially for low latency and low bit rate applications), the slice address is not parsed. Furthermore, when the picture is sent in the slice header, the analysis complexity can be reduced. In one embodiment, this omission will be fulfilled (only) when a raster scan slice mode will be used to decode the slice. This reduces the analysis complexity but still allows some bit rate reduction. The omission may further include omitting the parsing of a syntax element indicating the number of tiles in the slice. Therefore, a further reduction in bit rate can be obtained. In a second aspect, there is provided a method of decoding video data from a bitstream, the bitstream containing video data corresponding to one or more slices, where each slice may include one or more tiles, The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when decoding slices. , And the decoding includes: parsing one or more syntax elements, and in the case where all slices (or pictures) include many tiles, if one of the parsed syntax elements indicates that the picture header is transmitted in the slice header If in, the analysis of a syntax element indicating the number of tiles in the slice is omitted; and the syntax elements are used to decode the bit stream. In a further aspect, there is provided a method of decoding video data from a bitstream, the bitstream including video data corresponding to one or more slices, wherein each slice may include one or more tiles, wherein The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when decoding slices. And the decoding includes: parsing one or more syntax elements, and in the case where all slices or pictures include many bricks, if a syntax element being analyzed indicates that the picture header is signaled in the slice header, then The parsing of a syntax element indicating the number of tiles in the slice is omitted; and the syntax elements are used to decode the bit stream. In another further aspect according to the present invention, there is provided a method for decoding video data from a bitstream, the bitstream including video data corresponding to one or more slices, wherein each slice may include one or Multiple tiles, where the bitstream contains a picture header and a slice header, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a slice header that will be used when decoding slices. The syntax element used, the bitstream is constrained so that the bitstream includes a syntax element with a value indicating that its slices or pictures include one of the bricks, and the bitstream includes a header indicating that the picture is In the case of transmitting a syntax element in the slice header, the bit stream also includes a syntax element indicating that a syntax element indicating the number of tiles in the slice is not to be parsed, and the method includes using the syntax element To decode the bit stream. Therefore, the bit rate can be reduced, which is advantageous, especially for low latency and low bit rate applications where the number of tiles does not need to be transmitted. (Only) This omission can be fulfilled when a raster scan slice mode is to be used to decode the slice. This reduces the analysis complexity but still allows some bit rate reduction. The method may further include parsing a syntax element indicating the number of tiles in the picture and determining the number of tiles in the slice based on the number of tiles in the picture indicated by the parsed syntax elements. This is advantageous because it allows the number of tiles in the slice to be easily predicted, in the case where one of the picture headers is signaled in the slice header without further communication. The omission may further include omitting the parsing of a syntax element indicating the address of a slice. Therefore, the bit rate can be further reduced. In a third aspect of the present invention, there is provided a method of decoding video data from a bitstream, the bitstream including video data corresponding to one or more slices, wherein each slice may include one or more A brick, where the bitstream contains a picture header and slice headers, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a picture header that will be used when decoding slices. And the decoding includes: parsing one or more syntax elements, and in the case where all slices (or pictures) include many tiles, if the number of tiles in the slice is equal to the number of tiles in the picture, then omit Indicate the analysis of a syntax element of all slice addresses; and use these syntax elements to decode the bit stream. This system uses the following insight: if the number of tiles in a slice is equal to the number of tiles in the picture, it is confirmed that the current picture contains only one slice. Therefore, by omitting the slice address, the bit rate can be increased and the complexity of parsing and/or coding can be reduced. (Only) This omission can be fulfilled when a raster scan slice mode is to be used to decode the slice. Therefore, complexity can be reduced while still providing some bit rate reduction. The decoding may further include parsing a syntax element indicating the number of tiles in the slice in a slice; and parsing a syntax element indicating the number of tiles in the picture in a picture parameter set, where the address of the slice is indicated The omission of the analysis of the grammatical elements is based on the parsed grammatical elements. The decoding may further include parsing in the slice the syntax element indicating the number of tiles in the slice, before being used to transmit one or more syntax elements of all slice addresses. The decoding may further include parsing a syntax element in a slice indicating whether a picture header is signaled in a slice header, and if the parsed syntax element indicates that the picture header is signaled in the slice header If it is determined (inference), the number of tiles in the slice is equal to the number of tiles in the picture. In a fourth aspect, there is provided a method of decoding video data from a bitstream, the bitstream including video data corresponding to one or more slices, where each slice may include one or more tiles, The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when decoding slices. , And the decoding includes: parsing one or more syntax elements, and when one of the syntax elements indicates that a raster scan decoding mode is enabled for all slices, decoding the slice from the one or more syntax elements At least one of a slice address and the number of tiles, where the slice address and the slice address in the slice of the one or more syntax elements in the case where the raster scan decoding mode is enabled for the slice The decoding of the at least one of the number of tiles does not depend on the number of tiles in the picture; and the syntax elements are used to decode the bitstream. Therefore, the parsing complexity of the slice header can be reduced. In a fifth aspect according to the present invention, a method including the first aspect and the second aspect is provided. In a sixth aspect according to the present invention, a method including the first aspect, the second aspect, and the third aspect is provided. According to a seventh aspect of the present invention, there is provided a method for encoding video data into a bit stream, the bit stream including the video data corresponding to one or more slices, wherein each slice may include a Or multiple tiles, where the bitstream includes a picture header and slice headers, the picture header includes syntax elements that will be used when decoding one or more slices, and the slice header includes when encoding slices The syntax element to be used, and the encoding includes: determining one or more syntax elements for encoding the video material, and in the case where all the pieces (or pictures) include a plurality of tiles, if a syntax element indicates one of the pictures If the header is signaled in the slice header, the encoding of a syntax element indicating an address of all slices is omitted; and the syntax elements are used to encode the video data. According to another aspect of the present invention, there is provided a method of encoding video data into a bitstream, the bitstream including the video data corresponding to one or more slices, wherein each slice may include one or more A brick, where the bitstream contains a picture header and slice headers, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a slice header that will be used when encoding slices. And the encoding includes: determining one or more syntax elements for encoding the video data, and in the case where all the pieces or pictures include a plurality of tiles, if a syntax element indicates that one of the picture headers is transmitted In the slice header, the encoding of a syntax element indicating an address of all slices is omitted; and the syntax elements are used to encode the video data. According to an additional aspect of the present invention, there is provided a method of encoding video data into a bitstream, the bitstream including video data corresponding to one or more slices, wherein each slice may include one or more A brick, where the bitstream contains a picture header and slice headers, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a slice header that will be used when encoding slices. The bitstream is constrained so that the bitstream includes a syntax element with a value indicating that its slices or pictures include one of the majority of tiles, and the bitstream includes a header indicating that a picture is signaled In the case of a syntax element in the slice header, the bit stream also includes a syntax element indicating that a syntax element indicating an address of all slices is not to be parsed; the method includes using the syntax elements to Encode the video material. In one or more embodiments, this omission will be fulfilled (only) when a raster scan slice mode is used to encode the slice. The omission may further include omitting the coding of a syntax element indicating the number of tiles in the slice. According to an eighth aspect of the present invention, there is provided a method for encoding video data into a bit stream, the bit stream containing video data corresponding to one or more slices, wherein each slice may include one or more A brick, where the bitstream contains a picture header and slice headers, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a picture header that will be used when decoding slices. And the encoding includes: one or more syntax elements determined to be used for encoding the video material, and in the case where all slices include most tiles, if a syntax element determined to be used for encoding indicates the picture If the header is signaled in the slice header, the encoding of a syntax element indicating the number of tiles in the slice is omitted; and the syntax elements are used to encode the video data. According to a further aspect of the present invention, there is provided a method of encoding video data into a bit stream, the bit stream including video data corresponding to one or more slices, wherein each slice may include one or more A brick, where the bitstream contains a picture header and slice headers, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a picture header that will be used when decoding slices. And the encoding includes: one or more syntax elements determined to be used for encoding the video data, and in the case where all slices or pictures include a plurality of tiles, if a syntax element determined to be used for encoding indicates it If the picture header is signaled in the slice header, the encoding of a syntax element indicating the number of tiles in the slice is omitted; and the syntax elements are used to encode the video data. According to a further aspect of the present invention, there is provided a method of encoding video data into a bitstream, the bitstream including video data corresponding to one or more slices, wherein each slice may include one or more A brick, where the bitstream contains a picture header and slice headers, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a picture header that will be used when decoding slices. The bitstream is constrained such that the bitstream includes a syntax element with a value indicating that its slices or pictures include one of the majority of tiles, and the bitstream includes a header indicating that the picture header is signaled In the case of a syntax element determined to be used for encoding in the slice header, the bit stream also includes a syntax element indicating that a syntax element indicating the number of tiles in the slice is not to be parsed; the method includes Use the syntax elements to encode the video data. In one embodiment, this omission will be fulfilled (only) when a raster scan slice mode is to be used to encode the slice. The encoding may further include encoding a syntax element indicating the number of tiles in the picture, wherein the number of tiles in the slice is based on the number of tiles in the picture indicated by the parsed syntax elements. The omission may further include omitting the encoding of a syntax element indicating an address of a slice. According to a ninth aspect of the present invention, there is provided a method for encoding video data into a bit stream, the bit stream containing video data corresponding to one or more slices, wherein each slice may include one or Multiple tiles, where the bitstream contains a picture header and a slice header, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a slice header that will be used when decoding slices. The syntax element used, and the code includes: determining one or more syntax elements, and in the case where all slices (or pictures) include many tiles, if the number of tiles in the slice is equal to the number of tiles in the picture, then Omit the encoding indicating one of the syntax elements of all slice addresses; and use the syntax elements to encode the video data. In one or more embodiments, this omission will be fulfilled (only) when a raster scan slice mode is to be used to encode the slice. The encoding may further include encoding a syntax element indicating the number of tiles in the slice in a slice; and encoding a syntax element indicating the number of tiles in the picture in a picture parameter set, wherein whether to omit indicating the slice address The encoding of the syntax element is based on the values of the encoded syntax elements. The encoding may further include encoding the syntax element indicating the number of tiles in the slice in the slice, before one or more syntax elements are used to signal all slice addresses. The encoding may further include encoding a syntax element in a slice indicating whether a picture header is signaled in a slice header, and if the syntax element to be encoded indicates that the picture header is signaled in the slice header The words in the header determine that the number of tiles in the slice is equal to the number of tiles in the picture. According to a tenth aspect of the present invention, there is provided a method of encoding video data into a bitstream, the bitstream including video data corresponding to one or more slices, wherein each slice may include one or more A brick, where the bitstream contains a picture header and a slice header, the picture header contains syntax elements that will be used when decoding one or more slices, and the slice header contains a picture header that will be used when decoding slices And the encoding includes: one or more syntax elements determined to be used for encoding the video data, and a syntax element determined to be used for encoding indicates that a raster scan decoding mode is enabled for all slices In this case, the encoding indicates the syntax element of at least one of a slice address and the number of tiles in the slice, wherein the one or more syntax elements are derived from the one or more syntax elements in the case that the raster scan decoding mode is enabled The encoding of the at least one of the slice address and the number of tiles in the slice of does not depend on the number of tiles in the picture; and the syntax elements are used to encode the bitstream. In an eleventh aspect according to the present invention, a method including the seventh aspect and the eighth aspect is provided. In the twelfth aspect according to the present invention, a method including the seventh aspect, the eighth aspect, and the ninth aspect is provided. According to a thirteenth aspect of the present invention, there is provided a decoder for decoding video data from a bit stream, the decoder being configured to perform any one of the first to sixth aspects . According to a fourteenth aspect of the present invention, there is provided an encoder for encoding video data into a bit stream, and the encoder is configured to perform any one of the seventh to twelfth aspects method. According to a fifteenth aspect of the present invention, there is provided a computer program which, when executed, causes the method of any one of the first aspect to the twelfth aspect to be performed. The program can be provided by itself or can be carried by or in a carrier medium. The carrier medium may be non-transitory, for example, a storage medium, especially a computer-readable storage medium. The carrier medium can also be transient, such as a signal or other transmission medium. The signal can be transmitted via any suitable network, including the Internet. The further features of the present invention are characterized by independent items and dependent items. Any feature in one aspect of the present invention can be applied to other aspects of the present invention in any appropriate combination. In particular, the method aspect can be applied to the device aspect and vice versa. Furthermore, features implemented in hardware can be implemented in software, and vice versa. Any references to software and hardware features in the text should be constructed accordingly. Any device feature described in the text can also be provided as a method feature, and vice versa. As used in the text, the functional features of the means can be alternatively expressed in their corresponding structures, such as a suitably programmed processor and related memory. It should also be understood that the specific combination of the various features described and defined in any aspect of the present invention can be implemented and/or supplied and/or used independently.

圖1係相關於高效率視頻編碼(High Efficiency Video Coding (HEVC))視頻標準中所使用的編碼結構。視頻序列1係由一連串數位影像i所組成。各此等數位影像係由一或更多矩陣所表示。矩陣係數代表像素。 該序列之影像2可被分割為切片3。切片可於某些例子中構成完整影像。這些切片被分割為無重疊編碼樹單元(CTU)。編碼樹單元(CTU)是高效率視頻編碼(HEVC)視頻標準之基本處理單元且觀念上其結構係相應於數種先前視頻標準中所使用的巨集區塊單元。CTU亦有時被稱為最大編碼單元(LCU)。CTU具有亮度及色度成分部分,其成分部分之各者被稱為編碼樹區塊(CTB)。這些不同顏色成分未顯示於圖1中。 CTU通常係大小64x64像素。各CTU可接著使用四元樹分解而被疊代地分割為較小的可變大小編碼單元(CU)5。 編碼單元為基本編碼元件且係由稱為預測單元(PU)及變換單元(TU)之兩種子單元所構成。PU或TU之最大大小係等於CU大小。預測單元係相應於針對像素值之預測的CU之分割。CU之各種不同分割為PU是可能的(如由606所示),包括分割為4個方形PU及兩不同的分割為2個矩形PU。變換單元為基本單元,其係接受使用DCT之空間變換。CU可根據四元樹表示607而被分割為TU。 各切片被嵌入一個網路抽象化層(NAL)單元中。此外,視頻序列之編碼參數被儲存在專屬NAL單元(稱為參數集)中。在HEVC及H.264/AVC中,兩種參數集NAL單元被利用:第一,序列參數集(SPS)NAL單元,其係收集在整個視頻序列期間未改變的所有參數。通常,其係處置編碼輪廓、視頻框之大小及其他參數。第二,圖片參數集(PPS)NAL單元包括其可從一個影像(或框)改變至序列中之另一個的參數。HEVC亦包括視頻參數集(VPS)NAL單元,其含有描述位元流之整體結構的參數。VPS是一種以HEVC定義的新類型參數集,且應用於位元流之所有層。一層可含有多數時間子層,且所有版本1的位元流被限制於單一層。HEVC具有用於可擴縮性及多重視角之分層延伸,且這些將致能多數層,具有向後相容的版本1基礎層。 在多樣視頻編碼(VVC)之目前定義中,針對圖片之分割有三種高階可能性:子圖片、切片及磚。各具有其本身的特性及可用性。分割成子圖片係用於一視頻之區的空間提取及/或合併。分割成切片係基於如先前標準之類似概念並相應於視頻傳輸之封包化,即使其可被用於其他應用。分割成磚係概念上一編碼器平行化工具,因為其將圖片分裂成圖片之(幾乎)相同大小的獨立編碼區。但此工具亦可被用於其他應用。 因為圖片之分割的這三個高階可用可能方式可被一起使用,所以針對其使用有數個模式。如在VVC之目前草案規格中所界定,切片的兩個模式被界定。針對光柵掃描切片模式,切片含有依圖片之磚光柵掃描的完整磚之序列。目前VVC規格中之此模式被繪示在圖10(a)中。如在此圖中所示,顯示該圖片含有18x12的亮度CTU,其被分割成12個磚及3個光柵掃描切片。 針對第二者(矩形切片模式),一切片含有數個完整磚,其集體地來自圖片之一矩形區。目前VVC規格中之此模式被繪示在圖10(b)中。在此範例中,顯示具有18x12亮度CTU的圖片,其被分割成24個磚及9個矩形切片。 圖2繪示一資料通訊系統,其中本發明之一或更多實施例可被實施。資料通訊系統包含傳輸裝置(於此情況下為伺服器201),其可操作以經由資料通訊網路200而傳輸資料流之資料封包至接收裝置(於此情況下為客戶終端202)。資料通訊網路200可為廣域網路(WAN)或區域網路(LAN)。此一網路可為(例如)無線網路(Wifi/802.11a或b或g)、乙太網路、網際網路或由數個不同網路所組成的混合網路。於本發明之特定實施例中,資料通訊系統可為數位電視廣播系統,其中伺服器201傳送相同的資料內容至多數客戶。 由伺服器201所提供的資料流204可由其表示視頻及音頻資料之多媒體資料所組成。音頻及視頻資料流可(於本發明之一些實施例中)由伺服器201個別地使用麥克風及相機來擷取。於一些實施例中,資料流可被儲存在伺服器201上或者由伺服器201從另一資料提供器所接收、或者被產生在伺服器201上。伺服器201被提供有一用以編碼視頻及音頻流之編碼器,特別是用以提供用於傳輸之壓縮位元流,其為被呈現為針對編碼器之輸入的資料之更緊密的表示。 為了獲得已傳輸資料之品質相對於已傳輸資料之量的較佳比例,視頻資料之壓縮可(例如)依據HEVC格式或H.264/AVC格式。 客戶202接收已傳輸位元流並解碼已重建位元流以將視頻影像再生於顯示裝置上並由揚聲器再生音頻資料。 雖然串流情境被考量於圖2之範例中,但應理解:於本發明之一些實施例中,介於編碼器與解碼器之間的資料通訊可使用媒體儲存裝置(諸如光碟)來履行。 於本發明之一或更多實施例中,視頻影像被傳輸以其代表補償偏移之資料以利供應至影像之已重建像素來提供已過濾像素於最終影像中。 圖3概略地繪示處理裝置300,其係組態成實施本發明之至少一實施例。處理裝置300可為一種裝置,諸如微電腦、工作站或輕型可攜式裝置。裝置300包含一連接至以下的通訊匯流排313: - 中央處理單元311,諸如微處理器,標示為CPU; - 唯讀記憶體306,標示為ROM,用以儲存供實施本發明之電腦程式; - 隨機存取記憶體312,標示為RAM,用以儲存本發明之實施例的方法之可執行碼、以及暫存器,調適成記錄用以實施編碼數位影像的序列之方法及/或解碼位元流之方法所需的變數和參數,依據本發明之實施例;及 - 通訊介面302,連接至通訊網路303,待處理數位資料係透過該通訊網路來傳輸或接收。 選擇性地,設備300亦可包括以下組件: - 資料儲存機構304(諸如硬碟),用以儲存電腦程式及資料,該等電腦程式係用以實施本發明之一或更多實施例的方法,該資料係在本發明之一或更多實施例的實施期間所使用或產生的; - 磁碟306之磁碟驅動305,該磁碟驅動被調適成從磁碟306讀取資料或將資料寫至該磁碟上; - 螢幕309,用以顯示資料及/或作用為與使用者之圖形介面,藉由鍵盤310或任何其他指針機構。 設備300可被連接至各種周邊,諸如(例如)數位相機320或麥克風308,各被連接至輸入/輸出卡(未顯示)以供應多媒體資料至設備300。 通訊匯流排提供介於設備300中所包括的或連接至該設備300的各個元件之間的通訊及可交互操作性。匯流排之表示是非限制性的;且特別地,中央處理單元可操作以將指令傳遞至設備300之任何元件,直接地或者藉由設備300之另一元件。 磁碟306可被取代以任何資訊媒體,諸如(例如)光碟(CD-ROM)(可寫入或不可寫入)、ZIP碟或記憶卡;及(以一般性術語)藉由資訊儲存機構,其可由微電腦或由微處理器所讀取、被集成(或不集成)入該設備、可能為可移除的且調適成儲存一或更多程式,該等程式的執行係致能編碼數位影像之序列的方法及/或解碼位元流的方法,依據待實施之本發明。 可執行碼可被儲存於唯讀記憶體306中、於硬碟304上或者於可移除數位媒體(諸如,例如磁碟306,如先前所述)上。依據變體,程式之可執行碼可藉由通訊網路303來接收,經由介面302,以被儲存於設備300(在被執行前)的儲存機構(諸如硬碟304)之一中。 中央處理單元311係調適成依據本發明以控制並指導程式或多數程式之指令或軟體碼部分的執行,該些指令係儲存於前述儲存機構之一中。在開機時,其被儲存於非揮發性記憶體(例如在硬碟304上或者在唯讀記憶體306中)中之程式或多數程式被轉移入隨機存取記憶體312,其接著含有程式或多數程式之可執行碼、以及用以儲存供實施本發明所需之變數和參數的暫存器。 於此實施例中,該設備為可編程設備,其係使用軟體以實施本發明。然而,替代地,本發明可被實施以硬體(例如,以特定應用積體電路或ASIC之形式)。 圖4繪示一種依據本發明之至少一實施例的編碼器之方塊圖。編碼器係由已連接模組所表示,各模組係調適成實施(例如以將由裝置300之CPU 311所執行的編程指令之形式)一種方法之至少一相應步驟,該方法係依據本發明之一或更多實施例以實施編碼影像序列之影像的至少一實施例。 數位影像i 0至i n 401之原始序列係由編碼器400接收為輸入。各數位影像係由一組樣本(已知為像素)所表示。 位元流410係由編碼器400所輸出,在編碼程序之實施後。位元流410包含複數編碼單元或切片,各切片包含切片標頭及切片本體,該切片標頭係用以傳輸其用來編碼該切片之編碼參數的編碼值,而該切片本體包含已編碼視頻資料。 輸入數位影像i 0至i n 401係由模組402分割為像素之區塊。該等區塊係相應於影像部分且可有可變大小(例如,4x4、8x8、16x16、32x32、64x64、128x128像素且數個矩形區塊大小亦可被考量)。編碼模式係針對各輸入區塊來選擇。編碼模式之兩個家族被提供:根據空間預測編碼之編碼模式(內預測)、及根據時間預測之編碼模式(間編碼、合併、SKIP)。可能的編碼模式被測試。 模組403係實施內預測程序,其中待編碼的既定區塊係藉由預測子來預測,該預測子係從待編碼的該區塊附近之像素所計算。選定的內預測子以及介於既定區塊與其預測子之間的差異之指示被編碼以提供殘餘,假如內編碼被選擇的話。 時間預測係由移動估計模組404及移動補償模組405來實施。首先,來自一組參考影像416中的參考影像被選擇,且該參考影像之一部分(亦稱為參考區域或影像部分,其為針對待編碼的既定區塊之最接近區域)係由移動估計模組404所選擇。移動補償模組405接著使用該選定區域以預測待編碼的區塊。介於選定參考區域與既定區塊(亦稱為殘餘區塊)之間的差異係由移動補償模組405所計算。選定參考區域係由移動向量所指示。 因此,於兩情況(空間及時間預測)下,殘餘係藉由從原始區塊減去該預測來計算。 於藉由模組403所實施的INTRA預測中,預測方向被編碼。於時間預測中,至少一移動向量被編碼。在由模組404、405、416、418、417所實施的間預測中,用以識別此移動向量之至少一移動向量或資料係針對時間預測來編碼。 相對於移動向量及殘餘區塊之資訊被編碼,假如間預測被選擇的話。為了進一步減少位元率,假設其移動為同質的,則移動向量係藉由相關於移動向量預測子之差異而被編碼。一組移動資訊預測子之移動向量預測子係由移動向量預測及編碼模組417從移動向量場418獲得。 編碼器400進一步包含選擇模組406,用於藉由應用編碼成本準則(諸如率-失真準則)來選擇編碼模式。為了進一步減少冗餘,由變換模組407對殘餘區塊應用變換(諸如DCT),所獲得的變換接著係藉由量化模組408而被量化且藉由熵編碼模組409而被熵編碼。最後,目前正被編碼之區塊的已編碼殘餘區塊被插入位元流410中。 編碼器400亦履行已編碼影像之解碼以產生用於後續影像之移動估計的參考影像。此致能編碼器及解碼器接收位元流以具有相同的參考框。反量化模組411履行已量化資料之反量化,接續以藉由反變換模組412之反變換。反內預測模組413使用預測資訊以判定應使用哪個預測子於給定區塊,而反移動補償模組414實際地將其由模組412所獲得的殘餘加至從該組參考影像416所獲得的參考區域。 接著由模組415應用後過濾以過濾像素之已重建框。於本發明之實施例中,SAO迴路過濾器被使用,其中補償偏移被加至已重建影像之已重建像素的像素值。 圖5繪示其可被用以從編碼器接收資料的解碼器60之方塊圖,依據本發明之實施例。解碼器係由已連接模組所表示,各模組係調適成實施(例如以將由裝置300之CPU 311所執行的編程指令之形式)一種由解碼器60所實施之方法的相應步驟。 解碼器60接收一包含編碼單元之位元流61,各編碼單元係由標頭及本體所組成,該標頭含有關於編碼參數之資訊而該本體含有已編碼視頻資料。VVC中之位元流的結構係參考圖6而被更詳細地描述於下。如相關於圖4所解釋,已編碼視頻資料被熵編碼,而移動向量預測子的指標被編碼(針對既定區塊)於預定數目的位元上。所接收的已編碼視頻資料係由模組62所熵解碼。殘餘資料接著由模組63所去量化,且接著由模組64應用反變換以獲得像素值。 指示編碼模式之模式資料亦被熵解碼;且根據該模式,INTRA類型解碼或INTER類型解碼被履行在影像資料之已編碼區塊上。 在INTRA模式之情況下,INTRA預測子係由內反預測模組65根據位元流中所指明的內預測模式來判定。 假如該模式為INTER,則移動預測資訊被提取自該位元流以找出由編碼器所使用的參考區域。移動預測資訊係由參考框指標及移動向量殘餘所組成。移動向量預測子被加至移動向量殘餘以由移動向量解碼模組70獲得移動向量。 移動向量解碼模組70將移動向量解碼應用於其由移動預測所編碼的各目前區塊。一旦移動向量預測子之指標(針對目前區塊)已被獲得,則與目前區塊相關聯的移動向量之實際值可被解碼並用以由模組66應用反移動補償。由已解碼移動向量所指示之參考影像部分被提取自參考影像68以應用反移動補償66。移動向量場資料71被更新以已解碼移動向量來用於後續已解碼移動向量之反預測。 最後,獲得已解碼區塊。由後過濾模組67應用後過濾。已解碼視頻信號69最後由解碼器60所提供。 圖6繪示範例編碼系統VVC中之位元流的組織,如在JVET-Q2001-vD中所述。 依據VVC編碼系統之位元流61係由語法元素及經編碼資料之依序序列所組成。語法元素及經編碼資料被放置入網路抽象化層(NAL)單元601-608中。有不同的NAL單元類型。網路抽象化層提供用以將位元流囊封入不同協定的能力,如RTP/IP,其代表即時協定/網際網路協定、ISO基礎媒體檔案格式等等。網路抽象化層亦提供用於封包損失恢復力的框架。 NAL單元被劃分成視頻編碼層(VCL) NAL單元及非VCL NAL單元。VCL NAL單元含有實際經編碼視頻資料。非VCL NAL單元含有額外資訊。此額外資訊可為用於經編碼視頻資料之解碼所需的參數或者為可提升經解碼視頻資料之可用性的補充資料。NAL單元606相應於切片並構成位元流之VCL NAL單元。 不同NAL單元601-605相應於不同參數集,這些NAL單元係非VCL NAL單元。解碼器參數集(DPS) NAL單元301含有其針對既定解碼程序係恆定的參數。視頻參數集(VPS) NAL單元602含有針對完整視頻(及因此完整位元流)所界定的參數。DPS NAL單元可界定比VPS中之參數更靜態的參數。換言之,DPS之參數比VPS之參數更不頻繁地改變。 序列參數集(SPS) NAL單元603含有針對一視頻序列所界定的參數。特別地,SPS NAL單元可界定子圖片佈局及視頻序列之相關參數。與各子圖片相關聯的參數指明其施加至子圖片之編碼約束。特別地,其包含一旗標,該旗標指示其介於子圖片之間的時間預測被限制於來自相同子圖片之資料。另一旗標可致能或除能迴路過濾器橫跨子圖片邊界。 圖片參數集(PPS) NAL單元604含有針對一圖片或一圖片群組所界定的參數。調適參數集(APS) NAL單元605含有用於迴路過濾器之參數,通常係調適性迴路過濾器(ALF)或整形器模型(或具有色度擴縮(LMCS)模型之亮度映射)或在切片階所使用的擴縮矩陣。 PPS之語法(如在VVC之目前版本中所提議)包含語法元素,其指明亮度樣本中之圖片的大小且亦指明磚及切片中之各圖片的分割。 PPS含有語法元素,其使得能夠判定一框中之切片位置。因為子圖片形成框中之矩形區,所以能夠判定該組切片、磚之部分或磚,其屬於來自參數集NAL單元之子圖片。PPS以及APS具有ID機制,以限制所傳輸之相同PPS的量。 PPS與圖片標頭之間的主要差異係其傳輸,PPS通常被傳輸給圖片群組,相較於PH被系統地傳輸給各圖片。因此,PPS(相較於PH)含有其可針對數個圖片係恆定的參數。 位元流亦可含有補充增強資訊(SEI)NAL單元(未表示在圖6中)。在位元流中之這些參數集的發生週期係可變的。針對整個位元流所界定的VPS可在位元流中僅發生一次。反之,針對切片所界定的APS可針對各圖片中之各切片發生一次。實際上,不同切片可仰賴相同APS,而因此通常有比各圖片中之切片更少的APS。特別地,APS被界定在圖片標頭中。然而,ALP APS仍可被界定在切片標頭中。 存取單元定界符(AUD)NAL單元607分離兩個存取單元。存取單元係一組NAL單元,其可包含具有相同解碼時戳之一或多個經編碼圖片。此選擇性NAL單元僅含有一個語法元素在目前VVC規格中:pic_type,此語法元素。指示其在AU中之經編碼圖片的所有切片之slice_type值。假如pic_type被設為等於0,則AU僅含有內切片。假如等於1,則其含有P及I切片。假如等於2,則其含有B、P或內切片。 此NAL單元僅含有一個語法元素,pic-type。

Figure 02_image001
在JVET-Q2001-vD中,pic_type 被界定如下: 「pic_type 指示其在含有AU定界符NAL單元的AU中之經編碼圖片的所有切片之slice_type 值為pic_type 之既定值的表2中所列出之集合的成員。pic_type 之值應等於0、1或2,在符合此規格之此版本的位元流中。pic_type 之其他值被保留以供由ITU‑T | ISO/IEC之未來使用。符合此規格之此版本的解碼器應忽略pic_type 之保留值」。 rbsp_trailing_bits( )係一函數,其係添加位元以對準至一位元組之末端。因此在此函數之後,所剖析的位元流量係整數個位元組。
Figure 02_image003
PH NAL單元608係一圖片標頭NAL單元,其係群集一個經編碼圖片之一組切片所共有的參數。圖片可參考一或多個APS以指示AFL參數、整形器模型及擴縮矩陣(由圖片之切片所使用)。 VCL NAL單元606之各者含有切片。切片可相應於整個圖片或子圖片、單一磚或複數磚或磚之片段。例如,圖3之切片含有數個磚620。切片係由切片標頭610及原始位元組序列酬載RBSP 611(其含有經編碼成編碼區塊640之經編碼像素資料)所組成。 PPS之語法(如在VVC之目前版本中所提議)包含語法元素,其指明亮度樣本中之圖片的大小且亦指明磚及切片中之各圖片的分割。 PPS含有語法元素,其使得能夠判定一框中之切片位置。因為子圖片形成框中之矩形區,所以能夠判定該組切片、磚之部分或磚,其屬於來自參數集NAL單元之子圖片。 NAL單元切片 NAL單元切片層含有切片標頭及切片資料,如在表3中所示。
Figure 02_image005
APS 調適參數集(APS)NAL單元605被界定在顯示語法元素之表4中。 如表4中所描繪,有由aps_params_type語法元素所提供之三個可能類型的APS: ●    ALF_AP:針對ALF參數 ●    針對LMCS參數之LMCS_APS ●    針對擴縮列表相對參數之SCALING_APS
Figure 02_image007
這三個類型的APS參數被依次討論如下 ALF APS ALF參數被描述在調適性迴路過濾器資料語法元素(表5)中。首先,四個旗標被專用於指明ALF過濾器係針對亮度及/或針對色度來傳輸以及CC-ALF(跨成分調適性迴路過濾)是否針對Cb成分及Cr成分來致能。假如亮度過濾器旗標被致能,則另一旗標被解碼以得知截割值是否被傳訊 (alf_luma_clip_flag )。接著經傳訊之過濾器的數目係使用alf_luma_num_filters_signalled_minus1 語法元素而被解碼。假如需要的話,代表ALF係數差量之語法元素「alf_luma_coeff_delta_idx 」係針對各經致能過濾器而被解碼。接著各過濾器之各係數的絕對值及符號被解碼。 假如alf_luma_clip_flag 被致能,則各經致能過濾器之各係數的截割指數被解碼。 以相同方式,ALF色度係數被解碼(假如需要的話)。 假如CC-ALF係針對Cr或Cb來致能,則過濾器之數目被解碼(alf_cc_cb_filters_signalled_minus1 alf_cc_cr_filters_signalled_minus1 )且相關的係數被解碼(alf_cc_cb_mapped_coeff_absalf_cc_cb_coeff_sign 或各別地alf_cc_cr_mapped_coeff_absalf_cc_cr_coeff_sign )
Figure 02_image009
Figure 02_image011
亮度映射及色度擴縮兩者之LMCS語法元素 以下的表6提供全部LMCS語法元素,其被編碼以調適參數集(APS)語法結構,當aps_params_type 參數被設為1 (LMCS_APS)時。最多四個LMCS APS可被用於經編碼視頻序列,然而,僅單一LMCS APS可被用於既定圖片。 這些參數被用以建立亮度之前向和反向映射功能以及色度之擴縮功能。
Figure 02_image013
擴縮列表APS 擴縮列表提供用以更新用於量化之量化矩陣的可能性。在VVC中,此擴縮矩陣被傳訊在APS中,如在擴縮列表資料語法元素(表7擴縮列表資料語法)中所述。第一語法元素指明擴縮矩陣是否被用於LFNST(低頻不可分離變換)工具,基於旗標scaling_matrix_for_lfnst_disabled_flag 。假如擴縮列表被用於色度成分(scaling_list_chroma_present_flag ),則第二者被指明。接著用以建立擴縮矩陣所需的語法元素被解碼(scaling_list_copy_mode_flag, scaling_list_pred_mode_flag , scaling_list_pred_id_delta, scaling_list_dc_coef, scaling_list_delta_coef )。
Figure 02_image015
圖片標頭 圖片標頭被傳輸在其他切片資料前的各圖片之開始處。此相較於該標準之先前草案中之先前標頭係極大的。所有這些參數之完整描述可被發現在JVET-Q2001-vD中。表9顯示目前圖片標頭解碼語法中之這些參數。 其可被解碼之相關語法元素係有關於: ●    此圖片之使用、參考框與否 ●    圖片之類型 ●    輸出框 ●    圖片之數目 ●    子圖片使用(假如需要的話) ●    參考圖片列表(假如需要的話) ●    顏色平面(假如需要的話) ●    分割更新(假如撤銷旗標被致能的話) ●    差量QP參數(假如需要的話) ●    移動資訊參數(假如需要的話) ●    ALF參數(假如需要的話) ●    SAO參數(假如需要的話) ●    量化參數(假如需要的話) ●    LMCS參數(假如需要的話) ●    擴縮列表參數(假如需要的話) ●    圖片標頭延伸(假如需要的話) ●    等等 圖片「類型」 第一旗標為gdr_or_irap_pic_flag ,其指示目前圖片是否為再同步化圖片(IRAP或GDR).假如此旗標為真,則gdr_pic_flag 被解碼以得知目前圖片是否為IRAP或GDR圖片。 接著ph_inter_slice_allowed_flag 被解碼以識別間切片被容許。 當其被容許時,旗標ph_intra_slice_allowed_flag 被解碼以得知目前圖片是否容許內切片。 接著non_reference_picture_flag 、指示PPS ID之ph_pic_parameter_set_id 及圖片順序數ph_pic_order_cnt_lsb 被解碼。圖片順序數提供目前圖片之數目。 假如圖片為GDR或IRAP圖片,則旗標no_output_of_prior_pics_flag 被解碼。 而假如圖片為GDR,則recovery_poc_cnt 被解碼。接著,ph_poc_msb_present_flagpoc_msb_val 被解碼(假如需要的話)。 ALF 在描述有關目前圖片之重要資訊的這些參數後,該組ALF APS id語法元素被解碼,假如ALF被致能在SPS階的話以及假如ALF被致能在圖片標頭階的話。由於sps_alf_enabled_flag 旗標,ALF被致能在SPS階。且由於alf_info_in_ph_flag 等於1,ALF傳訊被致能在圖片標頭階;否則(alf_info_in_ph_flag等於0)ALF被傳訊在切片階。 alf_info_in_ph_flag被界定如下: 「alf_info_in_ph_flag 等於 1 指明其 ALF 資訊存在 PH 語法結構中且不存在切片標頭中,意指不含 PH 語法結構的 PPS alf_info_in_ph_flag 等於 0 指明其 ALF 資訊不存在 PH 語法結構中且可存在切片標頭中,意指不含 PH 語法結構 的PPS。」 首先ph_alf_enabled_present_flag 被解碼以判定ph_alf_enabled_flag 是否應被解碼。假如ph_alf_enabled_flag 被致能,則ALF被致能於目前圖片之所有切片。 假如ALF被致能,則亮度之ALF APS id的量被解碼,使用pic_num_alf_aps_ids_luma 語法元素。針對各APS id,亮度之APS id值被解碼「ph_alf_aps_id_luma 」。 針對色度,語法元素ph_alf_chroma_idc 被解碼以判定ALF是否被致能於色度、僅於Cr、或者僅於Cb。假如其被致能,則色度之APS ID的值被解碼,使用ph_alf_aps_id_chroma 語法元素。 以此方式,CC-ALF方法之APS ID被解碼(假如需要的話)於Cb及/或CR成分。 LMCS 該組LMCS APS ID語法元素被接著解碼,假如LMCS被致能在SPS階的話。首先ph_lmcs_enabled_flag 被解碼以判定LMCS是否被致能於目前圖片。假如LMCS被致能,則ID值為經解碼ph_lmcs_aps_id 。針對色度,僅ph_chroma_residual_scale_flag 被解碼以致能或除能用於色度之方法。 擴縮列表 該組擴縮列表APS ID被接著解碼,假如擴縮列表被致能在SPS階的話。ph_scaling_list_present_flag 被解碼以判定擴縮矩陣是否被致能於目前圖片。且APS ID (ph_scaling_list_aps_id )之值被接著解碼。 子圖片 子圖片參數被致能,當其被致能在SPS時以及假如子圖片id傳訊被除能的話。其亦含有關於虛擬邊界的一些資訊。針對子圖片參數,八個語法元素被界定:
Figure 02_image017
輸出旗標 這些子圖片參數被接續以pic_output_flag (假如存在的話)。 參考圖片列表 假如參考圖片列表被傳訊在圖片標頭中(由於rpl_info_in_ph_flag等於1)的話,則參考圖片列表之參數被解碼ref_pic_lists() ,其含有以下語法元素:
Figure 02_image019
Figure 02_image021
分割 該組分割參數被解碼(假如需要的話)且含有以下語法元素:
Figure 02_image023
加權預測 加權預測參數pred_weight_table() 被解碼,假如加權預測方法被致能在PPS階的話以及假如加權預測參數被傳訊在圖片標頭(wp_info_in_ph_flag 等於1)的話。pred_weight_table() 含有針對列表L0及針對列表L1之加權預測參數,當雙預測加權預測被致能時。當加權預測參數被傳輸在圖片標頭中時,針對各列表之權重的數目被明確地傳輸如在pred_weight_table() 語法表8中所繪示。
Figure 02_image025
差量QP 當圖片為內時,ph_cu_qp_delta_subdiv_intra_sliceph_cu_chroma_qp_offset_subdiv_intra_slice 被解碼(假如需要的話)。而假如間切片被容許的話,ph_cu_qp_delta_subdiv_inter_sliceph_cu_chroma_qp_offset_subdiv_inter_slice 被解碼(假如需要的話)。最後,圖片標頭延伸語法元素被解碼(假如需要的話)。 所有參數alf_info_in_ph_flagrpl_info_in_ph_flagqp_delta_info_in_ph_flagsao_info_in_ph_flagdbf_info_in_ph_flagwp_info_in_ph_flag 被傳訊在PPS中。
Figure 02_image027
Figure 02_image029
Figure 02_image031
Figure 02_image033
切片標頭 切片標頭被傳輸在各切片之開始時。切片標頭含有約65個語法元素。此相較於較早視頻編碼標準中之先前切片標頭係極大的。所有切片標頭參數之完整描述可被發現在JVET-Q2001-vD中。表10顯示目前切片標頭解碼語法中之這些參數。
Figure 02_image035
Figure 02_image037
Figure 02_image039
首先picture_header_in_slice_header_flag 被解碼以得知picture_header_structure( )是否存在切片標頭中。slice_subpic_id (假如需要的話)被接著解碼以判定目前切片之子圖片id。接著slice_address 被解碼以判定目前切片之位址。切片位址被解碼,假如目前切片模式為矩形切片模式(rect_slice_flag 等於1)的話以及假如目前子圖片中之切片的數目高於1的話。切片位址亦可被解碼,假如目前切片模式為光柵掃描模式(rect_slice_flag 等於0)的話以及假如目前圖片中之磚的數目基於PPS中所界定之變數來計算係高於1的話。num_tiles_in_slice_minus1 被接著解碼,假如目前圖片中之磚的數目大於一的話以及假如目前切片模式不是矩形切片模式的話。在目前VVC草案規格中,num_tiles_in_slice_minus1 被界定如下: 「num_tiles_in_slice_minus1 加1,當存在時,指明切片中之磚的數目。num_tiles_in_slice_minus1之值應在0至NumTilesInPic - 1(包括)之範圍中。」 接著slice_type 被解碼。 假如ALF被致能在SPS階(sps_alf_enabled_flag )的話以及假如ALF被傳訊在切片標頭中(alf_info_in_ph_flag 等於0)的話,則ALF資訊被解碼。此包括一旗標,其指示ALF被致能於目前切片(slice_alf_enabled_flag )。假如其被致能,則亮度之APS ALF ID的數目(slice_num_alf_aps_ids_luma )被解碼的話,則APS ID被解碼(slice_alf_aps_id_luma[ i ] )。接著slice_alf_chroma_idc 被解碼以得知ALF是否被致能於色度成分以及其係致能哪個色度成分。接著APS ID針對色度被解碼slice_alf_aps_id_chroma (假如需要的話)。以相同方式,slice_cc_alf_cb_enabled_flag 被解碼(假如需要的話)以得知CC ALF方法是否被致能。假如CC ALF被致能的話,則CR及/或CB之相關APS ID被解碼,假如CC ALF被致能於CR及/或CB的話。 假如顏色平面被獨立地傳輸的話 (separate_colour_plane_flag 為等於1)則colour_plane_id 被解碼。 當參考圖片列表未被傳輸在圖片標頭中(rpl_info_in_ph_flag 等於0)時以及當NAL單元不是IDR或者假如參考圖片列表被傳輸於IDR圖片(sps_idr_rpl_present_flag 等於1)的話,則參考圖片列表參數被解碼;這些係類似於圖片標頭中的那些。 假如參考圖片列表被傳輸在圖片標頭中(rpl_info_in_ph_flag 等於1)或NAL單元不是IDR的話或者假如參考圖片列表被傳輸於IDR圖片(sps_idr_rpl_present_flag 等於1)的話以及假如至少一個列表之參考的數目高於1的話,則撤銷旗標num_ref_idx_active_override_flag 被解碼。 假如此旗標被致能則各列表之參考指標被解碼。 當切片類型不是內時且假如需要的話,cabac_init_flag 被解碼。假如參考圖片列表被傳輸在切片標頭中且有其他條件的話,則slice_collocated_from_l0_flagslice_collocated_ref_idx 被解碼。這些資料係相關於CABAC編碼及經共置的移動向量。 以相同方式,當切片類型不是內時,則加權預測之參數pred_weight_table( ) 被解碼。slice_qp_delta 被解碼,假如差量QP資訊被傳輸在切片標頭中(qp_delta_info_in_ph_flag 等於0)的話。假如需要的話,語法元素slice_cb_qp_offset slice_cr_qp_offset slice_joint_cbcr_qp_offset cu_chroma_qp_offset_enabled_flag 被解碼。 假如SAO資訊被傳輸在切片標頭中 (sao_info_in_ph_flag 等於0)的話且假如其被致能在SPS階(sps_sao_enabled_flag )的話,則SAO之經致能旗標被解碼於亮度及色度兩者:slice_sao_luma_flag slice_sao_chroma_flag 。 接著解塊過濾器參數被解碼,假如其被傳訊在切片標頭中(dbf_info_in_ph_flag 等於0)的話。 旗標slice_ts_residual_coding_disabled_flag 被系統性地解碼以得知變換跳過殘餘編碼方法是否被致能於目前切片。 假如LMCS被致能於圖片標頭中(ph_lmcs_enabled_flag 等於1)的話,則旗標slice_lmcs_enabled_flag 被解碼。 以相同方式,假如擴縮列表被致能在圖片標頭中(phpic_scaling_list_presentenabled_flag 等於1)的話,則旗標slice_scaling_list_present_flag 被解碼。 接著,其他參數被解碼(假如需要的話)。 切片標頭中之圖片標頭 以一特別的傳訊方式,圖片標頭(708)可被傳訊在切片標頭(710)內部,如圖7中所繪示。在該情況下,沒有僅含圖片標頭(608)之NAL單元。NAL單元701-707係相應於圖6中之各別NAL單元601-607。類似地,編碼磚720及編碼區塊740相應於圖6之區塊620及640。因此,這些單元及區塊之解釋將不被重複於此。此可被致能在切片標頭中,由於旗標picture_header_in_slice_header_flag。此外,當圖片標頭被傳訊在切片標頭內部時,該圖片應僅含有一個切片。因此,每圖片永遠僅有一個圖片標頭。此外,旗標picture_header_in_slice_header_flag將具有針對CLVS(經編碼層視頻序列,Coded Layer Video Sequence)之所有圖片的相同值。其表示介於包括第一IRAP的兩個IRAP之間的所有圖片具有每圖片僅一個切片。 旗標picture_header_in_slice_header_flag被界定如下: picture_header_in_slice_header_flag 等於 1 指明其 PH 法結構係存在切片標頭中。 picture_header_in_slice_header_flag 等於 0 指明其 PH 語法結構不存在切片標頭中。 位元流符合之要求係其 picture_header_in_slice_header_flag 之值應在 CLVS 中之所有經編碼切片中均相同。 picture_header_in_slice_header_flag 等於 1( 針對經編碼切片 ) 時,位元流符合之要求係其在 CLVS 中應無具有等於 PH_NUT nal_unit_type VCL NAL 單元存在。 picture_header_in_slice_header_flag 等於 0 時,則在目前圖片中之所有經編碼切片均應具有 picture_header_in_slice_header_flag 等於 0 ,且目前 PU 應具有 PH NAL 單元。 picture_header_structure( ) 含有 picture_rbsp() 除了填充位元 rbsp_trailing_bits( ) 之語法元素。」 串流應用 一些串流應用僅提取該位元流之某些部分。這些提取可為空間(如子圖片)或時間(視頻序列之子部分)。接著這些經提取部分可與其他位元流合併。一些其他者係藉由僅提取一些框來減少框率。通常,這些串流應用之主要目的係使用容許的頻寬之最大值來產生最大品質給末端使用者。 在VVC中,APS ID編號已被限制以利框率減少,使得一框之新APS id編號無法被用於在時間階層中之上階處的框。然而,針對提取該位元流之部分的串流應用,APS ID需被追蹤以判定哪個APS應被保持於位元流之組部分,因為框(如IRAP)不重設APS ID之編號。 LMCS(具有色度擴縮之亮度映射) 具有色度擴縮之亮度映射(LMCS)技術係一種應用在一區塊上之樣本值轉換方法,在應用迴路過濾器於視頻解碼器(如VVC)中前。 LMCS可被劃分成兩個子工具。第一個被應用在亮度區塊上而第二個子工具被應用在色度區塊上,如以下所述: 1)第一子工具係基於調適性分段式線性模型之亮度成分的迴路中映射。亮度成分之迴路中映射調整輸入信號之動態範圍,藉由重新分佈碼字橫跨動態範圍以增進壓縮效率。亮度映射係利用前向映射功能入「映射域」及相應反映射功能以回到「輸入域」中。 2)第二子工具係相關於色度成分,其中亮度相依的色度殘餘擴縮被應用。色度殘餘擴縮被設計以補償介於亮度信號與其相應色度信號之間的互作用。色度殘餘擴縮係取決於目前區塊之頂部及/或左側經重建相鄰亮度樣本的平均值。 就像視頻編碼器中之大部分其他工具(如VVC),LMCS可被致能/除能在序列階(使用SPS旗標)。色度殘餘擴縮是否被致能亦被傳訊在切片階。假如亮度映射被致能的話,一額外旗標被傳訊以指示亮度相依的色度殘餘擴縮是否被致能。當亮度映射不被使用時,亮度相依的色度殘餘擴縮被完全除能。此外,亮度相依的色度殘餘擴縮總是被除能於其大小小於或等於4之色度區塊。 圖8顯示如以上針對亮度映射子工具所解釋之LMCS的原理。圖8中之陰影區塊係新LMCS功能性區塊,包括亮度信號之前向及反向映射。重要的是注意:當使用LMCS時,一些解碼操作被應用於「映射域」。這些操作係由圖8中之虛線的區塊所表示。其通常相應於反量化、反變換、亮度內預測及重建步驟,其在於以亮度殘餘加入亮度預測。反之,圖8中之實線區塊指示解碼程序被應用於原始(亦即,無映射)域之處,且此包括迴路過濾(諸如解塊、ALF、和SAO)、移動補償預測、及已解碼圖片之儲存為參考圖片(DPB)。 圖9顯示如圖8之類似圖形,但此次此係針對LMCS工具之色度擴縮子工具。圖9中之陰影區塊係新LMCS功能性區塊,其包括亮度相依的色度擴縮程序。然而,在色度中,有一些相較於亮度情況之重要差異。於此僅反量化及反變換(由虛線區塊所表示)被履行在色度樣本之「映射域」中。色度預測、移動補償、迴路過濾之所有其他步驟被履行在原始域中。如圖9中所示,僅有一擴縮程序且沒有如亮度映射之前向及反向處理。 藉由使用分段式線性模型的亮度映射。 亮度映射子工具係使用分段式線性模型。其表示分段式線性模型將輸入信號動態範圍分離成16個相等的子範圍;且針對各子範圍,其線性映射參數係使用指定給該範圍之碼字的數目來表達。 亮度映射之語意 語法元素lmcs_min_bin_idx 指明利用色度擴縮(LMCS)建構程序而用在亮度映射中之最小分格指標。lmcs_min_bin_idx 之值應在0至15(包括)之範圍中。 語法元素lmcs_delta_max_bin_idx 指明介於15與利用色度擴縮建構程序而用在亮度映射中的分格指標LmcsMaxBinIdx 之間的差量值。lmcs_delta_max_bin_idx 之值應在0至15(包括)之範圍中。LmcsMaxBinIdx 之值被設為等於15-lmcs_delta_max_bin_idxLmcsMaxBinIdx 之值應大於或等於lmcs_min_bin_idx 。 語法元素lmcs_delta_cw_prec_minus1 加1係指明用於語法lmcs_delta_abs_cw[ i ] 之表示的位元之數目。 語法元素lmcs_delta_abs_cw[ i ] 係指明第i分格之絕對差量碼字值。 語法元素lmcs_delta_sign_cw_flag[ i ] 係指明變數lmcsDeltaCW[ i ] 之符號。當lmcs_delta_sign_cw_flag[ i ] 不存在時,其被推論為等於0。 亮度映射之LMCS中間變數計算 為了應用前向及反向亮度映射處理,一些中間變數及資料陣列是需要的。 首先,變數OrgCW被導出如下:
Figure 02_image041
接著,變數lmcsDeltaCW[ i ],其中i=lmcs_min_bin_idx.. LmcsMaxBinIdx,被計算如下:
Figure 02_image043
新變數lmcsCW[ i ]被導出如下: -     針對i = 0.. lmcs_min_bin_idx - 1,lmcsCW[ i ]被設為等於0。 -     針對i = lmcs_min_bin_idx..LmcsMaxBinIdx,以下適用: lmcsCW[ i ] = OrgCW + lmcsDeltaCW[ i ] lmcsCW[ i ]之值應在(OrgCW>>3)至(OrgCW<<3 - 1) (包括)之範圍中。 -     針對i = LmcsMaxBinIdx + 1..15,lmcsCW[ i ]被設為等於0。 變數InputPivot[ i ],其中i = 0..16,被導出如下:
Figure 02_image045
變數LmcsPivot[ i ](其中i = 0..16)、變數ScaleCoeff[ i ]及InvScaleCoeff[ i ](其中i = 0..15)被計算如下:
Figure 02_image047
前向亮度映射 如由圖8所示,當LMCS被應用於亮度時,稱為predMapSamples[i][j] 之亮度再映射樣本被獲取自預測樣本predSamples[ i ][ j ]predMapSamples[i][j] 被計算如下: 首先,指標idxY被計算自預測樣本predSamples[ i ][ j ] ,在位置(i, j)處。 idxY = predSamples[ i ][ j ] >> Log2( OrgCW ) 接著,predMapSamples[i][j]係藉由使用段落0之中間變數idxY、LmcsPivot[ idxY ]及InputPivot[ idxY ]而被導出如下:
Figure 02_image049
亮度重建樣本 重建程序被獲得自預測亮度樣本predMapSample[i][j] 及殘餘亮度樣本resiSamples[i][j] 。 經重建亮度圖片樣本recSamples [ i ][ j ] 係藉由將predMapSample[i][j] 加至resiSamples[i][j] 而被簡單地獲得如下:
Figure 02_image051
在此上述關係式中,Clip 1函數係截割函數,用以確保經重建樣本係介於0與1<< BitDepth -1之間。 反向亮度映射 當依據圖8以應用反向亮度映射時,以下操作被應用在處理中之目前區塊的各樣本recSample[i][j] 上: 首先,指標idxY被計算自重建樣本recSamples[ i ][ j ] ,在位置(i, j)處。
Figure 02_image053
反向映射亮度樣本invLumaSample[i][j] 係基於而被導出如下:
Figure 02_image055
截割操作被接著執行以獲得最後樣本:
Figure 02_image057
色度擴縮 色度擴縮之LMCS語意 在表6中之語法元素lmcs_delta_abs_crs 係指明變數lmcsDeltaCrs 之絕對差量碼字值。lmcs_delta_abs_crs 之值應在0至7(包括)之範圍中。當不存在時,lmcs_delta_abs_crs 之值被推論為等於0。 語法元素lmcs_delta_sign_crs_flag 指明變數lmcsDeltaCrs 之符號。當不存在時,lmcs_delta_sign_crs_flag 被推論為等於0。 色度擴縮之LMCS中間變數計算 為了應用色度擴縮程序,一些中間變數是需要的。 變數lmcsDeltaCrs 被導出如下:
Figure 02_image059
變數ChromaScaleCoeff[ i ] ,其中i = 0...15,被導出如下:
Figure 02_image061
色度擴縮程序 在第一步驟中,變數invAvgLuma 被導出以計算在目前相應色度區塊周圍之經重建亮度樣本的平均亮度值。平均亮度被計算自圍繞相應色度區塊之左側及頂部亮度區塊。 假如無樣本可得,則變數invAvgLuma 被設定如下:
Figure 02_image063
基於段落0之中間陣列LmcsPivot[  ] ,變數idxYInv 被接著導出如下:
Figure 02_image065
變數varScale被導出如下:
Figure 02_image067
當變換被應用於目前色度區塊上時,經重建色度圖片樣本陣列recSamples 被導出如下:
Figure 02_image069
假如無變換已被應用於目前區塊,則以下適用:
Figure 02_image071
編碼器考量 LMCS編碼器之基本原理係首先將更多碼字指派至其中那些動態範圍段具有比平均方差更低的碼字之範圍。在此之替代公式中,LMCS之主要目標係指派較少的碼字至其具有比平均方差更高的碼字之那些動態範圍段。以此方式,圖片之平滑區域將被編碼以比平均更多的碼字,且反之亦然。 其被儲存在APS中之LMCS的所有參數(參見表6)被判定在編碼器側。LMCS編碼器演算法係基於局部亮度方差之評估,且依據上述基本原理以最佳化LMCS參數之判定。該最佳化被接著進行以獲得既定區塊之最終經重建樣本的最佳PSNR矩陣。 實施例 當不需要時避免切片位址語法 在一個實施例中,當圖片標頭被傳訊在切片標頭中時,切片位址語法元素(slice_address )被推論為等於值0,即使磚數目大於1。表11繪示此實施例。 此實施例之優點在於其當圖片標頭在其減少位元率之切片標頭中時則切片位址不被剖析,特別針對低延遲及低位元率應用;且其減少剖析複雜度,針對當該圖片被傳訊在切片標頭中時之一些實施方式。 在一實施例中,此僅被應用於光柵掃描切片模式(rect_slice_flag 等於0)。此減少一些實施方式之剖析複雜度。
Figure 02_image073
當不需要時避免切片中之磚數目的傳輸 在一個實施例中,當圖片標頭被傳輸在切片標頭中時,則切片中之磚數目不被傳輸。表12闡明此實施例,其中當旗標picture_header_in_slice_header_fla g被設為等於1時,num_tiles_in_slice_minus1 語法元素不被傳輸。此實施例之優點係位元率減少,特別針對低延遲及低位元率應用,因為磚數目無須被傳輸。 在一實施例中,此僅被應用於光柵掃描切片模式(rect_slice_flag 等於0)。此減少一些實施方式之剖析複雜度。
Figure 02_image075
藉由PPS值NumTilesInPic(語意)預測 在一個額外實施例中,當圖片標頭被傳輸在切片標頭中時,則目前切片中之磚數目被推論為等於圖片中之磚數目。此可藉由將以下句子加入語法元素num_tiles_in_slice_minus1 之語意中來設定:「當不存在時,變數 num_tiles_in_slice_minus1 被設為等於 NumTilesInPic-1 」。 其中變數NumTilesInPic 給出該圖片之最大磚數目。此變數係基於PPS中所傳輸之語法元素來計算。 在切片位址前設定磚數目並避免slice_address之非必要傳輸 在一實施例中,專屬於切片中之磚數目的語法元素被傳輸在切片位址前,且其值被用以得知是否需要解碼該切片位址。更精確地,切片中之磚數目係與圖片中之磚數目進行比較以得知是否需要解碼切片位址。確實,假如切片中之磚數目等於圖片中之磚數目的話則確認其目前圖片僅含有一個切片。 在一實施例中,此僅被應用於光柵掃描切片模式(rect_slice_flag 等於0)。此減少一些實施方式之剖析複雜度。 表13繪示此實施例。其中假如語法元素num_tiles_in_slice_minus1 等於變數NumTilesInPic 減1,則語法元素slice_address 不被解碼。當um_tiles_in_slice_minus1 等於變數NumTilesInPic 減1,則slice_address 被推論為等於0。
Figure 02_image077
此實施例之優點是位元率減少及剖析複雜度減少,當條件被設為等於真時,由於切片位址不被傳輸。 在一實施例中,指示目前切片中之磚數目的語法元素不被解碼且切片中之磚數目被推論為等於1,當圖片標頭被傳輸在切片標頭中時。以及切片位址被推論為等於0,且相關的語法元素不被解碼,當切片中之磚數目等於圖片中之磚數目時。表14繪示此實施例。 如此增加由這兩個實施例之結合所獲得的位元率減少。
Figure 02_image079
移除不需要的條件numTileInPic > 1 在一實施例中,目前圖片中之磚數目需大於1的條件不需要被測試(當光柵掃描切片模式被致能時),為了使語法元素slice_address 及/或目前切片中之磚數目被解碼。明確地,當目前圖片中之磚數目等於1時,rect_slice_flag 值被推論為等於1。結果,光柵掃描切片模式無法被致能在該情況下。表15繪示此實施例。 此實施例減少了切片標頭之剖析複雜度。
Figure 02_image081
在一實施例中,指示目前切片中之磚數目的語法元素不被解碼且切片中之磚數目被推論為等於1,當圖片標頭被傳輸在切片標頭中時以及當光柵掃描切片模式被致能時。以及切片位址被推論為等於0,且相關的語法元素slice_address 不被解碼,當切片中之磚數目等於圖片中之磚數目時以及當光柵掃描切片模式被致能時。表16繪示此實施例。 優點是位元率減少及剖析複雜度減少。
Figure 02_image083
實施方式 圖11顯示一種系統191、195,其包含編碼器150或解碼器100之至少一者以及通訊網路199,依據本發明之實施例。依據一實施例,系統195係用於處理並提供內容(例如,用於顯示/輸出或串流視頻/音頻內容之視頻及音頻內容)給使用者,其得以存取至解碼器100,例如透過包含解碼器100之使用者終端或可與解碼器100通訊之使用者終端的使用者介面。此一使用者終端可為電腦、行動電話、平板或者能夠提供/顯示(經提供/經串流)內容給使用者之任何其他類型的裝置。系統195經由通訊網路199以獲得/接收位元流101(以連續流或信號之形式-例如,當較早視頻/音頻被顯示/輸出時)。依據一實施例,系統191係用於處理內容並儲存經處理內容,例如用於在稍後時間顯示/輸出/串流之經處理視頻及音頻內容。系統191獲得/接收包含影像151之原始序列的內容,其被編碼器150接收並處理(包括利用依據本發明之解塊過濾器的過濾),且編碼器150產生位元流101,其將經由通訊網路191而被傳遞至解碼器100。位元流101被以數種方式接著傳遞至解碼器100,例如其可由編碼器150所事先產生並當作資料而被儲存在通訊網路199中之儲存設備中(例如,在伺服器或雲端儲存上)直到使用者從該儲存設備請求該內容(亦即,位元流資料),此刻資料係從該儲存設備被傳遞/串流至解碼器100。系統191亦可包含內容提供設備,用於提供/串流至使用者(例如,藉由傳遞資料給使用者介面以供顯示在使用者終端上),用於儲存設備中所儲存之內容的內容資訊(例如,內容之名稱及用於識別、選擇及請求該內容的其他元/儲存位置資料),並用於接收且處理針對一內容之使用者請求以致其該請求的內容可從儲存設備被遞送/串流至使用者終端。替代地,編碼器150產生位元流101並直接將其傳遞/串流至解碼器100,如且當使用者請求該內容時。解碼器100接著接收位元流101(或信號)並利用依據本發明之解塊過濾器來履行過濾,以獲得/產生視頻信號109及/或音頻信號,其接著由使用者終端所使用以提供該請求的內容給使用者。 依據本發明之方法/程序的任何步驟或文中所述的功能可被實施以硬體、軟體、韌體、或其任何組合。假如以軟體實施,則該等步驟/功能可被儲存在或傳輸透過、成為一或多個指令或碼或程式、或電腦可讀取媒體,且被執行以一或多個基於硬體的處理單元(諸如可編程計算機器),其可為PC(「個人電腦」)、DSP(「數位信號處理器」)、電路、電路系統、處理器及記憶體、通用微處理器或中央處理單元、微控制器、ASIC(「特定應用積體電路」)、場可編程邏輯陣列(FPGA)、或者其他同等集成或離散邏輯電路。因此,如文中所使用之術語「處理器」可指稱前述結構之任一者或者適於文中所述之技術的實施之任何其他結構。 本發明之實施例亦可由多種裝置或設備來實現,包括無線手機、積體電路(IC)或一組JC(例如,晶片組)。各種組件、模組、單元被描述在文中以闡明其組態成履行那些實施例之裝置/設備的功能性態樣,但不一定需要由不同硬體單元來實現。反之,各種模組/單元可被組合在編碼解碼器硬體單元中或者由互操作硬體單元之集合來提供,包括一或多個處理器聯合適當的軟體/韌體。 本發明之實施例可由一種系統或設備之電腦來實現,該電腦係讀出並執行在儲存媒體上所記錄的電腦可執行指令(例如,一或多個程式)以履行上述實施例之一或多者的模組/單元/功能;及/或其包括一或多個處理單元或電路以履行上述實施例之一或多者的功能;以及可由一種由系統或設備之電腦所履行的方法來實現,藉由(例如)從儲存媒體讀出並執行電腦可執行指令以履行上述實施例之一或多者的功能及/或控制一或多個處理單元或電路來履行上述實施例之一或多者的功能。電腦可包括分離電腦或分離處理單元的網路以讀出並執行電腦可執行指令。電腦可執行指令可被提供至電腦,例如,從電腦可讀取媒體(諸如通訊媒體),經由網路或有形儲存媒體。通訊媒體可為信號/位元流/載波。有形儲存媒體係「非暫態電腦可讀取儲存媒體」,其可包括(例如)硬碟、隨機存取記憶體 (RAM)、唯讀記憶體 (ROM)、分散式計算系統之儲存、光碟(諸如光碟(CD)、數位多功能光碟(DVD)、或藍光光碟(BD)™)、快閃記憶體裝置、記憶卡,等等之一或多者。步驟/功能之至少一些亦可被實施以硬體,藉由機器或專屬組件,諸如FPGA(「場可編程閘極陣列」)或ASIC(「特定應用積體電路」)。 圖12為一用於實施本發明之一或更多實施例的計算裝置2000之概略方塊圖。計算裝置2000可為一種裝置,諸如微電腦、工作站或輕型可攜式裝置。計算裝置2000包含一連接至以下的通訊匯流排:-中央處理單元(CPU)2001,諸如微處理器;-隨機存取記憶體(RAM)2002,用以儲存本發明之實施例的方法之可執行碼、以及暫存器,調適成記錄用以實施方法所需的變數和參數,該方法係依據本發明之實施例以編碼或解碼影像之至少部分,其記憶體容量可藉由一連接至(例如)擴充埠之選擇性RAM來擴充;-唯讀記憶體(ROM)2003,用以儲存供實施本發明之實施例的電腦程式;-網路介面(NET)2004,通常連接至通訊網路,待處理數位資料係透過該網路介面來傳輸或接收。網路介面(NET)2004可為單一網路介面,或者由不同網路介面之集合所組成(例如有線及無線介面、或者不同種類的有線或無線介面)。資料封包被寫入至網路介面以供傳輸或者從網路介面讀取以供接收,在CPU 2001中所運行之軟體應用程式的控制下;-使用者介面(UI)2005可用於從使用者接收輸入或者用以顯示資訊給使用者;-硬碟(HD)2006,可被提供為大量儲存裝置;-輸入/輸出模組(IO)2007可用於接收/傳送資料自/至外部裝置,諸如視頻來源或顯示。可執行碼可被儲存於ROM 2003中、於HD 2006上或者於可移除數位媒體(諸如,例如磁碟)上。依據變體,程式之可執行碼可藉由通訊網路來接收,經由NET 2004,以儲存於通訊裝置2000的儲存機構(諸如HD 2006)之一中,在執行之前。CPU 2001係調適成依據本發明之實施例以控制並指導程式或多數程式之指令或軟體碼部分的執行,該些指令係儲存於前述儲存機構之一中。在開機之後,CPU 2001能夠執行相關於軟體應用程式之來自主RAM記憶體2002的指令,在那些指令已從(例如)程式ROM 2003或HD 2006載入之後。此一軟體應用程式(當由CPU 2001所執行時)係致使依據本發明之方法的步驟被履行。 亦應理解:依據本發明之另一實施例,一種依據前述實施例之解碼器被提供於使用者終端,諸如電腦、行動電話(蜂巢式電話)、平板或任何其他類型的裝置(例如,顯示設備),其能夠提供/顯示內容給使用者。依據又另一實施例,一種依據前述實施例之編碼器被提供於一種影像擷取設備,其亦包含相機、視頻相機或網路相機(例如,閉路電視或視頻監視相機),其係擷取並提供內容給編碼器來編碼。兩個此類範例係參考圖13及14而被提供於下。 網路相機 圖13為一圖形,其繪示網路相機系統2100,包括網路相機2102及客戶設備2104。 網路相機2102包括成像單元2106、編碼單元2108、通訊單元2110、及控制單元2112。 網路相機2102與客戶設備2104被相互連接以能夠經由網路200而彼此通訊。 成像單元2106包括透鏡及影像感測器(例如,電荷耦合裝置(CCD)或互補金氧半導體(CMOS)),並擷取物件之影像且根據該影像以產生影像資料。此影像可為靜止影像或視頻影像。 編碼單元2108係藉由使用上述的該編碼方法以編碼影像資料。 網路相機2102之通訊單元2110將其由編碼單元2108所編碼的已編碼影像資料傳輸至客戶設備2104。 再者,通訊單元2110從客戶設備2104接收命令。該等命令包括用以設定編碼單元2108之編碼的參數之命令。 控制單元2112依據由通訊單元2110所接收的命令以控制網路相機2102中之其他單元。 客戶設備2104包括通訊單元2114、解碼單元2116、及控制單元2118。 客戶設備2104之通訊單元2114傳輸命令至網路相機2102。 再者,客戶設備2104之通訊單元2114從網路相機2102接收已編碼影像資料。 解碼單元2116係藉由使用上述的該解碼方法以解碼該經編碼影像資料。 客戶設備2104之控制單元2118依據由通訊單元2114所接收的使用者操作或命令以控制客戶設備2104中之其他單元。 客戶設備2104之控制單元2118控制顯示設備2120以顯示由解碼單元2116所解碼的影像。 客戶設備2104之控制單元2118亦控制顯示設備2120以顯示GUI(圖形使用者介面)來指定用於網路相機2102之參數的值,包括用於編碼單元2108之編碼的參數。 客戶設備2104之控制單元2118亦依據由顯示設備2120所顯示之輸入至GUI的使用者操作以控制客戶設備2104中之其他單元。 客戶設備2104之控制單元2119控制客戶設備2104之通訊單元2114以傳輸命令至網路相機2102,其指定用於網路相機2102之參數的值,依據由顯示設備2120所顯示之輸入至GUI的使用者操作。 智慧型手機 圖14為繪示智慧型手機2200之圖形。 智慧型手機2200包括通訊單元2202、解碼單元2204、控制單元2206、顯示單元2208、影像記錄裝置2210及感測器2212。 通訊單元2202經由網路200以接收經編碼影像資料。 解碼單元2204解碼其由通訊單元2202所接收的已編碼影像資料。 解碼單元2204係藉由使用上述的該解碼方法以解碼該經編碼影像資料。 控制單元2206依據由通訊單元2202所接收的使用者操作或命令以控制智慧型手機2200中之其他單元。 例如,控制單元2206控制顯示單元2208以顯示由解碼單元2204所解碼的影像。 雖然已參考了實施例來描述本發明,但應理解其本發明不限於所揭露的範例實施例。那些熟悉此技藝人士應理解:可做出各種改變及修改而不背離本發明之範圍,如後附申請專利範圍中所界定者。本說明書(包括任何伴隨的申請專利範圍、摘要及圖式)中所揭露的所有特徵、及/或所揭露的任何方法或程序之步驟,可以任何組合方式結合,除了其中此等特徵及/或步驟之至少部分是互斥的組合以外。本說明書(包括任何伴隨的申請專利範圍、摘要及圖式)中所揭露的各特徵可被取代以替代特徵,其係適用相同的、同等的或類似的目的,除非另外明確地聲明。因此,除非另外明確地聲明,所揭露的各特徵僅為同等或類似特徵之一般序列的一個範例。 亦應理解:上述比較、判定、評估、選擇、執行、履行、或考量之任何結果(例如於編碼或過濾程序期間所做的選擇)可指示於或者可判定/可推理自位元流中之資料(例如指示該結果之旗標或資料),以使得經指示的或經判定/經推理的結果可用於該處理,以取代實際地履行比較、判定、評估、選擇、執行、履行、或考量(例如於解碼程序期間)。 於申請專利範圍中,文字「包含」不排除其他元件或步驟,而不定冠詞「一(a)」或「一(an)」不排除複數。不同特徵在彼此不同的附屬項申請專利範圍中陳述之單純事實並不指示其這些特徵之組合無法被有利地使用。 出現在申請專利範圍中之參考數字僅為闡明且對於申請專利範圍之範圍應無限制性效果。Figure 1 is related to the coding structure used in the High Efficiency Video Coding (HEVC) video standard. Video sequence 1 is composed of a series of digital images i. Each of these digital images is represented by one or more matrices. The matrix coefficients represent pixels. Image 2 of the sequence can be divided into slice 3. Slices can form a complete image in some cases. These slices are divided into non-overlapping coding tree units (CTU). The coding tree unit (CTU) is the basic processing unit of the High Efficiency Video Coding (HEVC) video standard and conceptually its structure corresponds to the macro block unit used in several previous video standards. CTU is also sometimes referred to as the largest coding unit (LCU). CTU has luminance and chrominance component parts, and each of its component parts is called a coding tree block (CTB). These different color components are not shown in Figure 1. The CTU is usually 64x64 pixels in size. Each CTU can then be divided iteratively into smaller variable-size coding units (CU) 5 using a quadtree decomposition. A coding unit is a basic coding element and is composed of two sub-units called prediction unit (PU) and transform unit (TU). The maximum size of PU or TU is equal to the size of CU. The prediction unit corresponds to the partition of the CU for the prediction of the pixel value. Various partitions of the CU into PUs are possible (as shown by 606), including partitioning into 4 square PUs and two different partitioning into 2 rectangular PUs. The transformation unit is the basic unit, which accepts the spatial transformation using DCT. The CU can be divided into TUs according to the quadtree representation 607. Each slice is embedded in a network abstraction layer (NAL) unit. In addition, the coding parameters of the video sequence are stored in a dedicated NAL unit (called a parameter set). In HEVC and H.264/AVC, two parameter set NAL units are used: First, the sequence parameter set (SPS) NAL unit, which collects all parameters that have not changed during the entire video sequence. Usually, it deals with the coding outline, the size of the video frame, and other parameters. Second, the picture parameter set (PPS) NAL unit includes parameters that can be changed from one picture (or frame) to another in the sequence. HEVC also includes a video parameter set (VPS) NAL unit, which contains parameters describing the overall structure of the bitstream. VPS is a new type of parameter set defined by HEVC and is applied to all layers of the bit stream. A layer can contain most time sublayers, and all version 1 bit streams are restricted to a single layer. HEVC has layered extensions for scalability and multiple viewing angles, and these will enable most layers, with a backward compatible version 1 base layer. In the current definition of VVC, there are three high-level possibilities for picture segmentation: sub-picture, slice and tile. Each has its own characteristics and usability. The segmentation into sub-pictures is used for spatial extraction and/or merging of regions of a video. The segmentation into slices is based on similar concepts as the previous standard and corresponds to the packetization of video transmission, even if it can be used for other applications. Splitting into bricks is an encoder parallelization tool, because it splits the picture into independent coding regions of (almost) the same size of the picture. But this tool can also be used in other applications. Because these three high-level available possible ways of image segmentation can be used together, there are several modes for their use. As defined in the current draft specification of VVC, two modes of slicing are defined. For the raster scan slice mode, the slice contains a sequence of complete tiles raster-scanned by the tiles in the picture. This mode in the current VVC specification is shown in Figure 10(a). As shown in this figure, it is shown that the picture contains a brightness CTU of 18x12, which is divided into 12 tiles and 3 raster scan slices. For the second (rectangular slice mode), the slice contains several complete tiles, which collectively come from a rectangular area of the picture. This mode in the current VVC specification is shown in Figure 10(b). In this example, a picture with a brightness CTU of 18x12 is displayed, which is divided into 24 tiles and 9 rectangular slices. Figure 2 shows a data communication system in which one or more embodiments of the present invention can be implemented. The data communication system includes a transmission device (in this case, the server 201), which is operable to transmit data packets of the data stream to the receiving device (in this case, the client terminal 202) via the data communication network 200. The data communication network 200 may be a wide area network (WAN) or a local area network (LAN). This network can be, for example, a wireless network (Wifi/802.11a or b or g), an Ethernet network, the Internet, or a hybrid network composed of several different networks. In a specific embodiment of the present invention, the data communication system may be a digital television broadcasting system, in which the server 201 transmits the same data content to most clients. The data stream 204 provided by the server 201 can be composed of multimedia data representing video and audio data. The audio and video data streams can (in some embodiments of the invention) be captured by the server 201 using a microphone and a camera individually. In some embodiments, the data stream may be stored on the server 201 or received by the server 201 from another data provider, or generated on the server 201. The server 201 is provided with an encoder for encoding video and audio streams, in particular for providing a compressed bit stream for transmission, which is presented as a closer representation of the input data to the encoder. In order to obtain a better ratio of the quality of the transmitted data to the amount of the transmitted data, the compression of the video data can be based on the HEVC format or the H.264/AVC format, for example. The client 202 receives the transmitted bit stream and decodes the reconstructed bit stream to reproduce the video image on the display device and reproduce the audio data by the speaker. Although the streaming scenario is considered in the example of FIG. 2, it should be understood that in some embodiments of the present invention, the data communication between the encoder and the decoder can be performed using a media storage device (such as an optical disc). In one or more embodiments of the present invention, the video image is transmitted with its data representing offset compensation to facilitate the supply of reconstructed pixels to the image to provide filtered pixels in the final image. FIG. 3 schematically shows a processing device 300, which is configured to implement at least one embodiment of the present invention. The processing device 300 may be a device, such as a microcomputer, a workstation, or a light portable device. The device 300 includes a communication bus 313 connected to the following:-a central processing unit 311, such as a microprocessor, labeled as CPU;-a read-only memory 306, labeled as ROM, for storing computer programs for implementing the present invention; -Random access memory 312, labeled RAM, used to store the executable code of the method of the embodiment of the present invention, and a register, adapted to record the method and/or decoded bits used to implement the sequence of encoding digital images The variables and parameters required by the meta-flow method are based on the embodiment of the present invention; and-the communication interface 302 is connected to the communication network 303, and the digital data to be processed is transmitted or received through the communication network. Optionally, the device 300 may also include the following components:-A data storage mechanism 304 (such as a hard disk) for storing computer programs and data, and the computer programs are used to implement the method of one or more embodiments of the present invention , The data is used or generated during the implementation of one or more embodiments of the present invention;-the disk drive 305 of the disk 306, the disk drive is adapted to read data from the disk 306 or transfer data Write to the disk;-Screen 309, used to display data and/or function as a graphical interface with the user, by keyboard 310 or any other pointer mechanism. The device 300 may be connected to various peripherals, such as, for example, a digital camera 320 or a microphone 308, each connected to an input/output card (not shown) to supply multimedia data to the device 300. The communication bus provides communication and interoperability between various components included in the device 300 or connected to the device 300. The representation of the bus is non-limiting; and in particular, the central processing unit is operable to transfer instructions to any element of the device 300, directly or via another element of the device 300. Disk 306 can be replaced by any information medium, such as, for example, a compact disc (CD-ROM) (writable or non-writable), ZIP disc or memory card; and (in general terms) by means of an information storage mechanism, It can be read by a microcomputer or a microprocessor, integrated (or not integrated) into the device, may be removable and adapted to store one or more programs, the execution of which enables the encoding of digital images The method of the sequence and/or the method of decoding the bit stream are based on the present invention to be implemented. The executable code may be stored in the read-only memory 306, on the hard disk 304, or on a removable digital medium (such as, for example, the magnetic disk 306, as previously described). According to a variant, the executable code of the program can be received via the communication network 303 and stored in one of the storage mechanisms (such as the hard disk 304) of the device 300 (before execution) via the interface 302. The central processing unit 311 is adapted to control and direct the execution of commands or software code parts of programs or most programs according to the present invention, and these commands are stored in one of the aforementioned storage mechanisms. At boot time, the programs or most programs stored in non-volatile memory (for example, on the hard disk 304 or in the read-only memory 306) are transferred to the random access memory 312, which then contains programs or The executable code of most programs and the register used to store the variables and parameters required for implementing the present invention. In this embodiment, the device is a programmable device, which uses software to implement the present invention. However, alternatively, the present invention may be implemented in hardware (for example, in the form of application-specific integrated circuits or ASICs). Fig. 4 shows a block diagram of an encoder according to at least one embodiment of the present invention. The encoder is represented by connected modules, and each module is adapted to implement (for example, in the form of programming instructions to be executed by the CPU 311 of the device 300) at least one corresponding step of a method according to the present invention One or more embodiments to implement at least one embodiment of the images of the encoded image sequence. The original sequence of digital images i 0 to i n 401 is received by the encoder 400 as input. Each digital image is represented by a set of samples (known as pixels). The bit stream 410 is output by the encoder 400 after the encoding process is implemented. The bitstream 410 includes a plurality of coding units or slices. Each slice includes a slice header and a slice body. The slice header is used to transmit the coding value of the coding parameter used to encode the slice, and the slice body includes the encoded video. material. The input digital images i 0 to i n 401 are divided into pixel blocks by the module 402. The blocks correspond to the image portion and can have variable sizes (for example, 4x4, 8x8, 16x16, 32x32, 64x64, 128x128 pixels and the size of several rectangular blocks can also be considered). The coding mode is selected for each input block. Two families of coding modes are provided: coding mode based on spatial prediction (intra prediction) and coding mode based on temporal prediction (inter coding, merge, SKIP). Possible coding modes are tested. The module 403 implements an intra-prediction process, in which a predetermined block to be coded is predicted by a predictor, which is calculated from pixels near the block to be coded. The selected intra-predictor and an indication of the difference between the given block and its predictor are coded to provide a residual, if the intra-coding is selected. Time prediction is implemented by the motion estimation module 404 and the motion compensation module 405. First, a reference image from a set of reference images 416 is selected, and a part of the reference image (also called a reference area or image part, which is the closest area to a predetermined block to be encoded) is modeled by motion estimation. Selected by group 404. The motion compensation module 405 then uses the selected area to predict the block to be coded. The difference between the selected reference area and the predetermined block (also referred to as the residual block) is calculated by the motion compensation module 405. The selected reference area is indicated by the movement vector. Therefore, in both cases (spatial and temporal prediction), the residual is calculated by subtracting the prediction from the original block. In the INTRA prediction implemented by the module 403, the prediction direction is coded. In time prediction, at least one motion vector is coded. In the inter prediction implemented by the modules 404, 405, 416, 418, and 417, at least one motion vector or data used to identify the motion vector is coded for temporal prediction. The information relative to the motion vector and residual block is coded, if inter prediction is selected. In order to further reduce the bit rate, assuming that the movement is homogeneous, the motion vector is coded by the difference related to the motion vector predictor. The motion vector predictor of a group of motion information predictors is obtained from the motion vector field 418 by the motion vector prediction and coding module 417. The encoder 400 further includes a selection module 406 for selecting an encoding mode by applying an encoding cost criterion (such as a rate-distortion criterion). In order to further reduce redundancy, a transform (such as DCT) is applied to the residual block by the transform module 407, and the obtained transform is then quantized by the quantization module 408 and entropy coded by the entropy coding module 409. Finally, the coded residual block of the block currently being coded is inserted into the bitstream 410. The encoder 400 also performs decoding of the encoded image to generate a reference image for motion estimation of subsequent images. This enables the encoder and decoder to receive bit streams to have the same reference frame. The inverse quantization module 411 performs inverse quantization of the quantized data, followed by inverse transformation by the inverse transformation module 412. The anti-intra prediction module 413 uses the prediction information to determine which predictor should be used in a given block, and the anti-motion compensation module 414 actually adds its residual obtained by the module 412 to the set of reference images 416. Obtained reference area. The post-filtering is then applied by the module 415 to filter the reconstructed frame of pixels. In the embodiment of the present invention, a SAO loop filter is used, in which a compensation offset is added to the pixel value of the reconstructed pixel of the reconstructed image. Figure 5 shows a block diagram of a decoder 60 which can be used to receive data from the encoder, according to an embodiment of the invention. The decoder is represented by connected modules, and each module is adapted to implement (for example, in the form of programming instructions to be executed by the CPU 311 of the device 300) the corresponding steps of a method implemented by the decoder 60. The decoder 60 receives a bit stream 61 containing coding units. Each coding unit is composed of a header and a body. The header contains information about coding parameters and the body contains encoded video data. The structure of the bit stream in VVC is described in more detail below with reference to FIG. 6. As explained in relation to FIG. 4, the encoded video data is entropy encoded, and the index of the motion vector predictor is encoded (for a given block) on a predetermined number of bits. The received encoded video data is entropy decoded by the module 62. The residual data is then dequantized by module 63, and then inverse transformation is applied by module 64 to obtain pixel values. The mode data indicating the coding mode is also entropy decoded; and according to the mode, INTRA type decoding or INTER type decoding is performed on the coded blocks of the image data. In the case of the INTRA mode, the INTRA prediction sub-system is determined by the inverse prediction module 65 according to the intra prediction mode specified in the bit stream. If the mode is INTER, the motion prediction information is extracted from the bit stream to find the reference area used by the encoder. The motion prediction information is composed of the reference frame index and the residual motion vector. The motion vector predictor is added to the residual of the motion vector to obtain the motion vector by the motion vector decoding module 70. The motion vector decoding module 70 applies the motion vector decoding to each current block encoded by the motion prediction. Once the index of the motion vector predictor (for the current block) has been obtained, the actual value of the motion vector associated with the current block can be decoded and used by the module 66 to apply anti-motion compensation. The part of the reference image indicated by the decoded motion vector is extracted from the reference image 68 to apply anti-motion compensation 66. The motion vector field data 71 is updated to use the decoded motion vector for subsequent reverse prediction of the decoded motion vector. Finally, the decoded block is obtained. The post-filtering is applied by the post-filtering module 67. The decoded video signal 69 is finally provided by the decoder 60. Fig. 6 illustrates the organization of the bit stream in an exemplary coding system VVC, as described in JVET-Q2001-vD. The bit stream 61 according to the VVC coding system is composed of a sequential sequence of syntax elements and coded data. Syntax elements and coded data are placed into network abstraction layer (NAL) units 601-608. There are different NAL unit types. The network abstraction layer provides the ability to encapsulate the bit stream into different protocols, such as RTP/IP, which stands for real-time protocol/Internet protocol, ISO basic media file format, and so on. The network abstraction layer also provides a framework for packet loss resilience. NAL units are divided into video coding layer (VCL) NAL units and non-VCL NAL units. The VCL NAL unit contains the actual encoded video data. Non-VCL NAL units contain additional information. This additional information can be parameters required for the decoding of the encoded video data or supplementary data that can improve the usability of the decoded video data. The NAL unit 606 corresponds to a slice and constitutes a VCL NAL unit of the bit stream. Different NAL units 601-605 correspond to different parameter sets, and these NAL units are non-VCL NAL units. The Decoder Parameter Set (DPS) NAL unit 301 contains its constant parameters for a given decoding procedure. The Video Parameter Set (VPS) NAL unit 602 contains parameters defined for the complete video (and therefore the complete bitstream). The DPS NAL unit can define more static parameters than those in VPS. In other words, the parameters of DPS change less frequently than the parameters of VPS. The sequence parameter set (SPS) NAL unit 603 contains parameters defined for a video sequence. In particular, the SPS NAL unit can define the sub-picture layout and related parameters of the video sequence. The parameters associated with each sub-picture indicate the coding constraints that it applies to the sub-picture. In particular, it includes a flag indicating that its temporal prediction between sub-pictures is limited to data from the same sub-picture. Another flag can enable or disable the loop filter across the sub-picture boundary. The Picture Parameter Set (PPS) NAL unit 604 contains parameters defined for a picture or a group of pictures. The adaptive parameter set (APS) NAL unit 605 contains parameters for the loop filter, usually an adaptive loop filter (ALF) or shaper model (or brightness mapping with chrominance scaling (LMCS) model) or in the slice The scaling matrix used by the order. The syntax of PPS (as proposed in the current version of VVC) includes syntax elements that specify the size of the picture in the luminance sample and also indicate the division of each picture in the tiles and slices. The PPS contains syntax elements, which enable the determination of the slice position in a frame. Because the sub-pictures form a rectangular area in the frame, it can be determined that the group of slices, parts of bricks, or bricks belong to the sub-pictures from the NAL unit of the parameter set. PPS and APS have an ID mechanism to limit the amount of the same PPS transmitted. The main difference between the PPS and the picture header is its transmission. The PPS is usually transmitted to the picture group, compared to the PH which is systematically transmitted to each picture. Therefore, PPS (compared to PH) contains parameters that can be constant for several pictures. The bitstream may also contain Supplemental Enhancement Information (SEI) NAL units (not shown in Figure 6). The generation period of these parameter sets in the bit stream is variable. The VPS defined for the entire bitstream can occur only once in the bitstream. Conversely, the APS defined for slices can occur once for each slice in each picture. In fact, different slices can rely on the same APS, and therefore there are usually fewer APSs than slices in each picture. In particular, APS is defined in the picture header. However, ALP APS can still be defined in the slice header. The access unit delimiter (AUD) NAL unit 607 separates two access units. An access unit is a group of NAL units, which may include one or more coded pictures with the same decoding time stamp. This optional NAL unit only contains one syntax element in the current VVC specification: pic_type, this syntax element. Indicates the slice_type value of all slices of the coded picture in the AU. If pic_type is set equal to 0, the AU only contains inner slices. If it is equal to 1, then it contains P and I slices. If it is equal to 2, then it contains B, P or inner slice. This NAL unit contains only one syntax element, pic-type.
Figure 02_image001
In JVET-Q2001-vD, pic_type is defined as follows: " pic_type indicates that the slice_type value of all slices of the coded picture in the AU containing the AU delimiter NAL unit is listed in Table 2 as the predetermined value of pic_type A member of the set. The value of pic_type should be equal to 0, 1, or 2, in the bit stream of this version of this specification. The other values of pic_type are reserved for future use by ITU‑T | ISO/IEC. Compliant The decoder of this version of this specification should ignore the reserved value of pic_type". rbsp_trailing_bits() is a function that adds bits to align to the end of a bit group. Therefore, after this function, the analyzed bit flow is an integer number of bytes.
Figure 02_image003
The PH NAL unit 608 is a picture header NAL unit, which clusters parameters common to a set of slices of a coded picture. The picture can refer to one or more APSs to indicate AFL parameters, shaper models, and scaling matrices (used by slices of the picture). Each of the VCL NAL units 606 contains slices. The slice can correspond to the whole picture or sub-picture, a single brick or multiple bricks or fragments of bricks. For example, the slice in FIG. 3 contains several bricks 620. A slice is composed of a slice header 610 and an original byte sequence payload RBSP 611 (which contains coded pixel data coded into a code block 640). The syntax of PPS (as proposed in the current version of VVC) includes syntax elements that specify the size of the picture in the luminance sample and also indicate the division of each picture in the tiles and slices. The PPS contains syntax elements, which enable the determination of the slice position in a frame. Because the sub-pictures form a rectangular area in the frame, it can be determined that the group of slices, parts of bricks, or bricks belong to the sub-pictures from the NAL unit of the parameter set. NAL unit slice NAL unit slice layer contains slice header and slice data, as shown in Table 3.
Figure 02_image005
The APS Adaptation Parameter Set (APS) NAL unit 605 is defined in Table 4 showing syntax elements. As depicted in Table 4, there are three possible types of APS provided by the aps_params_type syntax element: ● ALF_AP: for ALF parameters ● LMCS_APS for LMCS parameters ● SCALING_APS for scaling list relative parameters
Figure 02_image007
These three types of APS parameters are discussed in turn as follows: ALF APS ALF parameters are described in the adaptive loop filter data syntax element (Table 5). First, four flags are dedicated to indicate whether the ALF filter is transmitted for luminance and/or chrominance and whether CC-ALF (Cross-Component Adaptive Loop Filtering) is enabled for Cb and Cr components. If the luminance filter flag is enabled, another flag is decoded to know whether the cut value is signaled (alf_luma_clip_flag). Then the number of transmitted filters is decoded using the alf_luma_num_filters_signalled_minus1 syntax element. If necessary, the syntax element " alf_luma_coeff_delta_idx " representing the ALF coefficient difference is decoded for each enabled filter. Then the absolute value and sign of each coefficient of each filter are decoded. If alf_luma_clip_flag is enabled, the cut index of each coefficient of each enabled filter is decoded. In the same way, the ALF chrominance coefficients are decoded (if needed). If for CC-ALF-based Cr or Cb to enable the number of devices to be decoded (alf_cc_cb_mapped_coeff_abs and alf_cc_cb_coeff_sign or severally alf_cc_cr_mapped_coeff_abs and alf_cc_cr_coeff_sign) decoding (alf_cc_cb_filters_signalled_minus1 or alf_cc_cr_filters_signalled_minus1) and the associated filter coefficients
Figure 02_image009
Figure 02_image011
LMCS syntax elements for both luma mapping and chroma scaling The following Table 6 provides all LMCS syntax elements, which are coded to adapt the parameter set (APS) syntax structure, when the aps_params_type parameter is set to 1 (LMCS_APS). Up to four LMCS APS can be used for the coded video sequence, however, only a single LMCS APS can be used for a given picture. These parameters are used to establish the luminance forward and backward mapping functions and the chrominance scaling function.
Figure 02_image013
Scaling list APS The scaling list provides the possibility to update the quantization matrix used for quantization. In VVC, this scaling matrix is signaled in APS, as described in the Scaling List Data Syntax Element (Table 7 Scaling List Data Syntax). The first syntax element indicates whether the scaling matrix is used for the LFNST (Low Frequency Inseparable Transformation) tool, based on the flag scaling_matrix_for_lfnst_disabled_flag . If the scaling list is used for the chroma component ( scaling_list_chroma_present_flag ), the second one is indicated. Then the syntax elements needed to build the scaling matrix are decoded ( scaling_list_copy_mode_flag, scaling_list_pred_mode_flag , scaling_list_pred_id_delta, scaling_list_dc_coef, scaling_list_delta_coef ).
Figure 02_image015
Picture header The picture header is transmitted at the beginning of each picture before other slice data. This is extremely large compared to the previous header in the previous draft of the standard. A complete description of all these parameters can be found in JVET-Q2001-vD. Table 9 shows these parameters in the current picture header decoding syntax. The relevant grammatical elements that can be decoded are related to: ● Use of this picture, reference frame or not ● Picture type ● Output frame ● Number of pictures ● Sub-picture use (if necessary) ● Reference picture list (if necessary) ) ● Color plane (if needed) ● Split update (if the revocation flag is enabled) ● Difference QP parameters (if needed) ● Mobile information parameters (if needed) ● ALF parameters (if needed) ● SAO parameters (if needed) ● quantization parameters (if needed) ● LMCS parameters (if needed) ● scaling list parameters (if needed) ● picture header extension (if needed) ● etc. picture "type" The first flag is gdr_or_irap_pic_flag , which indicates whether the current picture is a resynchronized picture (IRAP or GDR). If this flag is true, gdr_pic_flag is decoded to know whether the current picture is an IRAP or GDR picture. Then ph_inter_slice_allowed_flag is decoded to recognize that inter slices are allowed. When it is allowed, the flag ph_intra_slice_allowed_flag is decoded to know whether the current picture allows intra slices. Next non_reference_picture_flag, and images indicating ph_pic_parameter_set_id ph_pic_order_cnt_lsb PPS ID of the sequence number is decoded. Picture order number provides the number of current pictures. If the picture is a GDR or IRAP picture, the flag no_output_of_prior_pics_flag is decoded. If the picture is GDR, recovery_poc_cnt is decoded. Then, ph_poc_msb_present_flag and poc_msb_val are decoded (if needed). ALF After describing these parameters of important information about the current picture, the set of ALF APS id syntax elements are decoded, if ALF is enabled at the SPS level and if ALF is enabled at the picture header level. Due to the sps_alf_enabled_flag flag, ALF is enabled at the SPS level. And since alf_info_in_ph_flag is equal to 1, ALF transmission is enabled at the picture header level; otherwise (alf_info_in_ph_flag is equal to 0) ALF is transmitted at the slice level. alf_info_in_ph_flag is defined as follows: " alf_info_in_ph_flag equal to 1 indicates that its ALF information exists in the PH syntax structure and does not exist in the slice header, which means PPS without the PH syntax structure . alf_info_in_ph_flag equals 0 indicates that its ALF information does not exist in the PH syntax structure and It can be stored in the slice header, meaning PPS without PH syntax structure .” First, ph_alf_enabled_present_flag is decoded to determine whether ph_alf_enabled_flag should be decoded. If ph_alf_enabled_flag is enabled, ALF is enabled on all slices of the current picture. If ALF is enabled, the amount of ALF APS id of luminance is decoded, using pic_num_alf_aps_ids_luma syntax element. For each APS id, the APS id value of the brightness is decoded " ph_alf_aps_id_luma ". For chroma, the syntax element ph_alf_chroma_idc is decoded to determine whether ALF is enabled for chroma, only for Cr, or only for Cb. If it is enabled, the value of the chroma APS ID is decoded, using the ph_alf_aps_id_chroma syntax element. In this way, the APS ID of the CC-ALF method is decoded (if necessary) in the Cb and/or CR components. LMCS This group of LMCS APS ID syntax elements are then decoded, if the LMCS is enabled at the SPS level. First, ph_lmcs_enabled_flag is decoded to determine whether the LMCS is enabled for the current picture. If the LMCS is enabled, the ID value is decoded ph_lmcs_aps_id . For chroma, only ph_chroma_residual_scale_flag is decoded to enable or disable the method used for chroma. Scaling list The set of APS IDs of the scaling list is then decoded, if the scaling list is enabled at the SPS level. The ph_scaling_list_present_flag is decoded to determine whether the scaling matrix is enabled for the current picture. And the value of APS ID ( ph_scaling_list_aps_id ) is then decoded. Sub-picture The sub-picture parameter is enabled when it is enabled in SPS and if sub-picture id messaging is disabled. It also contains some information about the virtual boundary. For the sub-picture parameters, eight syntax elements are defined:
Figure 02_image017
These sub-picture parameters are followed by pic_output_flag (if it exists). Reference Picture List If the reference picture list is signaled in the picture header (because rpl_info_in_ph_flag is equal to 1), the parameters of the reference picture list are decoded ref_pic_lists() , which contains the following syntax elements:
Figure 02_image019
Figure 02_image021
Segmentation The set of segmentation parameters is decoded (if necessary) and contains the following syntax elements:
Figure 02_image023
The weighted prediction weighted prediction parameter pred_weight_table() is decoded if the weighted prediction method is enabled at the PPS level and if the weighted prediction parameter is signaled in the picture header (wp_info_in_ph_flag is equal to 1). pred_weight_table() contains weighted prediction parameters for list L0 and list L1, when bi-predictive weighted prediction is enabled. When the weighted prediction parameters are transmitted in the picture header, the number of weights for each list is explicitly transmitted as shown in the pred_weight_table() syntax table 8.
Figure 02_image025
Difference QP When the picture is internal, ph_cu_qp_delta_subdiv_intra_slice and ph_cu_chroma_qp_offset_subdiv_intra_slice are decoded (if needed). If inter-slicing is allowed, ph_cu_qp_delta_subdiv_inter_slice and ph_cu_chroma_qp_offset_subdiv_inter_slice are decoded (if needed). Finally, the picture header extension syntax elements are decoded (if needed). All parameters alf_info_in_ph_flag , rpl_info_in_ph_flag , qp_delta_info_in_ph_flag , sao_info_in_ph_flag , dbf_info_in_ph_flag , wp_info_in_ph_flag are transmitted in PPS.
Figure 02_image027
Figure 02_image029
Figure 02_image031
Figure 02_image033
Slice header The slice header is transmitted at the beginning of each slice. The slice header contains about 65 syntax elements. This is extremely large compared to the previous slice header in earlier video coding standards. A complete description of all slice header parameters can be found in JVET-Q2001-vD. Table 10 shows these parameters in the current slice header decoding syntax.
Figure 02_image035
Figure 02_image037
Figure 02_image039
First, picture_header_in_slice_header_flag is decoded to know whether picture_header_structure() exists in the slice header. The slice_subpic_id (if necessary) is then decoded to determine the sub-picture id of the current slice. Then slice_address is decoded to determine the address of the current slice. The slice address is decoded if the current slice mode is rectangular slice mode ( rect_slice_flag is equal to 1) and if the number of slices in the current sub-picture is higher than 1. The slice address can also be decoded if the current slice mode is raster scan mode ( rect_slice_flag is equal to 0) and if the number of tiles in the current picture is higher than 1 based on the variables defined in PPS. num_tiles_in_slice_minus1 is then decoded if the number of tiles in the current picture is greater than one and if the current slice mode is not a rectangular slice mode. In the current VVC draft specification, num_tiles_in_slice_minus1 is defined as follows: " num_tiles_in_slice_minus1 plus 1, when it exists, indicates the number of tiles in the slice. The value of num_tiles_in_slice_minus1 should be in the range of 0 to NumTilesInPic-1 (inclusive)." Then slice_type is defined. decoding. If ALF is enabled at the SPS level ( sps_alf_enabled_flag ) and if ALF is signaled in the slice header (alf_info_in_ph_flag is equal to 0), the ALF information is decoded. This includes a flag indicating that ALF is enabled on the current slice ( slice_alf_enabled_flag ). If it is enabled, if the number of APS ALF IDs ( slice_num_alf_aps_ids_luma ) of the luminance is decoded, then the APS IDs are decoded ( slice_alf_aps_id_luma[i] ). Then slice_alf_chroma_idc is decoded to know whether the ALF is enabled for the chroma component and which chroma component is enabled. Then the APS ID is decoded for chroma slice_alf_aps_id_chroma (if needed). In the same way, slice_cc_alf_cb_enabled_flag is decoded (if necessary) to know whether the CC ALF method is enabled. If CC ALF is enabled, the relevant APS ID of CR and/or CB is decoded, if CC ALF is enabled for CR and/or CB. If the color plane is transmitted independently ( separate_colour_plane_flag is equal to 1), then the colour_plane_id is decoded. When the reference picture list is not transmitted in the picture header ( rpl_info_in_ph_flag is equal to 0) and when the NAL unit is not IDR or if the reference picture list is transmitted to an IDR picture ( sps_idr_rpl_present_flag is equal to 1), the reference picture list parameters are decoded; these The lines are similar to those in the picture header. If the reference picture list is transmitted in the picture header ( rpl_info_in_ph_flag is equal to 1) or the NAL unit is not IDR or if the reference picture list is transmitted in an IDR picture ( sps_idr_rpl_present_flag is equal to 1) and if the number of references in at least one list is higher than 1. If so, the revocation flag num_ref_idx_active_override_flag is decoded. If this flag is enabled, the reference index of each list is decoded. When the slice type is not inner and if needed, cabac_init_flag is decoded. If the reference picture list is transmitted in the slice header and there are other conditions, slice_collocated_from_l0_flag and slice_collocated_ref_idx are decoded. These data are related to CABAC codes and co-located motion vectors. In the same way, when the slice type is not intra, the weighted prediction parameter pred_weight_table() is decoded. slice_qp_delta is decoded if the delta QP information is transmitted in the slice header ( qp_delta_info_in_ph_flag is equal to 0). If necessary, the syntax elements slice_cb_qp_offset , slice_cr_qp_offset , slice_joint_cbcr_qp_offset , cu_chroma_qp_offset_enabled_flag are decoded. If SAO information is transmitted in the slice header ( sao_info_in_ph_flag is equal to 0) and if it is enabled at the SPS level ( sps_sao_enabled_flag ), then the SAO enabled flag is decoded in both luminance and chrominance: slice_sao_luma_flag , slice_sao_chroma_flag . Then the deblocking filter parameter is decoded if it is signaled in the slice header (dbf_info_in_ph_flag is equal to 0). The slice_ts_residual_coding_disabled_flag is systematically decoded to know whether the transform skip residual coding method is enabled for the current slice. If the LMCS is enabled in the picture header ( ph_lmcs_enabled_flag is equal to 1), then the slice_lmcs_enabled_flag is decoded. In the same way, if the scaling list is enabled in the picture header ( phpic_scaling_list_presentenabled_flag is equal to 1), the slice_scaling_list_present_flag is decoded. Then, other parameters are decoded (if needed). The picture header in the slice header uses a special communication method. The picture header (708) can be transmitted inside the slice header (710), as shown in FIG. 7. In this case, there is no NAL unit containing only the picture header (608). The NAL units 701-707 correspond to the respective NAL units 601-607 in FIG. 6. Similarly, the coding brick 720 and the coding block 740 correspond to the blocks 620 and 640 in FIG. 6. Therefore, the explanation of these units and blocks will not be repeated here. This can be enabled in the slice header due to the flag picture_header_in_slice_header_flag. In addition, when the picture header is transmitted inside the slice header, the picture should contain only one slice. Therefore, each picture always has only one picture header. In addition, the flag picture_header_in_slice_header_flag will have the same value for all pictures of CLVS (Coded Layer Video Sequence). It means that all pictures between two IRAPs including the first IRAP have only one slice per picture. Flag is picture_header_in_slice_header_flag defined as follows: "picture_header_in_slice_header_flag equal present slice header syntax structure based PH 0 equal to 1 to indicate its specified picture_header_in_slice_header_flag PH slice header syntax structure is not present in the bit stream conforming to the requirements of the system the value of its picture_header_in_slice_header_flag. should be the same in all of the encoded slice in the CLVS when picture_header_in_slice_header_flag is equal to 1 (for coded slices), the bit stream conforming to the requirements of the system which should equal no nal_unit_type PH_NUT the presence of VCL NAL units in the CLVS when When picture_header_in_slice_header_flag is equal to 0 , all coded slices in the current picture should have picture_header_in_slice_header_flag equal to 0 , and the current PU should have a PH NAL unit. picture_header_structure() contains the syntax elements of picture_rbsp() except for padding bits rbsp_trailing_bits( ). Streaming applications Some streaming applications only extract certain parts of the bitstream. These extractions can be space (such as sub-pictures) or time (sub-parts of a video sequence). These extracted parts can then be combined with other bit streams. Some others reduce the frame rate by extracting only some frames. Generally, the main purpose of these streaming applications is to use the maximum allowable bandwidth to produce the maximum quality for end users. In VVC, the APS ID number has been restricted to reduce the frame rate, so that the new APS id number of a frame cannot be used for frames at higher levels in the time hierarchy. However, for streaming applications that extract the part of the bitstream, the APS ID needs to be tracked to determine which APS should be kept in the group part of the bitstream, because the box (such as IRAP) does not reset the number of the APS ID. LMCS (Luminance Mapping with Chroma Scaling) Luminance Mapping with Chroma Scaling (LMCS) technology is a method of sample value conversion applied on a block, in which loop filters are applied to video decoders (such as VVC) Middle front. LMCS can be divided into two sub-tools. The first one is applied to the luminance block and the second sub-tool is applied to the chrominance block, as described below: 1) The first sub-tool is based on the loop of the luminance component of the adaptive piecewise linear model Mapping. The mapping of the luminance component in the loop adjusts the dynamic range of the input signal, and the compression efficiency is improved by redistributing the codeword across the dynamic range. The brightness mapping system uses the forward mapping function to enter the "mapping domain" and the corresponding anti-mapping function to return to the "input domain". 2) The second sub-tool is related to the chrominance component, in which the luminance-dependent residual chrominance scaling is applied. The chrominance residual scaling is designed to compensate for the interaction between the luminance signal and its corresponding chrominance signal. The chroma residual scaling depends on the average value of the reconstructed adjacent luminance samples on the top and/or left side of the current block. Like most other tools in video encoders (such as VVC), LMCS can be enabled/disabled at the sequence level (using the SPS flag). Whether the chroma residual scaling is enabled is also signaled at the slice level. If luminance mapping is enabled, an additional flag is signaled to indicate whether luminance-dependent chrominance residual scaling is enabled. When the luminance mapping is not used, the luminance-dependent chrominance residual scaling is completely disabled. In addition, the luminance-dependent residual scaling of chrominance is always excluded from chrominance blocks whose size is less than or equal to 4. Figure 8 shows the principle of LMCS as explained above for the luminance mapping sub-tool. The shaded block in Figure 8 is the new LMCS functional block, including the forward and reverse mapping of the luminance signal. It is important to note that when using LMCS, some decoding operations are applied to the "mapping domain". These operations are represented by the dashed blocks in FIG. 8. It usually corresponds to the steps of inverse quantization, inverse transformation, intra-luminance prediction and reconstruction, which consist in adding luminance residuals to luminance prediction. On the contrary, the solid line block in FIG. 8 indicates that the decoding process is applied to the original (ie, unmapped) domain, and this includes loop filtering (such as deblocking, ALF, and SAO), motion compensation prediction, and The decoded picture is stored as a reference picture (DPB). Figure 9 shows a similar graph to Figure 8, but this time this is the chroma scaling sub-tool for the LMCS tool. The shaded block in Fig. 9 is a new LMCS functional block, which includes brightness-dependent chrominance scaling procedures. However, in chromaticity, there are some important differences compared to the brightness situation. Here, only the inverse quantization and inverse transformation (represented by the dashed block) are performed in the "mapping domain" of the chrominance sample. All other steps of chroma prediction, motion compensation, and loop filtering are performed in the original domain. As shown in Figure 9, there is only one scaling procedure and no forward and reverse processing such as brightness mapping. By using a piecewise linear model of brightness mapping. The brightness mapping sub-tool uses a piecewise linear model. It means that the piecewise linear model separates the dynamic range of the input signal into 16 equal sub-ranges; and for each sub-range, its linear mapping parameter is expressed using the number of codewords assigned to the range. The semantic syntax element lmcs_min_bin_idx of the luminance mapping indicates the minimum bin index used in the luminance mapping by the chrominance scaling (LMCS) construction procedure. The value of lmcs_min_bin_idx should be in the range of 0 to 15 (inclusive). The syntax element lmcs_delta_max_bin_idx indicates the difference value between 15 and the bin index LmcsMaxBinIdx used in the luminance mapping by the chrominance scaling construction process. The value of lmcs_delta_max_bin_idx should be in the range of 0 to 15 (inclusive). The value of LmcsMaxBinIdx is set equal to 15- lmcs_delta_max_bin_idx . The value of LmcsMaxBinIdx should be greater than or equal to lmcs_min_bin_idx . The syntax element lmcs_delta_cw_prec_minus1 plus 1 indicates the number of bits used for the representation of the syntax lmcs_delta_abs_cw[ i ]. The syntax element lmcs_delta_abs_cw[ i] indicates the absolute difference codeword value of the i-th division. The syntax element lmcs_delta_sign_cw_flag[ i] indicates the sign of the variable lmcsDeltaCW[ i ]. When lmcs_delta_sign_cw_flag[i] does not exist, it is inferred to be equal to 0. LMCS Intermediate Variable Calculation for Luminance Mapping In order to apply forward and reverse luminance mapping processing, some intermediate variables and data arrays are required. First, the variable OrgCW is derived as follows:
Figure 02_image041
Then, the variable lmcsDeltaCW[ i ], where i=lmcs_min_bin_idx.. LmcsMaxBinIdx, is calculated as follows:
Figure 02_image043
The new variable lmcsCW[ i] is derived as follows:-For i = 0.. lmcs_min_bin_idx-1, lmcsCW[ i] is set equal to 0. -For i = lmcs_min_bin_idx..LmcsMaxBinIdx, the following applies: lmcsCW[ i] = OrgCW + lmcsDeltaCW[ i] lmcsCW[ i] should be between (OrgCW>>3) to (OrgCW<<3-1) (inclusive) In the range. -For i = LmcsMaxBinIdx + 1..15, lmcsCW[ i] is set equal to 0. The variable InputPivot[ i ], where i = 0..16, is derived as follows:
Figure 02_image045
The variables LmcsPivot[ i] (where i = 0..16), the variables ScaleCoeff[ i] and InvScaleCoeff[ i] (where i = 0..15) are calculated as follows:
Figure 02_image047
The forward luminance mapping is shown in Figure 8. When the LMCS is applied to the luminance, the luminance remapping samples called predMapSamples[i][j] are obtained from the prediction samples predSamples[i][j] . predMapSamples[i][j] is calculated as follows: First, the index idxY is calculated from the prediction sample predSamples[ i ][ j ] , at position (i, j). idxY = predSamples[ i ][ j] >> Log2( OrgCW) Next, predMapSamples[i][j] is derived by using the intermediate variables idxY, LmcsPivot[ idxY] and InputPivot[ idxY] of paragraph 0 as follows:
Figure 02_image049
The luminance reconstruction sample reconstruction procedure is obtained from the predicted luminance sample predMapSample[i][j] and the residual luminance sample resiSamples[i][j] . The reconstructed luminance image sample recSamples [i ][ j] is simply obtained by adding predMapSample[i][j] to resiSamples[i][j] as follows:
Figure 02_image051
In the above-mentioned relational expression, the Clip 1 function is a cutting function to ensure that the reconstructed sample is between 0 and 1<<BitDepth -1. Inverse luminance mapping When applying inverse luminance mapping according to Figure 8, the following operations are applied to each sample recSample[i][j] of the current block under processing: First, the index idxY is calculated from the reconstructed sample recSamples[ i ][ j] , at position (i, j).
Figure 02_image053
The inverse mapping luminance sample invLumaSample[i][j] is derived based on it as follows:
Figure 02_image055
The cutting operation is then executed to obtain the final sample:
Figure 02_image057
The LMCS semantics of chrominance expansion and contraction is the syntax element lmcs_delta_abs_crs in Table 6 indicating the absolute difference codeword value of the variable lmcsDeltaCrs. The value of lmcs_delta_abs_crs should be in the range of 0 to 7 (inclusive). When it does not exist, the value of lmcs_delta_abs_crs is inferred to be equal to zero. The syntax element lmcs_delta_sign_crs_flag indicates the sign of the variable lmcsDeltaCrs. When not present, lmcs_delta_sign_crs_flag is inferred to be equal to 0. LMCS intermediate variable calculation for chroma scaling In order to apply the chroma scaling procedure, some intermediate variables are required. The variable lmcsDeltaCrs is derived as follows:
Figure 02_image059
The variable ChromaScaleCoeff[ i ] , where i = 0...15, is derived as follows:
Figure 02_image061
In the first step of the chrominance scaling procedure, the variable invAvgLuma is derived to calculate the average luminance value of the reconstructed luminance samples around the current corresponding chrominance block. The average brightness is calculated from the left and top brightness blocks surrounding the corresponding chrominance block. If no samples are available, the variable invAvgLuma is set as follows:
Figure 02_image063
Based on the middle array LmcsPivot[] of paragraph 0, the variable idxYInv is then derived as follows:
Figure 02_image065
The variable varScale is exported as follows:
Figure 02_image067
When the transformation is applied to the current chrominance block, the reconstructed chrominance image sample array recSamples is derived as follows:
Figure 02_image069
If no transformation has been applied to the current block, the following applies:
Figure 02_image071
The encoder considers that the basic principle of the LMCS encoder is to first assign more codewords to the range in which those dynamic range segments have codewords with lower than the average variance. In this alternative formula, the main goal of LMCS is to assign fewer codewords to those dynamic range segments that have codewords higher than the average variance. In this way, smooth areas of the picture will be encoded with more codewords than average, and vice versa. All the parameters of the LMCS stored in the APS (see Table 6) are determined on the encoder side. The LMCS encoder algorithm is based on the evaluation of the local luminance variance, and is based on the above basic principles to optimize the determination of LMCS parameters. The optimization is then performed to obtain the best PSNR matrix of the final reconstructed sample of the given block. Embodiment Avoid slice address syntax when not needed. In one embodiment, when the picture header is signaled in the slice header, the slice address syntax element (slice_address) is inferred to be equal to the value 0, even if the number of tiles is greater than 1. . Table 11 shows this embodiment. The advantage of this embodiment is that when the picture header is in the slice header with reduced bit rate, the slice address is not parsed, especially for low-latency and low-bit-rate applications; and it reduces the complexity of parsing. Some implementations when the picture is sent in the slice header. In one embodiment, this is only applied to raster scan slice mode ( rect_slice_flag is equal to 0). This reduces the analysis complexity of some implementations.
Figure 02_image073
Avoiding the transmission of the number of tiles in the slice when not needed. In one embodiment, when the picture header is transmitted in the slice header, the number of tiles in the slice is not transmitted. Table 12 illustrates this embodiment, where when the flag picture_header_in_slice_header_flag is set equal to 1, the num_tiles_in_slice_minus1 syntax element is not transmitted. The advantage of this embodiment is that the bit rate is reduced, especially for low latency and low bit rate applications, because the number of bricks does not need to be transmitted. In one embodiment, this is only applied to raster scan slice mode ( rect_slice_flag is equal to 0). This reduces the analysis complexity of some implementations.
Figure 02_image075
Predicted by the PPS value NumTilesInPic (semantic) in an additional embodiment, when the picture header is transmitted in the slice header, the number of tiles in the current slice is inferred to be equal to the number of tiles in the picture. This can be set by adding the following sentence to the semantics of the grammatical element num_tiles_in_slice_minus1 : " When it does not exist, the variable num_tiles_in_slice_minus1 is set equal to NumTilesInPic-1 ." The variable NumTilesInPic gives the maximum number of tiles in the picture. This variable is calculated based on the syntax elements transmitted in PPS. Set the number of tiles before the slice address and avoid unnecessary transmission of slice_address. In one embodiment, the syntax element dedicated to the number of tiles in the slice is transmitted before the slice address, and its value is used to know whether decoding is required The slice address. More precisely, the number of tiles in the slice is compared with the number of tiles in the picture to know whether the slice address needs to be decoded. Indeed, if the number of tiles in the slice is equal to the number of tiles in the picture, it is confirmed that the current picture contains only one slice. In one embodiment, this is only applied to raster scan slice mode ( rect_slice_flag is equal to 0). This reduces the analysis complexity of some implementations. Table 13 shows this embodiment. If the syntax element num_tiles_in_slice_minus1 is equal to the variable NumTilesInPic minus 1, the syntax element slice_address is not decoded. When um_tiles_in_slice_minus1 is equal to the variable NumTilesInPic minus 1, then slice_address is inferred to be equal to 0.
Figure 02_image077
The advantage of this embodiment is that the bit rate is reduced and the analysis complexity is reduced. When the condition is set equal to true, the slice address is not transmitted. In an embodiment, the syntax element indicating the number of tiles in the current slice is not decoded and the number of tiles in the slice is deduced to be equal to 1, when the picture header is transmitted in the slice header. And the slice address is inferred to be equal to 0, and the related syntax elements are not decoded, when the number of tiles in the slice is equal to the number of tiles in the picture. Table 14 shows this embodiment. Such an increase reduces the bit rate obtained by the combination of the two embodiments.
Figure 02_image079
Remove the unnecessary condition numTileInPic> 1 In one embodiment, the current condition that the number of tiles in the picture needs to be greater than 1 does not need to be tested (when the raster scan slice mode is enabled), in order to enable the syntax elements slice_address and/or The number of tiles in the current slice is decoded. Specifically, when the number of tiles in the current picture is equal to 1, the rect_slice_flag value is deduced to be equal to 1. As a result, the raster scan slice mode cannot be enabled in this case. Table 15 shows this embodiment. This embodiment reduces the parsing complexity of the slice header.
Figure 02_image081
In an embodiment, the syntax element indicating the number of tiles in the current slice is not decoded and the number of tiles in the slice is deduced to be equal to 1, when the picture header is transmitted in the slice header and when the raster scan slice mode is When enabled. And the slice address is inferred to be equal to 0, and the related syntax element slice_address is not decoded, when the number of tiles in the slice is equal to the number of tiles in the picture, and when the raster scan slice mode is enabled. Table 16 shows this embodiment. The advantages are reduced bit rate and reduced analysis complexity.
Figure 02_image083
Embodiment FIG. 11 shows a system 191, 195, which includes at least one of an encoder 150 or a decoder 100 and a communication network 199, according to an embodiment of the present invention. According to one embodiment, the system 195 is used to process and provide content (for example, video and audio content for display/output or streaming video/audio content) to the user, which can be accessed to the decoder 100, for example, through The user interface of a user terminal including the decoder 100 or a user terminal that can communicate with the decoder 100. This user terminal can be a computer, a mobile phone, a tablet, or any other type of device capable of providing/displaying (provided/streamed) content to the user. The system 195 obtains/receives the bit stream 101 via the communication network 199 (in the form of a continuous stream or signal-for example, when the earlier video/audio is displayed/output). According to one embodiment, the system 191 is used to process content and store processed content, such as processed video and audio content for display/output/streaming at a later time. The system 191 obtains/receives the content of the original sequence containing the image 151, which is received and processed by the encoder 150 (including filtering using the deblocking filter according to the present invention), and the encoder 150 generates a bit stream 101, which will pass The communication network 191 is transmitted to the decoder 100. The bit stream 101 is then delivered to the decoder 100 in several ways. For example, it can be generated by the encoder 150 in advance and stored as data in a storage device in the communication network 199 (for example, in a server or cloud storage). (Top) Until the user requests the content (ie, bitstream data) from the storage device, at this moment the data is transferred/streamed from the storage device to the decoder 100. The system 191 may also include a content providing device for providing/streaming to the user (for example, by transmitting data to the user interface for display on the user terminal), and for storing content stored in the device Information (for example, the name of the content and other meta/storage location data used to identify, select, and request the content), and used to receive and process user requests for a content so that the requested content can be delivered from the storage device /Stream to the user terminal. Alternatively, the encoder 150 generates the bitstream 101 and transmits/streams it directly to the decoder 100, such as when the user requests the content. The decoder 100 then receives the bit stream 101 (or signal) and uses the deblocking filter according to the present invention to perform filtering to obtain/generate a video signal 109 and/or audio signal, which is then used by the user terminal to provide The content of the request is given to the user. Any step of the method/program according to the present invention or the function described in the text can be implemented with hardware, software, firmware, or any combination thereof. If implemented in software, these steps/functions can be stored or transmitted through, become one or more commands or codes or programs, or computer readable media, and be executed in one or more hardware-based processes Units (such as programmable computing machines), which can be PCs ("personal computers"), DSPs ("digital signal processors"), circuits, circuit systems, processors and memories, general-purpose microprocessors or central processing units, Microcontrollers, ASICs ("application-specific integrated circuits"), field programmable logic arrays (FPGAs), or other equivalent integrated or discrete logic circuits. Therefore, the term "processor" as used in the text can refer to any of the foregoing structures or any other structure suitable for the implementation of the technology described in the text. The embodiments of the present invention can also be implemented by a variety of devices or devices, including wireless mobile phones, integrated circuits (ICs), or a set of JCs (for example, chipsets). Various components, modules, and units are described in the text to clarify that they are configured to fulfill the functional aspects of the devices/equipment of those embodiments, but they do not necessarily need to be implemented by different hardware units. Conversely, various modules/units can be combined in the codec hardware unit or provided by a collection of interoperable hardware units, including one or more processors combined with appropriate software/firmware. The embodiments of the present invention can be implemented by a computer of a system or device. The computer reads and executes computer-executable instructions (for example, one or more programs) recorded on a storage medium to perform one of the above-mentioned embodiments or Multiple modules/units/functions; and/or it includes one or more processing units or circuits to perform one or more of the functions of the above-mentioned embodiments; and can be implemented by a method performed by the computer of the system or device Implementation, by, for example, reading out and executing computer-executable instructions from a storage medium to perform the functions of one or more of the above-mentioned embodiments and/or control one or more processing units or circuits to perform one or more of the above-mentioned embodiments The function of more. The computer may include a network of separate computers or separate processing units to read and execute computer-executable instructions. Computer-executable instructions can be provided to the computer, for example, from a computer-readable medium (such as a communication medium), via a network or a tangible storage medium. The communication medium can be a signal/bit stream/carrier. Tangible storage media are "non-transitory computer-readable storage media", which can include, for example, hard disks, random access memory (RAM), read-only memory (ROM), storage for distributed computing systems, optical discs (Such as compact disc (CD), digital versatile disc (DVD), or Blu-ray Disc (BD)™), flash memory device, memory card, etc. one or more. At least some of the steps/functions can also be implemented in hardware, by machines or dedicated components, such as FPGA ("Field Programmable Gate Array") or ASIC ("Application Specific Integrated Circuit"). FIG. 12 is a schematic block diagram of a computing device 2000 for implementing one or more embodiments of the present invention. The computing device 2000 may be a device, such as a microcomputer, a workstation, or a light portable device. The computing device 2000 includes a communication bus connected to the following:-a central processing unit (CPU) 2001, such as a microprocessor;-a random access memory (RAM) 2002, used to store the data of the method of the embodiment of the present invention The execution code and the register are adapted to record the variables and parameters needed to implement the method. The method is to encode or decode at least part of the image according to the embodiment of the present invention. The memory capacity can be connected to (For example) Optional RAM for expansion ports to expand;-Read only memory (ROM) 2003, used to store computer programs for implementing embodiments of the present invention;-Network interface (NET) 2004, usually connected to a communication network , The digital data to be processed is transmitted or received through the network interface. The network interface (NET) 2004 can be a single network interface or a collection of different network interfaces (such as wired and wireless interfaces, or different types of wired or wireless interfaces). Data packets are written to the network interface for transmission or read from the network interface for reception, under the control of the software application running in the CPU 2001;-the user interface (UI) 2005 can be used from the user Receiving input or displaying information to the user;-Hard disk (HD) 2006, which can be provided as a mass storage device;-Input/output module (IO) 2007, which can be used to receive/transmit data from/to external devices, such as Video source or display. The executable code can be stored in ROM 2003, on HD 2006, or on removable digital media (such as, for example, a magnetic disk). According to a variant, the executable code of the program can be received via the communication network, and stored in one of the storage mechanisms (such as HD 2006) of the communication device 2000 via the NET 2004 before execution. The CPU 2001 is adapted to control and direct the execution of instructions or software code portions of programs or most programs according to the embodiments of the present invention, and these instructions are stored in one of the aforementioned storage mechanisms. After booting, the CPU 2001 can execute commands from the main RAM memory 2002 related to the software application, after those commands have been loaded from, for example, the program ROM 2003 or HD 2006. This software application (when executed by the CPU 2001) causes the steps of the method according to the present invention to be performed. It should also be understood that according to another embodiment of the present invention, a decoder according to the foregoing embodiment is provided in a user terminal, such as a computer, a mobile phone (cellular phone), a tablet, or any other type of device (for example, a display Equipment), which can provide/display content to users. According to yet another embodiment, an encoder according to the foregoing embodiment is provided in an image capturing device, which also includes a camera, a video camera, or a web camera (for example, a closed-circuit television or a video surveillance camera), which captures And provide content to the encoder to encode. Two such examples are provided below with reference to FIGS. 13 and 14. Network Camera FIG. 13 is a diagram showing a network camera system 2100 including a network camera 2102 and a client device 2104. The web camera 2102 includes an imaging unit 2106, an encoding unit 2108, a communication unit 2110, and a control unit 2112. The web camera 2102 and the client device 2104 are connected to each other to be able to communicate with each other via the network 200. The imaging unit 2106 includes a lens and an image sensor (for example, a charge coupled device (CCD) or a complementary metal oxide semiconductor (CMOS)), and captures an image of an object and generates image data based on the image. This image can be a still image or a video image. The encoding unit 2108 encodes image data by using the above-mentioned encoding method. The communication unit 2110 of the web camera 2102 transmits the encoded image data encoded by the encoding unit 2108 to the client device 2104. Furthermore, the communication unit 2110 receives commands from the client device 2104. These commands include commands for setting coding parameters of the coding unit 2108. The control unit 2112 controls other units in the network camera 2102 according to the commands received by the communication unit 2110. The client device 2104 includes a communication unit 2114, a decoding unit 2116, and a control unit 2118. The communication unit 2114 of the client device 2104 transmits the command to the web camera 2102. Furthermore, the communication unit 2114 of the client device 2104 receives the encoded image data from the web camera 2102. The decoding unit 2116 decodes the encoded image data by using the above-mentioned decoding method. The control unit 2118 of the client device 2104 controls other units in the client device 2104 according to user operations or commands received by the communication unit 2114. The control unit 2118 of the client device 2104 controls the display device 2120 to display the image decoded by the decoding unit 2116. The control unit 2118 of the client device 2104 also controls the display device 2120 to display a GUI (graphical user interface) to specify the values of the parameters for the web camera 2102, including the parameters for the encoding of the encoding unit 2108. The control unit 2118 of the client device 2104 also controls other units in the client device 2104 according to user operations input to the GUI displayed by the display device 2120. The control unit 2119 of the client device 2104 controls the communication unit 2114 of the client device 2104 to transmit a command to the web camera 2102, which specifies the value of the parameter for the web camera 2102, based on the input displayed by the display device 2120 to the GUI.者OPERATION. Smart phone FIG. 14 shows a figure of a smart phone 2200. The smart phone 2200 includes a communication unit 2202, a decoding unit 2204, a control unit 2206, a display unit 2208, an image recording device 2210, and a sensor 2212. The communication unit 2202 receives the encoded image data via the network 200. The decoding unit 2204 decodes the encoded image data received by the communication unit 2202. The decoding unit 2204 decodes the encoded image data by using the above-mentioned decoding method. The control unit 2206 controls other units in the smartphone 2200 according to user operations or commands received by the communication unit 2202. For example, the control unit 2206 controls the display unit 2208 to display the image decoded by the decoding unit 2204. Although the present invention has been described with reference to the embodiments, it should be understood that the present invention is not limited to the disclosed exemplary embodiments. Those familiar with the art should understand that various changes and modifications can be made without departing from the scope of the present invention, as defined in the scope of the appended patent application. All the features disclosed in this specification (including any accompanying patent scope, abstract and drawings), and/or any method or procedure steps disclosed, can be combined in any combination, except for these features and/or At least part of the steps are outside of mutually exclusive combinations. The features disclosed in this specification (including any accompanying patent scope, abstract and drawings) can be replaced with alternative features, which are applicable to the same, equivalent or similar purpose, unless expressly stated otherwise. Therefore, unless expressly stated otherwise, the disclosed features are only an example of a general sequence of equivalent or similar features. It should also be understood that any result of the above comparison, determination, evaluation, selection, execution, fulfillment, or consideration (for example, a selection made during the encoding or filtering process) can be indicated or determinable/reasonable from the bit stream. Data (such as a flag or data indicating the result) so that the indicated or determined/reasoned result can be used in the processing, instead of actually performing comparison, determination, evaluation, selection, execution, performance, or consideration (For example, during the decoding process). In the scope of the patent application, the word "include" does not exclude other elements or steps, and the indefinite article "一(a)" or "一(an)" does not exclude the plural. The mere fact that different features are stated in the scope of patent applications for different appendages does not indicate that the combination of these features cannot be used to advantage. The reference numbers appearing in the scope of the patent application are only for clarification and shall have no restrictive effect on the scope of the patent application.

1:視頻序列 2:影像 3:切片 5:編碼單元(CU) 60:解碼器 61:位元流 62:模組 63:模組 64:模組 65:內反預測模組 66:模組 67:後過濾模組 68:參考影像 69:視頻信號 70:移動向量解碼模組 71:移動向量場資料 100:解碼器 101:位元流 109:視頻信號 150:編碼器 151:影像 191, 195:系統 199:通訊網路 200:資料通訊網路 201:伺服器 202:客戶終端 204:資料流 300:處理裝置 302:通訊介面 303:通訊網路 304:資料儲存機構 305:磁碟驅動 306:磁碟 308:麥克風 309:螢幕 310:鍵盤 311:中央處理單元 312:隨機存取記憶體 313:通訊匯流排 320:數位相機 400:編碼器 401:數位影像i 0至in402:模組 403:模組 404:移動估計模組 405:移動補償模組 406:選擇模組 407:變換模組 408:量化模組 409:熵編碼模組 410:位元流 411:反量化模組 412:反變換模組 413:反內預測模組 414:反移動補償模組 415:模組 416:參考影像 417:移動向量預測及編碼模組 418:移動向量場 601~608:網路抽象化層(NAL)單元 610:切片標頭 611:原始位元組序列酬載RBSP 620:磚 640:編碼區塊 701~707:NAL單元 708:圖片標頭 710:切片標頭 720:磚 740:編碼區塊 2000:計算裝置 2001:中央處理單元(CPU) 2002:隨機存取記憶體(RAM) 2003:唯讀記憶體(ROM) 2004:網路介面(NET) 2005:使用者介面(UI) 2006:硬碟(HD) 2007:輸入/輸出模組(IO) 2100:網路相機系統 2102:網路相機 2104:客戶設備 2106:成像單元 2108:編碼單元 2110:通訊單元 2112:控制單元 2114:通訊單元 2116:解碼單元 2118:控制單元 2120:顯示設備 2200:智慧型手機 2202:通訊單元 2204:解碼/編碼單元 2206:控制單元 2208:顯示單元 2210:影像記錄裝置 2212:感測器1: Video sequence 2: Image 3: Slice 5: Coding unit (CU) 60: Decoder 61: Bit stream 62: Module 63: Module 64: Module 65: Inverse prediction module 66: Module 67 : Post-filtering module 68: Reference image 69: Video signal 70: Motion vector decoding module 71: Motion vector field data 100: Decoder 101: Bit stream 109: Video signal 150: Encoder 151: Image 191, 195: System 199: Communication network 200: Data communication network 201: Server 202: Client terminal 204: Data stream 300: Processing device 302: Communication interface 303: Communication network 304: Data storage mechanism 305: Disk drive 306: Disk 308: Microphone 309: Screen 310: Keyboard 311: Central Processing Unit 312: Random Access Memory 313: Communication Bus 320: Digital Camera 400: Encoder 401: Digital Image i 0 to i n402: Module 403: Module 404: Motion estimation module 405: Motion compensation module 406: Selection module 407: Transformation module 408: Quantization module 409: Entropy coding module 410: Bit stream 411: Inverse quantization module 412: Inverse transformation module 413: Inverse intra prediction module 414: Inverse motion compensation module 415: Module 416: Reference image 417: Motion vector prediction and coding module 418: Motion vector field 601~608: Network abstraction layer (NAL) unit 610: Slice Header 611: Original byte sequence payload RBSP 620: Brick 640: Coding block 701~707: NAL unit 708: Picture header 710: Slice header 720: Brick 740: Coding block 2000: Computing device 2001: Central Processing Unit (CPU) 2002: Random Access Memory (RAM) 2003: Read Only Memory (ROM) 2004: Network Interface (NET) 2005: User Interface (UI) 2006: Hard Disk (HD) 2007: Input/Output Module (IO) 2100: Web Camera System 2102: Web Camera 2104: Client Equipment 2106: Imaging Unit 2108: Encoding Unit 2110: Communication Unit 2112: Control Unit 2114: Communication Unit 2116: Decoding Unit 2118: Control Unit 2120: display device 2200: smartphone 2202: communication unit 2204: decoding/encoding unit 2206: control unit 2208: display unit 2210: image recording device 2212: sensor

現在將(以範例方式)參考附圖,其中: [圖1]係用以解釋HEVC及VVC中所使用之編碼結構的圖形; [圖2]係概略地繪示一資料通訊系統之方塊圖,其中本發明之一或更多實施例可被實施; [圖3]係繪示一處理裝置之組件的方塊圖,其中本發明之一或更多實施例可被實施; [圖4]係一流程圖,其繪示一種依據本發明之實施例的編碼方法之步驟; [圖5]係一流程圖,其繪示一種依據本發明之實施例的解碼方法之步驟; [圖6]繪示範例編碼系統VVC中之位元流的結構。 [圖7]繪示範例編碼系統VVC中之位元流的另一結構; [圖8]繪示亮度模擬色度擴縮(LMCS); [圖9]顯示LMCS之子工具; [圖10]係目前VVC草案標準之光柵掃描切片模式及矩形切片模式的圖示; [圖11]係顯示一系統之一圖形,該系統包含依據本發明之實施例的一編碼器或一解碼器及一通訊網路。 [圖12]為一用於實施本發明之一或更多實施例的計算裝置之概略方塊圖; [圖13]為繪示網路相機系統之圖形;及 [圖14]為繪示智慧型手機之圖形。Reference will now be made (by way of example) to the attached drawings, in which: [Fig. 1] It is a graph to explain the coding structure used in HEVC and VVC; [Figure 2] is a block diagram schematically showing a data communication system in which one or more embodiments of the present invention can be implemented; [Figure 3] is a block diagram showing the components of a processing device in which one or more embodiments of the present invention can be implemented; [Figure 4] is a flowchart showing the steps of an encoding method according to an embodiment of the present invention; [Figure 5] is a flowchart showing the steps of a decoding method according to an embodiment of the present invention; [Figure 6] shows the structure of the bit stream in an exemplary coding system VVC. [Fig. 7] shows another structure of the bit stream in an exemplary coding system VVC; [Figure 8] shows the luminance simulation chrominance scaling (LMCS); [Figure 9] Shows the child tool of LMCS; [Figure 10] is the diagram of the raster scan slice mode and rectangular slice mode of the current VVC draft standard; [Figure 11] shows a diagram of a system including an encoder or a decoder and a communication network according to an embodiment of the present invention. [Figure 12] is a schematic block diagram of a computing device for implementing one or more embodiments of the present invention; [Figure 13] is a diagram showing the network camera system; and [Figure 14] shows the graphics of a smart phone.

1:視頻序列 1: video sequence

2:影像 2: image

3:切片 3: slice

5:編碼單元(CU) 5: Coding Unit (CU)

Claims (21)

一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚, 其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,其中該方法包含 剖析該等語法元素,以及 在其中一圖片包括多數磚的情況下,假如被剖析之一語法元素指示其一圖片標頭被傳訊在該切片標頭中的話則省略指示一切片之一位址的一語法元素之剖析;及 使用該等語法元素以解碼該位元流。A method for decoding video data from a bitstream, the bitstream contains video data corresponding to one or more slices, where each slice may include one or more tiles, The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when decoding slices. , Where the method contains Analyze these grammatical elements, and In the case that one of the pictures includes a plurality of tiles, if a syntax element being parsed indicates that a picture header is transmitted in the slice header, the analysis of a syntax element indicating an address of all slices is omitted; and The syntax elements are used to decode the bitstream. 如請求項1之方法,其中當一光柵掃描切片模式將被用於解碼該切片時,該省略將被履行。Such as the method of claim 1, wherein when a raster scan slice mode is to be used to decode the slice, the omission will be fulfilled. 如請求項1或2之方法,其中該省略進一步包含省略指示該切片中之磚數目的一語法元素之剖析。Such as the method of claim 1 or 2, wherein the omission further includes the omission of parsing of a syntax element indicating the number of tiles in the slice. 一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚, 其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,且該解碼包含: 剖析一或多個語法元素,以及 在其中一圖片包括多數磚的情況下,假如被剖析之一語法元素指示其該圖片標頭被傳訊在該切片標頭中的話則省略指示該切片中之磚數目的一語法元素之剖析;及 使用該等語法元素以解碼該位元流。A method for decoding video data from a bitstream, the bitstream contains video data corresponding to one or more slices, where each slice may include one or more tiles, The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when decoding slices. , And the decoding includes: Analyze one or more grammatical elements, and In the case where one of the pictures includes a plurality of tiles, if a syntax element being parsed indicates that the picture header is reported in the slice header, the analysis of a syntax element indicating the number of tiles in the slice is omitted; and The syntax elements are used to decode the bitstream. 如請求項4之方法,其中當一光柵掃描切片模式將被用於解碼該切片時,該省略將被履行。Such as the method of claim 4, wherein when a raster scan slice mode is to be used to decode the slice, the omission will be fulfilled. 如請求項4或5之方法,進一步包含剖析指示該圖片中之磚數目的語法元素,及基於由該等經剖析語法元素所指示的該圖片中之該磚數目來判定該切片中之磚數目。For example, the method of claim 4 or 5, further comprising parsing a syntax element indicating the number of tiles in the picture, and determining the number of tiles in the slice based on the number of tiles in the picture indicated by the parsed syntax elements . 如請求項4至6之任一項的方法,其中省略進一步包含省略指示一切片中之一位址的一語法元素之剖析。Such as the method of any one of claims 4 to 6, wherein omitting further includes omitting parsing of a syntax element indicating an address in all slices. 一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之該視頻資料,其中各切片可包括一或多個磚, 其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當編碼一切片時將使用的語法元素,且該編碼包含: 判定用於編碼該視頻資料之一或多個語法元素,以及 在其中一圖片包括多數磚的情況下,假如之一語法元素指示其一圖片標頭被傳訊在該切片標頭中的話則省略指示一切片之一位址的一語法元素之編碼;及 使用該等語法元素以編碼該視頻資料。A method of encoding video data into a bit stream, the bit stream containing the video data corresponding to one or more slices, where each slice may include one or more tiles, The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when encoding slices. , And the code contains: Determine one or more syntax elements used to encode the video material, and In the case that one of the pictures includes a plurality of tiles, if a syntax element indicates that a picture header is signaled in the slice header, the code of a syntax element indicating the address of all slices is omitted; and Use these syntax elements to encode the video data. 如請求項14之方法,其中當一光柵掃描切片模式被用於編碼該切片時,該省略將被履行。Such as the method of claim 14, wherein when a raster scan slice mode is used to encode the slice, the omission will be fulfilled. 如請求項14或15之方法,其中該省略進一步包含省略指示該切片中之磚數目的一語法元素之編碼。Such as the method of claim 14 or 15, wherein the omission further includes omitting the coding of a syntax element indicating the number of tiles in the slice. 一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚, 其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,且該編碼包含: 判定用於編碼該視頻資料之一或多個語法元素,以及 在其中一圖片包括多數磚的情況下,假如經判定用於編碼的一語法元素指示其該圖片標頭被傳訊在該切片標頭中的話則省略指示該切片中之磚數目的一語法元素之編碼;及 使用該等語法元素以編碼該視頻資料。A method of encoding video data into a bit stream, the bit stream containing video data corresponding to one or more slices, where each slice may include one or more tiles, The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when decoding slices. , And the code contains: Determine one or more syntax elements used to encode the video material, and In the case where a picture includes a plurality of tiles, if a syntax element determined to be used for encoding indicates that the picture header is signaled in the slice header, then one of the syntax elements indicating the number of tiles in the slice is omitted. Code; and Use these syntax elements to encode the video data. 如請求項17之方法,其中當一光柵掃描切片模式將被用於編碼該切片時,該省略將被履行。Such as the method of claim 17, wherein when a raster scan slice mode is to be used to encode the slice, the omission will be fulfilled. 如請求項17或18之方法,進一步包含編碼指示該圖片中之磚數目的語法元素,其中該切片中之磚數目係基於由該等經剖析語法元素所指示的該圖片中之該磚數目。The method of claim 17 or 18, further comprising encoding a syntax element indicating the number of tiles in the picture, wherein the number of tiles in the slice is based on the number of tiles in the picture indicated by the parsed syntax elements. 如請求項17至19之任一項的方法,其中省略進一步包含省略指示一切片中之一位址的一語法元素之編碼。The method according to any one of claim items 17 to 19, wherein omitting further includes omitting a code of a syntax element indicating an address in all slices. 一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚, 其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,該位元流被約束以使得 在其中該位元流包括具有指示其一圖片包括多數磚之一值的一語法元素且該位元流包括指示其一圖片標頭被傳訊在該切片標頭中之一語法元素的情況下,該位元流亦包括指示其指示一切片之一位址的一語法元素不被剖析的一語法元素,該方法包含使用該等語法元素來解碼該位元流。A method for decoding video data from a bitstream, the bitstream contains video data corresponding to one or more slices, where each slice may include one or more tiles, The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when decoding slices. , The bit stream is constrained so that In the case where the bitstream includes a syntax element having a value indicating that one of the pictures includes one of the plurality of tiles, and the bitstream includes a syntax element indicating that one of the picture headers is signaled in the slice header, The bitstream also includes a syntax element indicating that a syntax element indicating an address of all slices is not to be parsed, and the method includes using the syntax elements to decode the bitstream. 一種解碼來自一位元流之視頻資料的方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚, 其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,該位元流被約束以使得 在其中該位元流包括具有指示其一圖片包括多數磚之一值的一語法元素且該位元流包括指示其該圖片標頭被傳訊在該切片標頭中之一語法元素的情況下,該位元流亦包括指示其指示該切片之磚數目不應被剖析的一語法元素,該方法包含使用該等語法元素來解碼該位元流。A method for decoding video data from a bitstream, the bitstream contains video data corresponding to one or more slices, where each slice may include one or more tiles, The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when decoding slices. , The bit stream is constrained so that In the case where the bitstream includes a syntax element having a value indicating that a picture includes one of the plurality of tiles, and the bitstream includes a syntax element indicating that the picture header is signaled in the slice header, The bitstream also includes a syntax element indicating that the number of tiles indicating the slice should not be parsed, and the method includes using the syntax elements to decode the bitstream. 一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之該視頻資料,其中各切片可包括一或多個磚, 其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當編碼一切片時將使用的語法元素,該位元流被約束以使得 在其中該位元流包括具有指示其一圖片包括多數磚之一值的一語法元素且該位元流包括指示其一圖片標頭被傳訊在該切片標頭中之一語法元素的情況下,該位元流亦包括指示其指示一切片之一位址的一語法元素不應被剖析的一語法元素;該方法包含使用該等語法元素來編碼該視頻資料。A method of encoding video data into a bit stream, the bit stream containing the video data corresponding to one or more slices, where each slice may include one or more tiles, The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when encoding slices. , The bit stream is constrained so that In the case where the bitstream includes a syntax element having a value indicating that one of the pictures includes one of the plurality of tiles, and the bitstream includes a syntax element indicating that one of the picture headers is signaled in the slice header, The bitstream also includes a syntax element indicating that a syntax element indicating an address of all slices should not be parsed; the method includes using the syntax elements to encode the video data. 一種將視頻資料編碼入一位元流中之方法,該位元流包含相應於一或多個切片之視頻資料,其中各切片可包括一或多個磚, 其中該位元流包含一圖片標頭及一切片標頭,該圖片標頭包含當解碼一或多個切片時將使用的語法元素,該切片標頭包含當解碼一切片時將使用的語法元素,該位元流被約束以使得 在其中該位元流包括具有指示其一圖片包括多數磚之一值的一語法元素且該位元流包括指示其該圖片標頭被傳訊在該切片標頭中之經判定用於編碼的一語法元素之情況下,該位元流亦包括指示其指示該切片中之磚數目的一語法元素不被剖析的一語法元素;該方法包含使用該等語法元素來編碼該視頻資料。A method of encoding video data into a bit stream, the bit stream containing video data corresponding to one or more slices, where each slice may include one or more tiles, The bitstream contains a picture header and a slice header. The picture header contains syntax elements that will be used when decoding one or more slices. The slice header contains syntax elements that will be used when decoding slices. , The bit stream is constrained so that Wherein the bit stream includes a syntax element having a value indicating that one of the pictures includes one of a plurality of bricks, and the bit stream includes a value that indicates that the picture header is signaled in the slice header and is determined to be used for encoding. In the case of syntax elements, the bitstream also includes a syntax element indicating that a syntax element indicating the number of tiles in the slice is not to be parsed; the method includes using the syntax elements to encode the video data. 一種用於解碼來自一位元流之視頻資料的解碼器,該解碼器係組態成履行請求項1至7、15及16之任一項的方法。A decoder for decoding video data from a bit stream. The decoder is configured to fulfill any one of request items 1 to 7, 15, and 16. 一種用於編碼視頻資料入一位元流中之編碼器,該編碼係組態成履行請求項8至14、17及18之任一項的方法。An encoder for encoding video data into a bit stream. The encoding is configured to fulfill any of the requirements 8 to 14, 17, and 18. 一種電腦程式,其在執行時致使請求項1至18之任一項的方法被履行。A computer program that, when executed, causes the method of any one of claims 1 to 18 to be performed.
TW110109783A 2020-03-20 2021-03-18 High level syntax for video coding and decoding TWI811651B (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
GB2004099.4 2020-03-20
GB2004099.4A GB2593224B (en) 2020-03-20 2020-03-20 High level syntax for video coding and decoding

Publications (2)

Publication Number Publication Date
TW202137764A true TW202137764A (en) 2021-10-01
TWI811651B TWI811651B (en) 2023-08-11

Family

ID=70546725

Family Applications (1)

Application Number Title Priority Date Filing Date
TW110109783A TWI811651B (en) 2020-03-20 2021-03-18 High level syntax for video coding and decoding

Country Status (8)

Country Link
US (1) US20230145618A1 (en)
EP (1) EP4122206A1 (en)
JP (2) JP2023516250A (en)
KR (1) KR20220157414A (en)
CN (1) CN115362683A (en)
GB (1) GB2593224B (en)
TW (1) TWI811651B (en)
WO (1) WO2021185928A1 (en)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CA3113219A1 (en) * 2018-09-18 2020-03-26 Huawei Technologies Co., Ltd. A video encoder, a video decoder and corresponding methods
WO2021141471A1 (en) * 2020-01-10 2021-07-15 엘지전자 주식회사 Transform-based image coding method and device therefor
WO2021200610A1 (en) * 2020-03-31 2021-10-07 シャープ株式会社 Dynamic image decoding device, dynamic image coding device, dynamic image decoding method, and dynamic image coding method
WO2024140793A1 (en) * 2022-12-27 2024-07-04 Mediatek Inc. Method for reducing signaling overhead in video coding

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP3301923B1 (en) * 2012-09-26 2020-01-08 Velos Media International Limited Image decoding method and image decoding apparatus
US9313500B2 (en) * 2012-09-30 2016-04-12 Microsoft Technology Licensing, Llc Conditional signalling of reference picture list modification information
WO2015104451A1 (en) * 2014-01-07 2015-07-16 Nokia Technologies Oy Method and apparatus for video coding and decoding
WO2021145687A1 (en) * 2020-01-14 2021-07-22 엘지전자 주식회사 Image encoding/decoding method and device for signaling information related to sub picture and picture header, and method for transmitting bitstream
WO2021170132A1 (en) * 2020-02-28 2021-09-02 Huawei Technologies Co., Ltd. An encoder, a decoder and corresponding methods simplifying signalling slice header syntax elements

Also Published As

Publication number Publication date
GB202004099D0 (en) 2020-05-06
CN115362683A (en) 2022-11-18
TWI811651B (en) 2023-08-11
JP2024116367A (en) 2024-08-27
WO2021185928A1 (en) 2021-09-23
JP2023516250A (en) 2023-04-19
US20230145618A1 (en) 2023-05-11
EP4122206A1 (en) 2023-01-25
GB2593224A (en) 2021-09-22
KR20220157414A (en) 2022-11-29
GB2593224B (en) 2024-07-17

Similar Documents

Publication Publication Date Title
TWI809336B (en) High level syntax for video coding and decoding
TW202139701A (en) High level syntax for video coding and decoding
TWI811651B (en) High level syntax for video coding and decoding
TWI827919B (en) High level syntax for video coding and decoding
TWI842980B (en) High level syntax for video coding and decoding
JP7345051B2 (en) Video encoding with support for subpictures, slices, and tiles
JP2024105712A (en) High-level syntax for video coding and decoding
JP2024001274A (en) High-level syntax for video coding and decoding