(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-05-23
(45)【発行日】2024-05-31
(54)【発明の名称】ニューラル画像圧縮における置換の多学習率のための方法および装置
(51)【国際特許分類】
H04N 19/90 20140101AFI20240524BHJP
H04N 19/85 20140101ALI20240524BHJP
【FI】
H04N19/90
H04N19/85
(21)【出願番号】P 2022564637
(86)(22)【出願日】2021-10-14
(86)【国際出願番号】 US2021055039
(87)【国際公開番号】W WO2022220868
(87)【国際公開日】2022-10-20
【審査請求日】2022-10-24
(32)【優先日】2021-04-16
(33)【優先権主張国・地域又は機関】US
(32)【優先日】2021-10-13
(33)【優先権主張国・地域又は機関】US
(73)【特許権者】
【識別番号】520353802
【氏名又は名称】テンセント・アメリカ・エルエルシー
(74)【代理人】
【識別番号】100110364
【氏名又は名称】実広 信哉
(74)【代理人】
【識別番号】100150197
【氏名又は名称】松尾 直樹
(72)【発明者】
【氏名】ディン・ディン
(72)【発明者】
【氏名】ウェイ・ジアン
(72)【発明者】
【氏名】シェン・リン
(72)【発明者】
【氏名】ウェイ・ワン
(72)【発明者】
【氏名】シャオジョン・シュ
(72)【発明者】
【氏名】シャン・リュウ
【審査官】間宮 嘉誉
(56)【参考文献】
【文献】特許第7374340(JP,B2)
【文献】米国特許出願公開第2020/0366914(US,A1)
【文献】米国特許出願公開第2020/0304802(US,A1)
【文献】米国特許出願公開第2017/0230675(US,A1)
【文献】特開2020-191630(JP,A)
【文献】TALEBI, Hossein et al.,Better Compression with Deep Pre-Editing,arXiv:2002.00113,version 1,Cornell University,2020年02月01日,pp.1-12,[online],[retrieved on 2023-12-25],Retrieved from the Internet: <URL: https://arxiv.org/abs/2002.00113v1>,https://doi.org/10.48550/arXiv.2002.00113
【文献】BALLE, Johannes et al.,Variational Image Compression with a Scale Hyperprior,arXiv:1802.01436,version 2,Cornell University,2018年05月01日,pp.1-23,[online],[retrieved on 2023-12-25],Retrieved from the Internet: <URL: https://arxiv.org/abs/1802.01436>,https://doi.org/10.48550/arXiv.1802.01436
【文献】WANG, Xiao et al.,Substitutional Neural Image Compression,arXiv:2105.07512,version 1,Cornell University,2021年05月16日,pp.1-8,[online],[retrieved on 2023-12-26],Retrieved from the Internet: <URL: https://arxiv.org/abs/2105.07512>,https://doi.org/10.48550/arXiv.2105.07512
(58)【調査した分野】(Int.Cl.,DB名)
H04N 7/12
H04N 19/00-19/98
IEEE Xplore
(57)【特許請求の範囲】
【請求項1】
少なくとも1つのプロセッサによって実行されるニューラルネットワークを使用した置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)の方法であって、前記方法が、
E2E NICフレームワークへの入力画像を受信するステップと、
前記入力画像を1つまたは複数のブロックに分割するステップであって、前記1つまたは複数のブロックが同じサイズを有し、前記1つまたは複数のブロックのための学習率は、前記1つまたは複数のブロックのうちの各ブロックの特性に基づいて選択される、ステップと、
前記E2E NICフレームワークのトレーニングモデルに基づいて
前記1つまたは複数のブロックの各々のための代替ブロックを決定するステップと、
前記
代替ブロックを符号化するステップと、
前記
符号化された代替ブロックを
ブロックビットストリームにマッピング
して、圧縮済みブロックを生成するステップと
を含む、方法。
【請求項2】
前記
代替ブロックが、
代替
ブロック表現を生成するために前記入力画像
が分割されたブロックの要素を調整するステップと、
前記代替
ブロックとして使用するために前記
分割されたブロックと前記代替
ブロック表現との間の歪み損失が最も小さい前記要素を選択するステップと
を含む、前記E2E NICフレームワークの前記トレーニングモデルの最適化プロセスを実行することによって決定される、
請求項1に記載の方法。
【請求項3】
少なくとも1つのプロセッサによって実行されるニューラルネットワークを使用した置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)の方法であって、前記方法が、
E2E NICフレームワークへの入力画像を受信するステップと、
前記E2E NICフレームワークのトレーニングモデルに基づいて代替画像を決定するステップであって、前記E2E NICフレームワークの前記トレーニングモデルが、前記入力画像の
ための学習率、前記入力画像の更新回数、および歪み損失に基づいてトレーニングさ
れ、前記入力画像のための学習率は、前記入力画像の特性に基づいて選択される、ステップと、
前記代替画像を符号化するステップと、
前記符号化された代替画像をビットストリームにマッピングして、圧縮表現を生成するステップと
を含む、方法。
【請求項4】
複数の代替画像が、
前記学習率に基づいて決定され
る、
請求項
3に記載の方法。
【請求項5】
前記入力画像の前記特性が、前記入力画像のRGB分散および前記入力画像のRD性能のうちの一方である、請求項
3に記載の方法。
【請求項6】
少なくとも1つのプロセッサによって実行されるニューラルネットワークを使用した置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)の方法であって、前記方法が、
E2E NICフレームワークへの入力画像を受信するステップと、
前記E2E NICフレームワークのトレーニングモデルに基づいて代替画像を決定するステップであって、前記E2E NICフレームワークの前記トレーニングモデルが、予めトレーニングされた画像符号化に基づく人工ニューラルネットワークであり
、前記人工ニューラルネットワークのパラメータが固定され、前記入力画像を更新するために勾配が使用される、
ステップと、
前記代替画像を符号化するステップと、
前記符号化された代替画像をビットストリームにマッピングして、圧縮表現を生成するステップと
を含む、方法。
【請求項7】
請求項1~
6のいずれか一項に記載の方法を行うように構成された装置。
【請求項8】
置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)のために少なくとも1つのプロセッサによって実行されると、前記少なくとも1つのプロセッサに、請求項1~
6のいずれか一項に記載の方法を行わせるためのコンピュータプログラム。
【発明の詳細な説明】
【技術分野】
【0001】
本開示は、概して、ニューラル画像圧縮(NIC)に関し、より具体的には、ニューラルネットワークを使用した置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)に関する。
【背景技術】
【0002】
従来のハイブリッドビデオコーデックは、全体として最適化することが困難である。単一のモジュールの改善は、全体的な性能における符号化利得をもたらさない場合がある。近年、標準的なグループおよび企業は、将来のビデオ符号化技術の標準化に対する潜在的な需要を積極的に調査してきた。これらの標準的なグループおよび企業は、ディープニューラルネットワーク(DNN)を使用したAIベースのエンドツーエンドのニューラル画像圧縮に焦点を当てたJPEG-AIグループを確立している。また、中国のAVS規格では、AVS-AI特別グループも結成し、ニューラル画像およびビデオ圧縮技術に取り組んでいる。最近の手法の成功は、高度なニューラル画像およびビデオ圧縮方法論に対するますます多くの産業上の関心をもたらしている。
【発明の概要】
【課題を解決するための手段】
【0003】
例示的な実施形態によれば、少なくとも1つのプロセッサによって実行される、ニューラルネットワークを使用した置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)の方法は、E2E NICフレームワークへの入力画像を受信するステップと、E2E NICフレームワークのトレーニングモデルに基づいて代替画像を決定するステップと、ビットストリームを生成するために代替画像を符号化するステップと、圧縮表現を生成するために代替画像をビットストリームにマッピングするステップとを含む。
【0004】
例示的な実施形態によれば、ニューラルネットワークを使用した置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)のための装置であって、装置は、プログラムコードを記憶するように構成された少なくとも1つのメモリと、プログラムコードを読み取り、プログラムコードによって指示されたように動作するように構成された少なくとも1つのプロセッサとを含む。プログラムコードは、少なくとも1つのプロセッサにE2E NICフレームワークへの入力画像を受信させるように構成された受信コードと、少なくとも1つのプロセッサにE2E NICフレームワークのトレーニングモデルに基づいて代替画像を決定させるように構成された第1の決定コードと、ビットストリームを生成するために、少なくとも1つのプロセッサに代替画像を符号化させるように構成された第1の符号化コードと、圧縮表現を生成するために、少なくとも1つのプロセッサに代替画像をビットストリームにマッピングさせるように構成されたマッピングコードとを含む。
【0005】
例示的な実施形態によれば、非一時的コンピュータ可読媒体は、置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)のために少なくとも1つのプロセッサによって実行されると、少なくとも1つのプロセッサに、E2E NICフレームワークへの入力画像を受信させ、E2E NICフレームワークのトレーニングモデルに基づいて代替画像を決定させ、ビットストリームを生成するために代替画像を符号化させ、圧縮表現を生成するために代替画像をビットストリームにマッピングさせる命令を記憶する。
【図面の簡単な説明】
【0006】
【
図1】実施形態による、本明細書に記載された方法、装置、およびシステムがその中で実現され得る環境の図である。
【
図2】
図1の1つまたは複数のデバイスの例示的なコンポーネントを示すブロック図である。
【
図3】置換型学習ベースの画像符号化前処理モデルを示す例示的な図である。
【
図4】ブロック単位の画像符号化の一例を示す図である。
【
図5】実施形態による、置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)の方法のフローチャートである。
【
図6】実施形態による、置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)のための装置のブロック図である。
【発明を実施するための形態】
【0007】
実施形態は、ピクチャを受信することと、エンドツーエンド(E2E)最適化フレームワークに基づいてピクチャの代替表現を符号化するレート歪み性能を最適化するためにピクチャの代替表現の要素を調整する最適化プロセスを実行することによってピクチャの代替表現を決定することとを含み得る。E2E最適化フレームワークは、予めトレーニングされた人工ニューラルネットワーク(ANN)ベースの画像またはビデオ符号化フレームワークとすることができる。ピクチャの代替表現を符号化してビットストリームを生成することができる。人工ニューラルネットワークに基づくビデオ符号化フレームワークでは、機械学習プロセスを実行することによって、最終目的(例えば、レート歪み性能)を改善するために入力から出力まで異なるモジュールを一緒に最適化することができ、エンドツーエンド(E2E)の最適化されたニューラル画像圧縮(NIC)が得られる。
【0008】
図1は、実施形態による、本明細書に記載された方法、装置、およびシステムがその中で実現され得る環境100の図である。
【0009】
図1に示されるように、環境100は、ユーザデバイス110と、プラットフォーム120と、ネットワーク130とを含んでもよい。環境100のデバイスは、有線接続、無線接続、または有線接続と無線接続との組合せを介して相互接続されてもよい。
【0010】
ユーザデバイス110は、プラットフォーム120に関連付けられた情報を受信、生成、記憶、処理、および/または提供することが可能な1つまたは複数のデバイスを含む。例えば、ユーザデバイス110は、コンピューティングデバイス(例えば、デスクトップコンピュータ、ラップトップコンピュータ、タブレットコンピュータ、ハンドヘルドコンピュータ、スマートスピーカ、サーバなど)、携帯電話(例えば、スマートフォン、無線電話など)、ウェアラブルデバイス(例えば、スマートグラスもしくはスマートウォッチなど)、または同様のデバイスを含んでもよい。いくつかの実装形態では、ユーザデバイス110は、プラットフォーム120から情報を受信し、かつ/またはプラットフォーム120に情報を送信してもよい。
【0011】
プラットフォーム120は、本明細書の他の箇所に記載されているような、1つまたは複数のデバイスを含む。いくつかの実装形態では、プラットフォーム120は、クラウドサーバまたはクラウドサーバのグループを含んでもよい。いくつかの実装形態では、プラットフォーム120は、ソフトウェアコンポーネントがスワップインまたはスワップアウトされ得るようにモジュール式に設計されてもよい。したがって、プラットフォーム120は、異なる用途向けに、容易にかつ/または迅速に再構成されてもよい。
【0012】
いくつかの実装形態では、図示のように、プラットフォーム120は、クラウドコンピューティング環境122下でホストされてもよい。とりわけ、本明細書に記載の実装形態では、プラットフォーム120がクラウドコンピューティング環境122下でホストされるものとして記載しているが、いくつかの実装形態では、プラットフォーム120はクラウドベースでなくてもよく(すなわち、クラウドコンピューティング環境の外部で実装されてもよい)、あるいは部分的にクラウドベースであってもよい。
【0013】
クラウドコンピューティング環境122は、プラットフォーム120をホストする環境を含む。クラウドコンピューティング環境122は、プラットフォーム120をホストするシステムおよび/またはデバイスの物理的な位置と構成に関するエンドユーザ(例えば、ユーザデバイス110)の知識を必要としない計算、ソフトウェア、データアクセス、ストレージなどのサービスを提供できる。図示のように、クラウドコンピューティング環境122は、コンピューティングリソース124のグループ(「コンピューティングリソース124」と総称され、なおかつ個別に「コンピューティングリソース124」と呼ばれている)を含んでもよい。
【0014】
コンピューティングリソース124は、1つまたは複数のパーソナルコンピュータ、ワークステーションコンピュータ、サーバデバイス、または他のタイプの計算デバイスおよび/または通信デバイスを含む。いくつかの実装形態では、コンピューティングリソース124は、プラットフォーム120をホストしてもよい。クラウドリソースは、コンピューティングリソース124内で実行されるコンピューティングインスタンス、コンピューティングリソース124内に設けられるストレージデバイス、コンピューティングリソース124によって提供されるデータ転送デバイスなどを含んでもよい。いくつかの実装形態では、コンピューティングリソース124は、有線接続、無線接続、または有線接続と無線接続との組合せを介して他のコンピューティングリソース124と通信してもよい。
【0015】
図1にさらに示されたように、コンピューティングリソース124は、1つまたは複数のアプリケーション(「APP」)124-1、1つまたは複数の仮想マシン(「VM」)124-2、仮想化ストレージ(「VS」)124-3、1つまたは複数のハイパーバイザ(「HYP」)124-4などのクラウドリソースのグループを含む。
【0016】
アプリケーション124-1は、ユーザデバイス110および/またはプラットフォーム120に提供されるか、もしくはアクセスされてもよい1つまたは複数のソフトウェアアプリケーションを含む。アプリケーション124-1は、ユーザデバイス110にソフトウェアアプリケーションをインストールして実行する必要性を排除してもよい。例えば、アプリケーション124-1は、プラットフォーム120に関連付けられたソフトウェアおよび/またはクラウドコンピューティング環境122を介して提供され得る他の任意のソフトウェアを含んでもよい。いくつかの実装形態では、1つのアプリケーション124-1は、仮想マシン124-2を介して1つまたは複数の他のアプリケーション124-1との間で情報を送受信することができる。
【0017】
仮想マシン124-2は、物理マシンのようにプログラムを実行するマシン(例えば、コンピュータ)のソフトウェア実装形態を含む。仮想マシン124-2は、仮想マシン124-2による用途および任意の実マシンに対するその対応度に応じて、システム仮想マシンまたはプロセス仮想マシンのいずれであってもよい。システム仮想マシンは、完全なオペレーティングシステム(「OS」)の実行をサポートする完全なシステムプラットフォームを提供できる。プロセス仮想マシンは、単一のプログラムを実行することができ、単一の処理をサポートすることができる。いくつかの実装形態では、仮想マシン124-2は、ユーザ(例えば、ユーザデバイス110)に代わって動作してもよく、データ管理、同期、または長期間にわたるデータ転送などのクラウドコンピューティング環境122の基盤を管理してもよい。
【0018】
仮想化ストレージ124-3は、コンピューティングリソース124のストレージシステムまたはデバイス内で仮想化技術を使用する1つもしくは複数のストレージシステムおよび/または1つもしくは複数のデバイスを含む。いくつかの実装形態では、ストレージシステムを背景に、仮想化のタイプがブロックの仮想化およびファイルの仮想化を含んでもよい。ブロックの仮想化は、当該ストレージシステムが物理ストレージであるか異種構造であるかに関係なくアクセスされ得るように、物理ストレージから論理ストレージを抽出する(または分離する)ことを指してもよい。これらを分離することにより、ストレージシステムの管理者がエンドユーザのストレージを管理する方法に柔軟性がもたらされ得る。ファイルの仮想化は、ファイルレベルでアクセスされるデータとファイルが物理的に記憶されている場所との間の依存関係を排除し得る。これにより、ストレージ使用が最適化され、サーバが統合され、かつ/または中断なくファイルが移行されるようになり得る。
【0019】
ハイパーバイザ124-4は、複数のオペレーティングシステム(例えば、「ゲストオペレーティングシステム」など)をコンピューティングリソース124などのホストコンピュータ上で同時に実行できるハードウェア仮想化技術を提供し得る。ハイパーバイザ124-4は、仮想オペレーティングプラットフォームをゲストオペレーティングシステムに提示し得、ゲストオペレーティングシステムの実行を管理し得る。様々なオペレーティングシステムの複数のインスタンスが、仮想化ハードウェアリソースを共有してもよい。
【0020】
ネットワーク130は、1つまたは複数の有線ネットワークおよび/または無線ネットワークを含む。例えば、ネットワーク130は、セルラーネットワーク(例えば、第5世代(5G)ネットワーク、ロングタームエボリューション(LTE)ネットワーク、第3世代(3G)ネットワーク、符号分割多元接続(CDMA)ネットワークなど)、公的地域モバイルネットワーク(PLMN)、ローカルエリアネットワーク(LAN)、ワイドエリアネットワーク(WAN)、メトロポリタンエリアネットワーク(MAN)、電話ネットワーク(例えば、公衆交換電話網(PSTN))、プライベートネットワーク、アドホックネットワーク、イントラネット、インターネット、光ファイバベースのネットワークなど、および/またはそれらもしくは他のタイプのネットワークの組合せを含んでもよい。
【0021】
図1に示すデバイスおよびネットワークの数ならびに配置は、一例として提供されている。実際には、
図1に示されるものに対して、追加のデバイスおよび/もしくはネットワーク、より少ないデバイスおよび/もしくはネットワーク、異なるデバイスおよび/もしくはネットワーク、または異なる配置のデバイスおよび/もしくはネットワークが存在してもよい。さらに、
図1に示された2つ以上のデバイスは、単一のデバイス内に実装されてもよく、または
図1に示された単一のデバイスは、複数の分散型デバイスとして実装されてもよい。追加または代替として、環境100のデバイスのセット(例えば、1つまたは複数のデバイス)は、環境100のデバイスの別のセットによって実行されるものとして記載された1つまたは複数の機能を実行することができる。
【0022】
図2は、
図1の1つまたは複数のデバイスの例示的なコンポーネントを示すブロック図である。
【0023】
デバイス200は、ユーザデバイス110および/またはプラットフォーム120に対応してもよい。
図2に示されるように、デバイス200は、バス210と、プロセッサ220と、メモリ230と、ストレージコンポーネント240と、入力コンポーネント250と、出力コンポーネント260と、通信インターフェース270とを備えてもよい。
【0024】
バス210は、デバイス200のコンポーネント間の通信を可能にするコンポーネントを含む。プロセッサ220は、ハードウェア、ファームウェア、またはハードウェアとソフトウェアとの組合せに実装される。プロセッサ220は、中央処理装置(CPU)、グラフィック・プロセッシング・ユニット(GPU)、加速処理ユニット(APU)、マイクロプロセッサ、マイクロコントローラ、デジタル信号プロセッサ(DSP)、フィールド・プログラマブル・ゲート・アレイ(FPGA)、特定用途向け集積回路(ASIC)、または別のタイプの処理コンポーネントである。いくつかの実装形態では、プロセッサ220は、機能を実行するようにプログラムされることが可能な1つまたは複数のプロセッサを含む。メモリ230は、ランダム・アクセス・メモリ(RAM)、読み取り専用メモリ(ROM)、ならびに/またはプロセッサ220が使用するための情報および/もしくは命令を記憶する別のタイプの動的もしくは静的なストレージデバイス(例えば、フラッシュメモリ、磁気メモリ、および/もしくは光メモリ)を含む。
【0025】
ストレージコンポーネント240は、デバイス200の操作および使用に関連する情報および/またはソフトウェアを記憶する。例えば、ストレージコンポーネント240は、対応するドライブと共に、ハードディスク(例えば、磁気ディスク、光ディスク、光磁気ディスク、および/またはソリッドステートディスク)、コンパクトディスク(CD)、デジタル多用途ディスク(DVD)、フロッピーディスク、カートリッジ、磁気テープ、および/または別のタイプの非一時的コンピュータ可読媒体を含んでもよい。
【0026】
入力コンポーネント250は、デバイス200がユーザ入力(例えば、タッチ・スクリーン・ディスプレイ、キーボード、キーパッド、マウス、ボタン、スイッチ、および/またはマイクロフォン)などを介して情報を受信できるようにするコンポーネントを含む。追加または代替として、入力コンポーネント250は、情報を検知するためのセンサ(例えば、全地球測位システム(GPS)コンポーネント、加速度計、ジャイロスコープ、および/またはアクチュエータ)を含んでもよい。出力コンポーネント260は、デバイス200(例えば、ディスプレイ、スピーカ、および/または1つもしくは複数の発光ダイオード(LED))からの出力情報を提供するコンポーネントを含む。
【0027】
通信インターフェース270は、有線接続、無線接続、または有線接続と無線接続との組合せなどを介してデバイス200が他のデバイスと通信できるようにする、トランシーバ様のコンポーネント(例えば、トランシーバならびに/または別個の受信機および送信機)を含む。通信インターフェース270は、デバイス200が別のデバイスから情報を受信し、かつ/または別のデバイスに情報を提供できるようにしてもよい。例えば、通信インターフェース270は、イーサネットインターフェース、光インターフェース、同軸インターフェース、赤外線インターフェース、無線周波数(RF)インターフェース、ユニバーサル・シリアル・バス(USB)インターフェース、Wi-Fiインターフェース、またはセルラー・ネットワーク・インターフェースなどを含んでもよい。
【0028】
デバイス200は、本書で説明されている1つまたは複数のプロセスを遂行できる。デバイス200は、プロセッサ220がメモリ230および/またはストレージコンポーネント240などの非一時的コンピュータ可読媒体によって記憶されたソフトウェア命令を実行したことに応答して、これらのプロセスを実行してもよい。コンピュータ可読媒体は、本明細書では非一時的メモリデバイスと定義されている。メモリデバイスは、単一の物理ストレージデバイス内のメモリ空間、または複数の物理ストレージデバイスにわたって広がるメモリ空間を含む。
【0029】
ソフトウェア命令は、別のコンピュータ可読媒体から、または通信インターフェース270を介して別のデバイスから、メモリ230および/またはストレージコンポーネント240に読み込まれてもよい。メモリ230および/またはストレージコンポーネント240に記憶されたソフトウェア命令は、実行されると、本明細書に記載された1つまたは複数のプロセスをプロセッサ220に実行させてもよい。追加または代替として、本明細書に記載された1つまたは複数のプロセスを実行するために、ソフトウェア命令の代わりに、またはソフトウェア命令と組み合わせてハードワイヤード回路が使用されてもよい。したがって、本明細書に記載の実装形態は、ハードウェア回路とソフトウェアとのいかなる特定の組合せにも限定されない。
【0030】
図2に示されるコンポーネントの数および配置は、一例として提供されている。実際には、デバイス200は、
図2に示されるコンポーネントに対して、追加のコンポーネント、より少ないコンポーネント、異なるコンポーネント、または異なる配置のコンポーネントを備えてもよい。追加または代替として、デバイス200のコンポーネントのセット(例えば、1つまたは複数のコンポーネント)は、デバイス200の別のコンポーネントのセットによって実行されるものとして記載された、1つまたは複数の機能を実行してもよい。
【0031】
入力画像xが与えられると、NICの目標は、記憶および伝送の目的のためにコンパクトである圧縮表現
【数1】
を計算するためにDNNエンコーダへの入力として画像xを使用することである。次に、圧縮表現
【数2】
をDNNデコーダへの入力として使用して、画像
【数3】
を再構成する。いくつかのNIC方法は、変分オートエンコーダ(VAE)構造を取ることができ、DNNエンコーダは、画像x全体をその入力として直接使用し、これは、ブラックボックスのように機能するネットワーク層のセットを通過し、出力表現(すなわち、圧縮表現
【数4】
)を計算する。これに対応して、DNNデコーダは、圧縮表現
【数5】
全体をその入力として取り、これは、別のブラックボックスのように機能するネットワーク層の別のセットを通過し、再構築画像
【数6】
を計算する。レート歪み(R-D)損失は、以下の目標損失関数
【数7】
を使用してトレードオフハイパーパラメータλを用いて、再構成画像
【数8】
の歪み損失
【数9】
と圧縮表現
【数10】
のビット消費量Rとの間のトレードオフを達成するように最適化される。
【0032】
【0033】
前処理に関する実施形態は、圧縮される入力画像ごとに、オンライントレーニングを使用して最適な代替物を見つけ、元の画像の代わりにこの代替物を圧縮することができることを提案する。この代替物を使用することにより、エンコーダはより良好な圧縮性能を達成することができる。この方法は、任意のE2E NIC圧縮方法の圧縮性能を上げるための前処理ステップとして用いられる。それは、予めトレーニングされた圧縮モデル自体または任意のトレーニングデータに対するいかなるトレーニングまたは微調整も必要としない。次に、1つまたは複数の実施形態による、前処理モデルのための詳細な方法および装置について説明する。
【0034】
図3は、置換型学習ベースの画像符号化前処理モデルを示す例示的な図である。
【0035】
学習ベースの画像圧縮は、2ステップのマッピングプロセスと見なすことができる。
図3に示されるように、高次元空間における元の画像x
0は、長さR(x
0)を有するビットストリームにマッピングされ(符号化マッピング300)、その後、
【数12】
において歪み損失
【数13】
を有する元の空間にマッピングされる(復号マッピング310)。
【0036】
例示的な実施形態では、
図3に示されるように、代替画像x’
0が存在する場合、それは長さR(x’
0)を有するビットストリームにマッピングされ、次に、それは歪み損失
【数14】
を有する元の画像x
0により近い空間
【数15】
にマッピングされる。距離測定または損失関数が与えられると、代替画像を使用してより良好な圧縮を達成することができる。式(1)に従って、目標損失関数の大域的最小値において最良の圧縮性能が達成される。別の例示的な実施形態では、復号画像と元の画像x
0との間の差を低減するために、ANNの任意の中間ステップにおいて代替物を見つけることができる。
【0037】
勾配がモデルのパラメータを更新するために使用されるモデルトレーニング段階とは異なり、前処理モデルでは、モデルのパラメータは固定され、勾配は入力画像自体を更新するために使用され得る。モデル全体は、微分不可能な部分を微分可能な部分に置き換える(例えば、量子化をノイズ注入に置き換える)ことによって微分可能にされる。したがって、上記の最適化は、勾配降下法によって反復的に解くことができる。
【0038】
この前処理モデルには、ステップサイズとステップ数という2つの重要なハイパーパラメータがある。ステップサイズは、オンライントレーニングの「学習率」を示す。異なるタイプのコンテンツを有する画像は、最良の最適化結果を達成するために異なるステップサイズに対応することができる。ステップ数は、操作された更新の数を示す。目標損失関数
【数16】
と共に、ハイパーパラメータが学習プロセスに使用される。例えば、ステップサイズは、勾配降下アルゴリズムまたは学習プロセスで実行される逆伝播計算で使用されてもよい。反復回数は、学習プロセスをいつ終了させることができるかを制御するための最大反復回数の閾値として使用することができる。
【0039】
図4は、ブロック単位の画像符号化の一例を示す図である。
【0040】
例示的な実施形態では、画像400は、最初にブロックに分割されてもよく(
図4に破線で示す)、分割されたブロックは、画像400自体の代わりに圧縮されてもよい。
図4では、圧縮済みブロックに斜線を付し、圧縮対象ブロックに斜線を付していない。分割されたブロックは、等しいサイズまたは等しくないサイズであってもよい。ブロックごとのステップサイズは異なっていてもよい。この目的のために、より良好な圧縮結果を達成するために、画像400に異なるステップサイズを割り当てることができる。ブロック410は、高さhおよび幅wを有する分割されたブロックのうちの1つの例である。
【0041】
例示的な実施形態では、画像はブロックに分割せずに圧縮されてもよく、画像全体はE2E NICモデルの入力である。異なる画像は、最適化された圧縮結果を達成するために異なるステップサイズを有することができる。
【0042】
別の例示的な実施形態では、ステップサイズは、画像(またはブロック)の特性、例えば画像のRGB分散に基づいて選択されてもよい。実施形態では、RGBは、赤-緑-青のカラーモデルを指すことができる。さらに、別の例示的な実施形態では、ステップサイズは、画像(またはブロック)のRD性能に基づいて選択されてもよい。したがって、その実施形態によれば、複数の代替物が複数のステップサイズに基づいて生成され、より良好な圧縮性能を有するものが選択される。
【0043】
図5は、実施形態による、置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)の方法500のフローチャートである。
【0044】
いくつかの実装形態では、
図5の1つまたは複数のプロセスブロックは、プラットフォーム120によって実行されてもよい。いくつかの実装形態では、図
5の1つまたは複数の処理ブロックは、ユーザデバイス110などのプラットフォーム120とは別個の、またはプラットフォーム120を含む別のデバイスもしくはデバイスのグループによって実行されてもよい。
【0045】
図5に示すように、動作510において、方法500は、E2E NICフレームワークへの入力画像を受信するステップを含む。
【0046】
動作520において、方法500は、E2E NICフレームワークのトレーニングモデルに基づいて代替画像を決定することを含む。代替画像は、E2E NICフレームワークのトレーニングモデルの最適化プロセスによって決定されてもよい。これは、代替表現を生成するために入力画像の要素を調整し、代替画像として使用するために入力画像と代替表現との間の歪み損失が最も小さい要素を選択することによって行われる。さらに、E2E NICフレームワークのトレーニングモデルは、入力画像の学習率、入力画像の更新回数、および歪み損失に基づいてトレーニングされてもよい。1つまたは複数の代替画像は、入力画像の異なる学習率に基づいて決定されてもよい。学習率は、入力画像の特性に基づいて選択される。特性は、入力画像のRGB分散または入力画像のRD性能であってもよい。
【0047】
入力画像がブロックに分割される場合、代替ブロックは、代替ブロック表現を生成するために、分割されたブロックの要素を調整し、代替ブロックとして使用するために、分割されたブロックと代替ブロック表現との間の歪み損失が最も小さい要素を選択することによって、E2E NICフレームワークの訓練モデルの最適化プロセスによって決定され得る。さらに、E2E NICフレームワークのトレーニングモデルは、分割されたブロックの学習率、分割されたブロックの更新回数、および分割された各ブロックの歪み損失に基づいてトレーニングされてもよい。1つまたは複数の代替ブロックは、分割されたブロックの異なる学習率に基づいて決定されてもよい。学習率は、分割されたブロックの特性に基づいて選択される。特性は、分割されたブロックのRGB分散または分割されたブロックのRD性能であってもよい。
【0048】
動作530において、方法500は、ビットストリームを生成するために代替画像を符号化することを含む。
【0049】
動作540において、方法500は、圧縮表現を生成するために代替画像をビットストリームにマッピングすることを含む。実施形態では、ビットストリームまたは圧縮表現の1つまたは複数は、例えば、デコーダおよび/または受信装置に送信されてもよい。
【0050】
方法500はまた、入力画像を1つまたは複数のブロックに分割することを含んでもよい。この場合、動作520~540は、入力画像全体ではなく、各ブロックに対して実行される。すなわち、方法500は、E2E NICフレームワークのトレーニングモデルに基づいて、分割された各ブロックのための代替ブロックを決定するステップと、ブロックビットストリームを生成するために代替ブロックを符号化するステップと、圧縮済みブロックを生成するために代替ブロックをブロックビットストリームにマッピングするステップとをさらに含む。分割されたブロックは、同じサイズであっても異なるサイズであってもよく、各ブロックは異なる学習率を有する。
【0051】
方法500は、予めトレーニングされた画像符号化モデルに基づく人工ニューラルネットワークを使用することができ、人工ニューラルネットワークのパラメータは固定され、入力画像を更新するために勾配が使用される。
【0052】
図5は、本方法の例示的なブロックを示しているが、いくつかの実装形態では、本方法は、
図5に示されているブロックに対して、追加のブロック、より少ないブロック、異なるブロック、または異なる配置のブロックを含んでもよい。追加または代替として、本方法のブロックのうちの2つ以上が並行して実行されてもよい。
【0053】
図6は、実施形態による、置換型エンドツーエンド(E2E)ニューラル画像圧縮(NIC)のための装置600のブロック図である。
【0054】
図6に示されるように、装置600は、受信コード610と、決定コード620と、符号化コード630と、マッピングコード640とを含む。
【0055】
受信コード610は、少なくとも1つのプロセッサに、E2E NICフレームワークへの入力画像を受信させるように構成される。
【0056】
決定コード620は、少なくとも1つのプロセッサに、E2E NICフレームワークのトレーニングモデルに基づいて代替画像を決定させるように構成される。
【0057】
符号化コード630は、少なくとも1つのプロセッサに、ビットストリームを生成するために代替画像を符号化させるように構成される。
【0058】
マッピングコード640は、少なくとも1つのプロセッサに、圧縮表現を生成するために代替画像をビットストリームにマッピングさせるように構成される。
【0059】
装置600は、少なくとも1つのプロセッサに入力画像を1つまたは複数のブロックに分割させるように構成された分割コードをさらに含んでもよい。この場合、決定コード620、符号化コード630、およびマッピングコード640は、入力画像全体ではなく、分割された各ブロックを用いて行われる。
【0060】
決定コード620によって決定される代替画像は、E2E NICフレームワークのトレーニングモデルの最適化プロセスによって決定されてもよい。これは、代替画像を生成するために少なくとも1つのプロセッサに入力画像の要素を調整させるように構成されたコードを調整し、少なくとも1つのプロセッサに入力画像と代替表現との間の歪み損失が最小の要素を代替画像として選択させるように構成されたコードを選択することによって行われる。さらに、E2E NICフレームワークのトレーニングモデルは、入力画像の学習率、入力画像の更新回数、および歪み損失に基づいてトレーニングされてもよい。1つまたは複数の代替画像は、入力画像の異なる学習率に基づいて決定されてもよい。学習率は、入力画像の特性に基づいて選択される。特性は、入力画像のRGB分散または入力画像のRD性能であってもよい。
【0061】
さらに、装置600は、予めトレーニングされた画像符号化モデルに基づく人工ニューラルネットワークを使用することができ、人工ニューラルネットワークのパラメータは固定され、入力画像を更新するために勾配が使用される。
【0062】
図6は装置の例示的なブロックを示しているが、いくつかの実装形態では、装置は、
図6に示されているブロックに対して、追加のブロック、より少ないブロック、異なるブロック、または異なる配置のブロックを含んでもよい。追加または代替として、本装置のブロックのうちの2つ以上が並行して実行されてもよい。
【0063】
本明細書の実施形態は、E2E画像圧縮方法を説明する。本方法は、様々なタイプの品質メトリックに対応する柔軟で一般的なフレームワークを使用することによって、置換機構を利用してNICコーディング効率を改善する。
【0064】
1つまたは複数の実施形態によるE2E画像圧縮方法は、別々に使用されてもよく、または任意の順序で組み合わされてもよい。さらに、方法(または実施形態)、エンコーダ、およびデコーダのそれぞれは、処理回路(例えば、1つもしくは複数のプロセッサまたは1つもしくは複数の集積回路)によって実施されてもよい。一例では、1つまたは複数のプロセッサは、非一時的コンピュータ可読媒体に記憶されたプログラムを実行する。
【0065】
前述の開示は例示および説明を提供しているが、網羅的なものではなく、開示されたまさにその形態に実装形態を限定するものではない。上記の開示内容に照らして修正形態および変形形態が実現可能であり、または実装形態の実施により取得されてもよい。
【0066】
本明細書で使用される場合、コンポーネントという用語は、ハードウェア、ファームウェア、またはハードウェアとソフトウェアとの組合せとして広く解釈されることを意図している。
【0067】
本明細書に記載のシステムおよび/または方法は、ハードウェア、ファームウェア、またはハードウェアとソフトウェアとの組合せの異なる形態で実装されてもよいことは明らかであろう。これらのシステムおよび/または方法を実装するために使用される実際の専用の制御ハードウェアまたはソフトウェアコードは、実装形態を限定するものではない。したがって、システムおよび/または方法の動作および挙動は、特定のソフトウェアコードを参照することなく本明細書に記載されており、ソフトウェアおよびハードウェアは、本明細書の記載に基づいてシステムおよび/または方法を実装するように設計され得ることが理解される。
【0068】
特徴の組合せが特許請求の範囲に列挙され、かつ/または本明細書に開示されているが、これらの組合せは、実施可能な実装形態の開示を限定するものではない。実際には、これらの特徴の多くは、特許請求の範囲に具体的に列挙されていない、かつ/または本明細書に開示されていない方法で組み合わされてもよい。以下に列挙される各従属請求項は1つの請求項にのみ直接従属してもよいが、実施可能な実装形態の開示は、各従属請求項を請求項セット内のあらゆる他の請求項と組み合わせて含む。
【0069】
本明細書で使用される要素、行為、または指示は、明示的にそのように記載されていない限り、重要または必須であると解釈されなくてもよい。また、本明細書で使用される冠詞「a」および「an」は、1つまたは複数の項目を含むものであり、「1つまたは複数」と同じ意味で使用されてもよい。さらに、本明細書で使用される「セット」という用語は、1つまたは複数の項目(例えば、関連項目、非関連項目、関連項目と非関連項目との組合せなど)を含むことを意図しており、「1つまたは複数」と互換的に使用されてもよい。1つの項目のみが対象とされる場合、「1つ」という用語または同様の言葉が使用される。また、本明細書で使用される「有する(has)」、「有する(have)」、「有する(having)」などの用語は、オープンエンド用語であることを意図している。さらに、「に基づいて(based on)」という語句は、特に明記しない限り、「少なくとも部分的に~に基づいて」を意味することを意図している。
【符号の説明】
【0070】
100 環境
110 ユーザデバイス
120 プラットフォーム
124 コンピューティングリソース
124-1 アプリケーション
124-2 仮想マシン
124-3 仮想化ストレージ
124-4 ハイパーバイザ
130 ネットワーク
200 デバイス
210 バス
220 プロセッサ
230 メモリ
240 ストレージコンポーネント
250 入力コンポーネント
260 出力コンポーネント
270 通信インターフェース
300 符号化マッピング
310 復号マッピング
400 画像
410 ブロック
500 方法
510 動作
520 動作
530 動作
540 動作
600 装置
610 受信コード
620 決定コード
630 符号化コード
640 マッピングコード