高效率視訊編碼High Efficiency Video Coding,簡稱HEVC),又稱為H.265MPEG-H第2部分,是一種視訊壓縮標準,獲視為是ITU-T H.264/MPEG-4 AVC標準的繼任者。2004年開始由ISO/IEC Moving Picture Experts Group(MPEG)和ITU-T Video Coding Experts Group(VCEG)作為ISO/IEC 23008-2 MPEG-H Part 2或稱作ITU-T H.265開始制定[1][2][3][4][5]。第一版的HEVC/H.265視訊壓縮標準在2013年4月13日獲接受為國際電信聯盟(ITU-T)的正式標準[1][2][6]。HEVC獲認為不僅提昇影像品質,同時也能達到H.264/MPEG-4 AVC兩倍之壓縮率(等同於同樣畫面品質下位元率減少到了50%),可支援4K解析度甚至到超高畫質電視(UHDTV),最高解析度可達到8192×4320(8K解析度)。

Quick Facts 狀態, 開始年 ...
HEVC / H.265 / MPEG-H Part 2
High efficiency video coding
狀態現行
開始年2013
最新版本2019年6月
組織ITU-TISOIEC
委員會ITU-T Study Group 16, VCEG, MPEG
基礎標準H.261H.262H.263H.264MPEG-1
有關標準H.266
領域影像壓縮
網站https://www.itu.int/rec/T-REC-H.265
Close

數個基於HEVC延伸的編碼標準正在進行中,包含range extensions(支援進階的影片格式)、可調式編碼和3D視訊編碼標準。

歷史

標準制定

  • 2004年:Key Technical Areas(KTA)

在H.264/AVC標準制定完(2003年)的後一年,VCEG組織便開始研究更先進的視訊壓縮技術,期望能夠發展下一代視訊壓縮標準,或期望能大量提昇壓縮率成為H.264/AVC的延伸版本[1][7]。2005年1月,VCEG開始將這些議題統整稱為Key Technical Areas(KTA),並且開發了一個同名的軟體編解碼器KTA Software來評估受提案的新技術[8][9]。KTA software是基於H.264/AVC的標準參考軟體Joint Model(JM)[8]上,加入新的編碼技術並與JM的編碼效率做比較。到了2007年,KTA Software的編碼效率較JM提升了不少[10]

  • JCT-VC

為此目的MPEG與VCEG聯合成立了一個Joint Collaborative Team on Video Coding(JCT-VC)作為共同開發HEVC的團隊[1][2]。並每四個月進行一次標準討論與制定的會議。並發佈了HEVC的標準參考軟體HEVC Test Model(HM)[11]

規格書時程

HEVC標準(第一個版本)制定的時程如下:[1]

  • 2012年2月:Committee Draft(complete draft of standard)[12]
  • 2012年7月:Draft International Standard[13]
  • 2013年1月:Final Draft International Standard and ITU-T Consent[14][15][16][17]

技術細節

Thumb
典型的Hybrid Video Coding視訊編碼器架構

HEVC與H.264/AVC和許多其他視訊壓縮編碼一樣,都是採用Hybrid Video Coding的架構(如右圖),但在各部分加入了一些新技術或者提升了原本編碼工具的效率[18]

編碼樹單元(Coding Tree Unit)

編碼樹單元(Coding Tree Unit, CTU)是HEVC的基本編碼單元,有如H.264/AVC的Macroblock。HEVC支援8x8到64×64像素的CTU大小。編碼樹單元可向下分割編碼單元(Coding Unit,CU)、預測單元(Prediction Unit,PU)及轉換單元(Transform Unit,TU)。

取代了過往中使用的 16×16 像素宏區塊,編碼樹單元可使用 64×64 的大區塊結構,且可以更好地將圖片細分為可變大小尺寸。

於初始時將圖片劃分為編碼樹單元,可以為64×64、32×32或16×16,而像素塊尺寸提升通常會提高時編碼的效率。

逆轉換(Inverse Transforms)

規範指定HEVC以 4×4、8×8、16×16 和 32×32 四個變換單元 (transform units) 大小來對預測殘差進行編碼,編碼樹單元可以遞迴地劃分超過四個變換單元。

變換單元使用基於離散餘弦變換(DCT) 的整數基函式;而屬於影格內編碼範疇的 4×4 亮度變換區塊則使用從離散正弦變換(DST) 匯出的整數變換進行變換。

平行處理工具(Parallel Processing Tools)

  • 允許圖磚(Tiles)將圖片切片為可以獨立解碼/編碼的矩形區塊,切片的主要目的是允許並列處理。圖塊可以獨立解碼,甚至可以允許隨機訪問影像流中其圖片的特定區域。
  • 波前並列處理 (Wavefront parallel processing) 是指將切片分成多行編碼樹單元,除第一行解碼外,而後每一行都需要在前一行中做出決定。波前並列處理具有來自前一行編碼樹單元的熵編碼器訊息,並允許並列處理方法,該方法可以實現比圖磚更好的壓縮。
  • 圖磚與波前並列處理具有可選擇性,如使用圖磚,則至少須達高 64 像素,寬 256 像素,並且對圖磚數量有特定的限制。
  • 絕大多數情況下,切片可以彼此獨立解碼,這是在視訊流中遺失資料的情況下進行重新同步的手段之一。 因預測無法跨切片邊界進行,切片於初始便受定義為各自獨立;而當對圖片進行環路濾波時,則將需要跨切片邊界資訊。切片是按照掃描順序解碼的編碼樹單元,切片可以使用不同的編碼類型,有I、P與B型。
  • 與對完整切片解碼相比,相依的切片可以讓系統更快地訪問與圖磚或波前並列處理相關的資料。相依切片具有較低的延遲並允許低延遲影像編碼。

熵編碼(Entropy Coding)

HEVC 使用前文參考之適應性二元算術編碼(CABAC) 演算法,使用了跟H.264/AVC High Profile中一樣的前文參考之適應性二元算術編碼演算法來做熵編碼,並拋棄了適應性變動長度編碼法(CAVLC)。

HEVC僅允許前文參考之適應性二元算術編碼作為熵編碼器實踐方法,基於前文參考之適應性二元算術編碼的熵編碼目的在於實現更高的吞吐量。

HEVC 的另一個改進是編碼資料之間的相依關係改變,藉以提高吞吐量。

因此與 H.264/MPEG-4 AVC 相比,前文參考之適應性二元算術編碼可以更好地選擇提高效率的前文。

影格內預測(Intra Prediction)

相比於 H.264/MPEG-4 AVC 的8 種影格內預測方向模式 ,HEVC 影格內預測有33 種方向模式。HEVC還有DC影格內預測和平面預測模式。

DC 影格內預測模式對樣本求平均值而來,可用於平坦表面。

至於平面預測模式,相對於而H.264/MPEG-4 AVC而言,HEVC的平面預測模式支援所有區塊尺寸,而H.264/MPEG-4 AVC的平面預測模式僅限於 16×16 像素的區塊尺寸。

從同一圖片內解碼的數據,獲用來作為影格內預測模式使用相鄰且相間的預測區塊資料。

Thumb
HEVC 有 33 種影格內預測模式

運動補償(Motion Compensation)

關於亮度插值,HEVC 使用八個抽頭的濾波器進行一維半處樣本插值,或是七個抽頭的濾波器進行一維四分之一處樣本插值;

H.264/MPEG-4 AVC則先使用6 抽頭濾波器一維插值運算半樣本值,四捨五入後,在附近的半樣本位置的值之間使用線性插值,生成四分之一處樣本值。

兩者相比,使用更多抽頭的插值濾波器,並且消除了四捨五入的誤差,HEVC 精度更加高。

運動向量預測(Motion Vector Prediction)

水平和垂直的運動向量 (Motion Vectors) 在 2012 年 7 月添加到 HEVC 中,其中包含 mvLX 變數。

其中,HEVC 水平/垂直運動向量範圍為 -32768 至 32767,共16位元;使用四分之一像素精度的HEVC,運動向量範圍則為 -8192 至 8191.75 亮度樣本。

HEVC 有兩種運動向量模式,即進階運動向量預測 (Advanced Motion Vector Prediction) 和合併模式(Merge Mode)。

進階運動向量預測,其使用來自參考圖片的資料,也可以使用來自相鄰預測區塊資料。

合併模式類似於 H.264/MPEG-4 AVC 的跳過與直接運動推理模式,不同的地方是,其使用索引資訊來選擇備選目標。

環路濾波器(Loop Filtering)

HEVC有兩個環路濾波器,解塊濾波器(DBF)與取樣自適應偏移(SAO)濾波器。

在圖片間預測迴圈中使用解塊濾波器與自適應偏移量濾波器兩者,隨後將濾波後影像儲存存在解碼圖片緩衝區(Decoded Picture Buffer,DPB)中作為圖片間預測之基準。

解塊濾波器(Deblocking Filter)

類似於 H.264/MPEG-4 AVC 使用的解塊濾波器,但其設計更佳簡潔。 HEVC的解塊濾波器僅適用 8×8 樣本網格(Sample Grid),而 H.264/MPEG-4 AVC 則適用於 4×4 樣本網格。

DBF 使用 8×8 樣本網格讓影像退化顯著降低,並顯著提高了並行處理效率,因為解塊濾波器不再導致與其他操作互動作用。此外,HEVC只允許至多三個的解塊濾波器深度。

HEVC的解塊濾波器先做畫面垂直邊緣的水平濾波,而後再做對於水平邊緣的垂直濾波,有利於平行處理多執行緒(Multithreading)。

取樣自適應偏移(Sample Adaptive Offset)

樣本自適應偏移濾波器在解塊濾波器之後使用,透過尋找表查詢偏移量,藉以重建原始訊號震幅。每個編碼樹單元都可禁止使用樣本自適應偏移濾波器,或油以下兩種模式之一啟用:邊緣偏移模式(Edge Offset Mode)或帶偏移模式(Band Offset Mode)。

邊緣偏移模過使用方向梯度將樣本的值與其八個相臨且相間中的兩個值進行比較來操作,並將樣本分為五種類型:最小值、最大值、較低值邊緣、較高值的邊緣,與單調。除了單調以外,都會使用偏移量。

帶偏移模式根據單個樣本的振幅而使用不同的偏移量,樣本按其振幅分類為 32種頻帶,並為 32 個頻帶中的其中四個連續帶指定了偏移量,在容易產生振鈴效應的平坦區域中,樣本振幅經常在一個小範圍內改變。樣本自適應偏移濾波器旨在提高影像品質和減少振鈴效應

編碼規範

Profile

層級與等級

HEVC定義了包含Main和High 2種「層級」(tiers)註:目前沒有公定譯名,以及13種「等級」(levels)註:目前沒有公定譯名[1]。層級是設計來面對不同的應用,對其最大位元率做限制。其中Main tier是設計給大部分的應用,而High tier是設計給高要求的應用[1]。等級則是針對位元流設定了一組限制,與Profile相似[1]。當一個解碼器符合給定了的層級與等級,代表此解碼器也受要求必須能解碼用該層級/等級及較低層級/等級所編碼出來的位元流[1]

編碼效率

More information 視訊編碼標準, 較之H.264/MPEG-4 AVC HP減少位元速率的比例 ...
主觀視訊效能比較[19]
視訊編碼標準 較之H.264/MPEG-4 AVC HP減少位元速率的比例
480p 720p 1080p 4K UHD
HEVC 52% 56% 62% 64%
Close

產品與實現

2012

  • 2月29日,在2012世界行動通訊大會上,高通展示了一個運行在Android平板上的HEVC解碼器,使用了Qualcomm Snapdragon S4雙核心處理器運行在1.5GHz,將同一個影片以H.264/AVC和HEVC同時並行播放。在此展示中HEVC展現了較H.264/AVC幾乎節省了50%的位元率。[20]
  • 8月22日,Ericsson發表了世界第一個HEVC編碼器Ericsson SVP 5500,並預計在2012 IBC貿易展展出。Ericsson SVP 5500設計來做到實時編碼影片供行動裝置使用。[21][22]
  • 8月22日,研究者們發布訊息說他們計畫擴展當前MPEG-DASH標準,使其在2013年4月前支援HEVC。[23]
  • 9月2日,Vanguard Video(前身為Vanguard Software Solutions[24],發表了一個實時HEVC軟體編碼器執行於1080p30(1920×1080, 30fps)在一個單一Intel Xeon處理器平台上。此編碼器也在IBC 2012中展示[25][26]
  • 9月9日,Ateme在IBC 2012上展示了一個HEVC編碼器,能夠以60fps、平均15 Mbit/s的條件下編碼3840×2160p解析度的影片。ATEME計畫在2013年10月正式發布此HEVC編碼器。[29][30][31]

2013

  • 1月7日,Rovi Corporation英語Rovi Corporation宣稱在官方發表HEVC標準後,他們計畫開始把對HEVC的支援加入他們的MainConcept SDK以及他們的產品DivX[34][35]
  • 1月8日,Vanguard Video發表了V.265,一個專業的純軟體HEVC編碼器,能達到實時的編碼效能。[40]
  • 1月25日,NGCodec英語NGCodec發表免費可取得的合於HEVC規格測試影片。[41]
  • 2月11日,MIT的研究者們於2013國際固態電路會議(ISSCC)上,展示了世界第一個HEVC ASIC解碼器[45]。他們的晶片能夠實時解碼3840x2160p 30fps的影片串流,並消耗低於0.1的電力[46]
  • 4月19日,SES發表第一個使用HEVC標準的UHD影片傳輸。此傳輸擁有3840x2160的解析度於20 Mbit/s下。SES使用了Harmonic Inc.英語Harmonic Inc.的ProMedia Xpress HEVC編碼器以及博通的BCM7445 HEVC解碼器。[51][52][53]
  • 5月9日,日本廣播協會三菱電機發表訊息說他們正共同開發第一個專門為8K UHD TV(也可稱為Super Hi-Vision, SHV)的HEVC編碼器,將支援Main 10 profile達到Level 6.1,允許以60fps的速度編碼10-bit解析度7680x4320的影片。此HEVC編碼器有17個3G-SDI英語3G-SDI輸入並使用了17個主機板做平行處理,每一塊主機板都會獲分配到7680x256畫面中的其中一行像素點同時做運算,來達到整個影片的實時編碼[54][55][56][57]。此HEVC編碼器相容於HEVC第四版的草稿並且提供最大位元率340 Mbit/s[58],並獲展示在2013年5月30至6月2日的NHK廣播電視技術研究所 Open House 2013[54][56][59]。在此展覽中此HEVC編碼器在85 Mbit/s的位元率下提供了350:1的壓縮比[60][61]
  • 5月15日,DivX發布了一個DivX HEVC影片profile草案,基於HEVC Main profile及Main tier並加上特別為了DivX HEVC影片profile所設的限制[62][63]。DivX HEVC 4K、1080p、720p影片profile的草案目前只定義了影片部分,DivX也計畫在未來定義profile的其他部分[62][63]。此DivX HEVC 4K影片profile允許最大位元率達到HEVC Level 5.1(40 Mbit/s)但是最大每秒取樣數則被限制在HEVC Level 5 (4096x2160 at 30 fps)[64]
  • 5月31日,法國電信發表第一個公開展示HEVC實時端對端(end-to-end英語End-to-end principle)的傳送鏈(delivery chain)。此展示同時使用IPTVDVB-T2的HD品質廣播了6月1日至6月9日的2013 French Open[65][66]
  • 6月4日,Rovi Corporation英語Rovi Corporation發布MainConcept HEVC SDK 1.0[67],支援Smart Adaptive Bitrate Encoding Technology(SABET)能允許在降低了的計算耗損下,同時編碼至多10個影片串流輸出[67]。SDK 1.0將有Windows版本,而SDK 1.0.1將在2013年7月發布,並增加Linux和Mac OS X的支援[67][68]。SDK 1.0支援了Main profile而SDK 2.0將會支援Main 10 profile並將在2013年Q4發布[68][69]
  • 6月10日,Vanguard Video發表訊息說他們的V.265專業HEVC編碼器加入了Main 10 profile的支援,成為第一個支援Main 10 profile的實時HEVC軟體編碼器。[70]
  • 7月19日,Allegro DVT說他們改進了該公司的HEVC解碼器IP,增加Main 10 profile的支援。[72][73]
  • 8月8日,日本電信電話發布了他們的HEVC-1000 SDK軟體編碼器,能支援Main 10 profile、解析度最高7680x4320以及禎率最高到120 fps。[76]
  • 8月21日,Microsoft發布了一個用於HEVC的DXVA(DirectX Video Acceleration)規範,支援Main、Main 10及Main Still Picture profile。DXVA 2.0啟用後可進行HEVC解碼的硬體加速DXVA 2.0,並且相容的解碼器可以使用DXVA 2.0進行以下操作:位元流解析、去區塊、反量化縮放、反轉換以及動作補償[77]
  • 9月4日,Ittiam Systems英語Ittiam Systems在2013 IBC上展示了實時1080p HEVC編碼和4K HEVC解碼。Ittiam的軟體HEVC編碼器在Intel x86平台支援了UHD解析度編碼以及實時進行廣播等級的HD 1080p編碼;其軟體HEVC解碼器則是能在Intel x86和ARM Cortex™平台上運行4K/UHD的實時解碼。[78][79]
  • 9月5日,DivX在當天發佈的DivX 10.0中提供了DivX HEVC Plug-in,啟用後即可播放或將其他格式影片轉換為HEVC影片。DivX成為第一家提供免費的影片播放器和影片轉換器的軟體廠商。[80]
  • 9月11日,ViXS Systems英語ViXS Systems發表了XCode 6400 SoC,在HEVC Main 10 profile下支援4K解析度於60 fps,以及Rec. 2020英語Rec. 2020色彩空間[82]
  • 9月11日,NGCodec Inc.發表了免費可取得的4K HEVC測試影片。[83]
  • 10月16日,OpenHEVC解碼器受加入到FFmpeg中。[101]
  • 10月23日,Ittiam Systems英語Ittiam Systems在2013 ARM TechCon上,展示了為ARM Mali™ GPU運算以及ARM® Cortex®-A系列處理器最佳化的低功耗HEVC解碼器。Ittiam的HEVC解碼器設計來充分利用行動SoC的運算能力,它可以很好地控制GPU的計算能力以及能源效率來減少電量消耗。[102] [103]
  • 11月14日,DivX developers提供了使用Intel i7 3.5 GHz四核心八執行緒CPU的HEVC解碼表現。DivX 10.1 Beta版的解碼器能分別以210.9 fps、101.5 fps、29.6 fps的速度來解碼720p、1080p、4K的影片。[105]
  • 12月18日,ViXS Systems英語ViXS Systems的XCode 6400 SoC,第一個支援HEVC Main 10 profile的SoC正式出貨。[106]

2014

  • 1月15日,oViCs發表了ViC-1 HEVC解碼器,支援了Main 10 profile並且能以120fps速度編碼4K影片。[107]
  • 4月5日,在美國廣播電視展上,eBrisk視訊公司和Altera公司演示了支援FPGA(現場可程式化門陣列)加速的HEVC Main10編碼器即時編碼所壓制的4K60影格視訊 / 10-bit視訊,採用了雙至強E5-2697-V2平台[108][109]
  • 8月13日,Ittiam Systems英語Ittiam Systems宣布支援第三代H.265/HEVC 4:2:2 12-bit編碼。[111]
  • 9月5日,藍光光碟協會宣布,4K藍光光碟的標準將支援60 fps、4K的HEVC視訊,且支援Rec. 2020英語Rec. 2020的色域、高動態範圍成像和10-bit的色深。[112][113]4K藍光光碟將具有至少50Mbit/s的位元速率,單張光碟的容量最高可達66GB/100GB[112][113]。4K藍光光碟將在2015年年初獲得相應許可,配套的播放器有望在此後面世[112][113]

2022

2022年10月25日,Google Chrome 發布了 107 版本,開始支援所有平台「開箱即用」的HEVC硬體解碼。[114]

瀏覽器支援

HEVC在以下web瀏覽器中實現:

  • Android瀏覽器(自2014年11月第5版起) [115]
  • Safari 瀏覽器(自2017年9月發布的 11 版本起)[116]
  • Microsoft Edge(自2017年7月發布的 77 版本開始,如果已安裝 HEVC 視訊擴充,在Windows 10 1709+上受支援)[117]
  • Google Chrome(自2022年10月發布的 107 版本起,在Windows 8+、macOS 11+、Android 5.0+、ChromeOS 和 Linux 受支援的硬體上都可用)[118]

根據StatCounter的資料,2021年5月,估計有18%的桌上型電腦和筆記本系統上使用的瀏覽器能夠播放HTML5網頁中的HEVC視訊。[119]

作業系統支援

More information Microsoft Windows, macOS ...
不同作業系統對HEVC的支援情況
Microsoft Windows macOS Android iOS
支援編解碼
支援的容器
備註
  • Windows 10 1507版本開始支援。
  • 由於許可費問題,Windows 10 1709版本中內建支援被移除,可從Microsoft Store購買HEVC Video Extensions以在電影與電視應用中播放HEVC。[120]
  • 自Windows 11 22H2開始,HEVC Video Extensions在預設安裝中已經內建。[121]
  • macOS 10.13 High Sierra版本開始支援。 [122]
  • Android 5.0版本開始支援。 [115]
  • iOS 11.0版本開始支援。 [123]
Close

參見

參考資料

外部連結

Wikiwand in your browser!

Seamless Wikipedia browsing. On steroids.

Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.

Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.