IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ KDDI株式会社の特許一覧

特許7557436点群復号装置、点群復号方法及びプログラム
<>
  • 特許-点群復号装置、点群復号方法及びプログラム 図1
  • 特許-点群復号装置、点群復号方法及びプログラム 図2
  • 特許-点群復号装置、点群復号方法及びプログラム 図3
  • 特許-点群復号装置、点群復号方法及びプログラム 図4
  • 特許-点群復号装置、点群復号方法及びプログラム 図5
  • 特許-点群復号装置、点群復号方法及びプログラム 図6A
  • 特許-点群復号装置、点群復号方法及びプログラム 図6B
  • 特許-点群復号装置、点群復号方法及びプログラム 図7
  • 特許-点群復号装置、点群復号方法及びプログラム 図8
  • 特許-点群復号装置、点群復号方法及びプログラム 図9
  • 特許-点群復号装置、点群復号方法及びプログラム 図10
< >
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-09-18
(45)【発行日】2024-09-27
(54)【発明の名称】点群復号装置、点群復号方法及びプログラム
(51)【国際特許分類】
   G06T 9/40 20060101AFI20240919BHJP
   H04N 19/59 20140101ALI20240919BHJP
   H04N 19/96 20140101ALI20240919BHJP
   H04N 19/70 20140101ALI20240919BHJP
【FI】
G06T9/40
H04N19/59
H04N19/96
H04N19/70
【請求項の数】 3
(21)【出願番号】P 2021111088
(22)【出願日】2021-07-02
(65)【公開番号】P2023007934
(43)【公開日】2023-01-19
【審査請求日】2023-07-24
【国等の委託研究の成果に係る記載事項】(出願人による申告)令和元年度、総務省、「多様な用途、環境下での高精細映像の活用に資する次世代映像伝送・通信技術の研究開発」委託事業、産業技術力強化法第17条の適用を受ける特許出願
(73)【特許権者】
【識別番号】000208891
【氏名又は名称】KDDI株式会社
(74)【代理人】
【識別番号】110001564
【氏名又は名称】フェリシテ弁理士法人
(72)【発明者】
【氏名】海野 恭平
(72)【発明者】
【氏名】河村 圭
【審査官】岡本 俊威
(56)【参考文献】
【文献】国際公開第2021/046038(WO,A1)
【文献】特許第6732152(JP,B1)
【文献】米国特許出願公開第2021/0029187(US,A1)
(58)【調査した分野】(Int.Cl.,DB名)
G06T 9/00- 9/40
H04N 19/00-19/98
(57)【特許請求の範囲】
【請求項1】
点群復号装置であって、
複数レベルでのTrisoupを許可するか否かを制御する第1フラグを復号するように構成されている幾何情報復号部を備え、
前記幾何情報復号部は、前記第1フラグの値が前記複数レベルでのTrisoupを許可することを示す場合、最大Trisoupノードサイズ及び最小Trisoupノードサイズを復号するように構成されていることを特徴とする点群復号装置。
【請求項2】
点群復号方法であって、
複数レベルでのTrisoupを許可するか否かを制御する第1フラグを復号する工程を有し、
前記工程において、前記第1フラグの値が前記複数レベルでのTrisoupを許可することを示す場合、最大Trisoupノードサイズ及び最小Trisoupノードサイズを復号することを特徴とする点群復号方法。
【請求項3】
コンピュータを、点群復号装置として機能させるプログラムであって、
前記点群復号装置は、複数レベルでのTrisoupを許可するか否かを制御する第1フラグを復号するように構成されている幾何情報復号部を備え、
前記幾何情報復号部は、前記第1フラグの値が前記複数レベルでのTrisoupを許可することを示す場合、最大Trisoupノードサイズ及び最小Trisoupノードサイズを復号するように構成されていることを特徴とするプログラム。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、点群復号装置、点群復号方法及びプログラムに関する。
【背景技術】
【0002】
非特許文献1には、幾何情報のインター予測技術が開示されている。
【先行技術文献】
【非特許文献】
【0003】
【文献】[PCC]An exploratory model for inter geometry-based PCC、ISO/IEC JTC1/SC29/WG11 m44754
【文献】Text of ISO/IEC 23090-9 DIS Geometry-based PCC、ISO/IEC JTC1/SC29/WG11 N19088
【発明の概要】
【発明が解決しようとする課題】
【0004】
しかしながら、非特許文献1では、動き補償した参照点群の点の分布を基に、符号化対象点群の部分空間(ノード)毎の点の存在有無を推定する。この時、特に、参照点群及び符号化対象点群の両方が疎な場合、動き補償の結果に少しでもずれがあると、十分に時間方向の相関を活用できないという問題点があった。
【0005】
そこで、本発明は、上述の課題に鑑みてなされたものであり、参照点群をアップサンプリングすることで位置情報のインター予測による符号化効率を高めることができる点群復号装置、点群復号方法及びプログラムを提供することを目的とする。
【課題を解決するための手段】
【0006】
本発明の第1の特徴は、点群復号装置であって、点群の位置情報を再構成するように構成されている幾何情報再構成部と、前記幾何情報再構成部で再構成された点群をアップサンプリングするように構成されているアップサンプル部と、前記アップサンプルされた点群を参照してインター予測を行うように構成されているツリー合成部と、を備え、前記アップサンプル部は、前記再構成された点群における各点の座標からオフセットベクトルを算出し、前記オフセットベクトルを用いてアップサンプリングを行うように構成されていることを要旨とする。
【0007】
本発明の第2の特徴は、点群復号装置であって、複数レベルでのTrisoupを許可するか否かを制御する第1フラグを復号するように構成されている幾何情報復号部を備えることを要旨とする。
【0008】
本発明の第3の特徴は、点群復号方法であって、点群の位置情報を再構成するように構成されている幾何情報再構成部と、前記幾何情報再構成部で再構成された点群をアップサンプリングする工程Aと、前記アップサンプリングされた点群を参照してインター予測を行う工程Bと、を備え、前記工程Aにおいて、前記再構成された点群における各点の座標からオフセットベクトルを算出し、前記オフセットベクトルを用いてアップサンプリングを行うことを要旨とする。
【0009】
本発明の第4の特徴は、コンピュータを、点群復号装置として機能させるプログラムであって、前記点群復号装置は、点群の位置情報を再構成するように構成されている幾何情報再構成部と、前記幾何情報再構成部で再構成された点群をアップサンプリングするように構成されているアップサンプル部と、前記アップサンプリングされた点群を参照してインター予測を行うように構成されているツリー合成部と、を備え、前記アップサンプル部は、前記再構成された点群における各点の座標からオフセットベクトルを算出し、前記オフセットベクトルを用いてアップサンプリングを行うように構成されていることを要旨とする。
【発明の効果】
【0010】
本発明によれば、参照点群をアップサンプリングすることで位置情報のインター予測による符号化効率を高めることができる点群復号装置、点群復号方法及びプログラムを提供することができる。
【図面の簡単な説明】
【0011】
図1図1は、一実施形態に係る点群処理システム10の構成の一例を示す図である。
図2図2は、一実施形態に係る点群復号装置200の機能ブロックの一例を示す図である。
図3図3は、一実施形態に係る点群復号装置200の幾何情報復号部2010で受信する符号化データ(ビットストリーム)の構成の一例を示す図である。
図4図4は、GPS2011のシンタックス構成の一例を示す図である。
図5図5は、一実施形態に係る点群復号装置200のアップサンプル部2120におけるアップサンプリングの一例を示すフローチャートである。
図6A図6Aは、一実施形態に係る点群復号装置200のアップサンプル部2120の動作を説明するための図である。
図6B図6Bは、一実施形態に係る点群復号装置200のアップサンプル部2120の動作を説明するための図である。
図7図7は、一実施形態に係る点群復号装置200のツリー合成部2020における処理の一例を示すフローチャートである。
図8図8は、一実施形態に係る点群復号装置200のツリー合成部2020によるTrisoup情報の復号処理の一例を示すフローチャートである。
図9図9は、一実施形態に係る点群符号化装置100の機能ブロックの一例を示す図である。
図10図10は、一実施形態に係る点群復号装置200のツリー合成部2020の機能ブロックの一例を示す図である。
【発明を実施するための形態】
【0012】
以下、本発明の実施の形態について、図面を参照しながら説明する。なお、以下の実施形態における構成要素は、適宜、既存の構成要素等との置き換えが可能であり、また、他の既存の構成要素との組み合わせを含む様々なバリエーションが可能である。したがって、以下の実施形態の記載をもって、特許請求の範囲に記載された発明の内容を限定するものではない。
【0013】
(第1実施形態)
以下、図1図10を参照して、本発明の第1実施形態に係る点群処理システム10について説明する。図1は、本実施形態に係る実施形態に係る点群処理システム10を示す図である。
【0014】
図1に示すように、点群処理システム10は、点群符号化装置100及び点群復号装置200を有する。
【0015】
点群符号化装置100は、入力点群信号を符号化することによって符号化データ(ビットストリーム)を生成するように構成されている。点群復号装置200は、ビットストリームを復号することによって出力点群信号を生成するように構成されている。
【0016】
なお、入力点群信号及び出力点群信号は、点群内の各点の位置情報と属性情報とから構成される。属性情報は、例えば、各点の色情報や反射率である。
【0017】
ここで、かかるビットストリームは、点群符号化装置100から点群復号装置200に対して伝送路を介して送信されてもよい。また、ビットストリームは、記憶媒体に格納された上で、点群符号化装置100から点群復号装置200に提供されてもよい。
【0018】
(点群復号装置200)
以下、図2及び図10を参照して、本実施形態に係る点群復号装置200について説明する。図2は、本実施形態に係る点群復号装置200の機能ブロックの一例について示す図である。
【0019】
図2に示すように、点群復号装置200は、幾何情報復号部2010と、ツリー合成部2020と、近似表面合成部2030と、幾何情報再構成部2040と、逆座標変換部2050と、属性情報復号部2060と、逆量子化部2070と、RAHT部2080と、LoD算出部2090と、逆リフティング部2100と、逆色変換部2110と、アップサンプリング部2120と、フレームバッファ2130とを有する。
【0020】
幾何情報復号部2010は、点群符号化装置100から出力されるビットストリームのうち、幾何情報に関するビットストリーム(幾何情報ビットストリーム)を入力とし、シンタックスを復号するように構成されている。
【0021】
復号処理は、例えば、コンテキスト適応二値算術復号処理である。ここで、例えば、シンタックスは、位置情報の復号処理を制御するための制御データ(フラグやパラメータ)を含む。
【0022】
ツリー合成部2020は、幾何情報復号部2010によって復号された制御データ及び後述するツリー内のどのノードに点群が存在するかを示すoccupancy codeを入力として、復号対象空間内のどの領域に点が存在するかというツリー情報を生成するように構成されている。
【0023】
なお、occupancy codeの復号処理をツリー合成部2020内部で行うよう構成されていてもよい。
【0024】
本処理は、復号対象空間を直方体で区切り、occupancy codeを参照して各直方体内に点が存在するかを判断し、点が存在する直方体を複数の直方体に分割し、occupancy codeを参照するという処理を再帰的に繰り返すことで、ツリー情報を生成することができる。
【0025】
ここで、かかるoccupancy codeの復号に際して、後述するインター予測を用いてもよい。
【0026】
本実施形態では、上述の直方体を常に立方体として8分木分割を再帰的に行う「Octree」と呼ばれる手法、及び、8分木分割に加え、4分木分割及び2分木分割を行う「QtBt」と呼ばれる手法を使用することができる。「QtBt」を使用するか否かは、制御データとして点群符号化装置100側から伝送される。
【0027】
或いは、制御データによってPredicitive codingを使用するように指定された場合、ツリー合成部2020は、点群符号化装置100において決定した任意のツリー構成に基づいて各点の座標を復号するように構成されている。
【0028】
近似表面合成部2030は、ツリー合成部2020によって生成されたツリー情報を用いて近似表面情報を生成し、かかる近似表面情報に基づいて点群を復号するように構成されている。
【0029】
近似表面情報は、例えば、物体の3次元点群データを復号する際等において、点群が物体表面に密に分布しているような場合に、個々の点群を復号するのではなく、点群の存在領域を小さな平面で近似して表現したものである。
【0030】
具体的には、近似表面合成部2030は、例えば、「Trisoup」と呼ばれる手法で、近似表面情報を生成し、点群を復号することができる。「Trisoup」の具体的な処理例については後述する。また、Lidar等で取得した疎な点群を復号する場合は、本処理を省略することができる。
【0031】
幾何情報再構成部2040は、ツリー合成部2020によって生成されたツリー情報及び近似表面合成部2030によって生成された近似表面情報を元に、復号対象の点群データの各点の幾何情報(復号処理が仮定している座標系における位置情報)を再構成するように構成されている。
【0032】
逆座標変換部2050は、幾何情報再構成部2040によって再構成された幾何情報を入力として、復号処理が仮定している座標系から、出力点群信号の座標系に変換を行い、位置情報を出力するように構成されている。
【0033】
アップサンプル部2120は、幾何情報再構成部2040によって再構成された幾何情報を入力として、後述する通りアップサンプル処理を行うように構成されている。
【0034】
フレームバッファ2130は、アップサンプル部2120でアップサンプルされた点群を入力とし、参照フレームとして保存するように構成されている。保存した参照フレームは、ツリー合成部2020において時間的に異なるフレームのインター予測を行う場合に、フレームバッファ2130から読み出されて参照フレームとして使用される。
【0035】
ここで、各フレームに対してどの時刻の参照フレームを用いるかどうかは、例えば、点群符号化装置100からビットストリームとして伝送されてくる制御データに基づいて決定されてもよい。
【0036】
なお、ここでは、アップサンプル部2120でアップサンプルした後にフレームバッファ2130に保存する場合の例を説明したが、この順番は、逆でもよい。
【0037】
すなわち、幾何情報再構成部2040から出力される幾何情報を参照フレームとしてフレームバッファ2130へ保存し、その後、ツリー合成部2020にてインター予測を行う際に、フレームバッファ2130に保存されていた参照フレームをアップサンプル部2120でアップサンプルしてからツリー合成部2020に入力してもよい。
【0038】
さらに別の例として、図10に示すように、アップサンプル部2120は、ツリー合成部2020の内部に含まれるように構成されていてもよい。以下、図10に示す構成例について説明する。
【0039】
ツリー合成部2020は、フレームバッファ2130から、復号対象の点群とは時刻の異なる既に復号済みの点群を取得し、動き補償部2021へ入力する。
【0040】
動き補償部2021は、制御データから復号した動き情報(動きベクトル等)を用いて動き補償を行うように構成されている。動き補償の具体的な方法は、公知の手法を適用できるため、詳細については省略する。
【0041】
ここで、動き補償部2021は、復号済みの点群内の各点にクラス分類処理を行い、クラスごとに異なる動き補償処理を適用するように構成されていてもよい。
【0042】
例えば、動き補償部2021は、点毎に「地面」及び「物体」のどちらかのクラスを割り当て、「物体」と見なされた点のみに動き補償を適用するように構成されていてもよい。
【0043】
アップサンプル部2021は、前記動き補償済みの点群を入力して、後述の様にアップサンプル処理を行うように構成されている。
【0044】
上述のように、クラス分類に基づいた動き補償処理が行われている場合、アップサンプル部2021は、アップサンプル処理についても特定のクラスのみアップサンプル処理を行うように構成されていてもよい。
【0045】
例えば、アップサンプル部2021は、「地面」の点のみに対して、アップサンプリング処理を行う、或いは、「物体」の点のみに対してアップサンプル処理を行うように構成されていてもよい。
【0046】
上述のクラス分類が、例えば、各点のz軸座標(高さ成分)の値を基に行われている場合、アップサンプル部2021は、動き補償後の点群の各点のz座標を基に、アップサンプル処理を実行するか否かを制御するように構成されていてもよい。
【0047】
具体的には、z軸座標が、第1閾値以上であり(又は、第1閾値よりも大きく)、且つ、第2閾値以下である(又は、第2閾値よりも小さい)場合にのみ、アップサンプル部2021は、アップサンプル処理を行うよう構成されていてもよい。
【0048】
上述とは逆に、z軸座標が、第1閾値以下である(又は、第1閾値よりも小さい)、又は、第2閾値以上である(又は、第2閾値よりも大きい)場合にのみ、アップサンプル部2021は、アップサンプルを行うよう構成されていてもよい。ここで、第2閾値は、第1閾値より大きな値であるとする。
【0049】
確率推定部2022は、アップサンプル後の点群を入力として、occpancy Codeの各ビットの値が0である確率、又は、occpancy Codeの各ビットの値が1である確率を推定するように構成されている。
【0050】
占有情報復号部2023は、確率推定部2022で推定した確率に基づいて、エントロピー復号によってoccpancy Codeを復号するように構成されている。
【0051】
ツリー構成部2024は、上述のoccpancy Codeの値に基づいて、ツリーを構成するように構成されている。
【0052】
属性情報復号部2060は、点群符号化装置100から出力されるビットストリームのうち、属性情報に関するビットストリーム(属性情報ビットストリーム)を入力とし、シンタックスを復号するように構成されている。
【0053】
復号処理は、例えば、コンテキスト適応二値算術復号処理である。ここで、例えば、シンタックスは、属性情報の復号処理を制御するための制御データ(フラグ及びパラメータ)を含む。
【0054】
また、属性情報復号部2060は、復号したシンタックスから、量子化済み残差情報を復号するように構成されている。
【0055】
逆量子化部2070は、属性情報復号部2060によって復号された量子化済み残差情報と、属性情報復号部2060によって復号された制御データの一つである量子化パラメータとを元に、逆量子化処理を行い、逆量子化済み残差情報を生成するように構成されている。
【0056】
逆量子化済み残差情報は、復号対象の点群の特徴に応じて、RAHT部2080及びLoD算出部2090のいずれかに出力される。いずれに出力されるかは、属性情報復号部2060によって復号される制御データによって指定される。
【0057】
RAHT部2080は、逆量子化部2070によって生成された逆量子化済み残差情報及び幾何情報再構成部2040によって生成された幾何情報を入力とし、RAHT(Region Adaptive Hierarchical Transform)と呼ばれるHaar変換(復号処理においては、逆Haar変換)の一種を用いて、各点の属性情報を復号するように構成されている。RAHTの具体的な処理としては、例えば、非特許文献1に記載の方法を用いることができる。
【0058】
LoD算出部2090は、幾何情報再構成部2040によって生成された幾何情報を入力とし、LoD(Level of Detail)を生成するように構成されている。
【0059】
LoDは、ある点の属性情報から、他のある点の属性情報を予測し、予測残差を符号化或いは復号するといった予測符号化を実現するための参照関係(参照する点及び参照される点)を定義するための情報である。
【0060】
言い換えると、LoDは、幾何情報に含まれる各点を複数のレベルに分類し、下位のレベルに属する点については上位のレベルに属する点の属性情報を用いて属性を符号化或いは復号するといった階層構造を定義した情報である。
【0061】
LoDの具体的な決定方法としては、例えば、非特許文献1に記載の方法を用いてもよい。
【0062】
逆リフティング部2100は、LoD算出部2090によって生成されたLoD及び逆量子化部2070によって生成された逆量子化済み残差情報を用いて、LoDで規定した階層構造に基づいて各点の属性情報を復号するように構成されている。逆リフティングの具体的な処理としては、例えば、非特許文献1に記載の方法を用いることができる。
【0063】
逆色変換部2110は、復号対象の属性情報が色情報であり且つ点群符号化装置100側で色変換が行われていた場合に、RAHT部2080又は逆リフティング部2100から出力される属性情報に逆色変換処理を行うように構成されている。かかる逆色変換処理の実行の有無については、属性情報復号部2060によって復号された制御データによって決定される。
【0064】
点群復号装置200は、以上の処理により、点群内の各点の属性情報を復号して出力するように構成されている。
【0065】
(幾何情報復号部2010)
以下、図3図4を用いて幾何情報復号部2010で復号される制御データについて説明する。
【0066】
図3は、幾何情報復号部2010で受信する符号化データ(ビットストリーム)の構成の一例である。
【0067】
第1に、ビットストリームは、GPS2011を含んでいてもよい。GPS2011は、ジオメトリパラメータセットとも呼ばれ、幾何情報の復号に関する制御データの集合である。具体例については後述する。各GPS2011は、複数のGPS2011が存在する場合に個々を識別するためのGPS id情報を少なくとも含む。
【0068】
第2に、ビットストリームは、GSH2012A/2012Bを含んでいてもよい。GSH2012A/2012Bは、ジオメトリスライスヘッダ或いはジオメトリデータユニットヘッダとも呼ばれ、後述するスライスに対応する制御データの集合である。以降では、スライスという呼称を用いて説明するが、スライスをデータユニットと読み替えることもできる。具体例については後述する。GSH2012A/2012Bは、各GSH2012A/2012Bに対応するGPS2011を指定するためのGPS id情報を少なくとも含む。
【0069】
第3に、ビットストリームは、GSH2012A/2012Bの次に、スライスデータ2013A/2013Bを含んでいてもよい。スライスデータ2013A/2013Bには、幾何情報を符号化したデータが含まれている。スライスデータ2013A/2013Bの一例としては、後述するoccupancy codeが挙げられる。
【0070】
以上のように、ビットストリームは、各スライスデータ2013A/2013Bに、1つずつGSH2012A/2012B及びGPS2011が対応する構成となる。
【0071】
上述のように、GSH2012A/2012Bにて、どのGPS2011を参照するかをGPS id情報で指定するため、複数のスライスデータ2013A/2013Bに対して共通のGPS2011を用いることができる。
【0072】
言い換えると、GPS2011は、スライスごとに必ずしも伝送する必要がない。例えば、図3のように、GSH2012B及びスライスデータ2013Bの直前では、GPS2011を符号化しないようなビットストリームの構成とすることもできる。
【0073】
なお、図3の構成は、あくまで一例である。各スライスデータ2013A/2013Bに、GSH2012A/2012B及びGPS2011が対応する構成となっていれば、ビットストリームの構成要素として、上述以外の要素が追加されてもよい。
【0074】
例えば、図3に示すように、ビットストリームは、シーケンスパラメータセット(SPS)2001を含んでいてもよい。また、同様に、伝送に際して、図3と異なる構成に整形されてもよい。更に、後述する属性情報復号部2060で復号されるビットストリームと合成して単一のビットストリームとして伝送されてもよい。
【0075】
図4は、GPS2011のシンタックス構成の一例である。
【0076】
なお、以下で説明するシンタックス名は、あくまで一例である。以下で説明したシンタックスの機能が同様であれば、シンタックス名は異なっていても差し支えない。
【0077】
GPS2011は、各GPS2011を識別するためのGPS id情報(gps_geom_parameter_set_id)を含んでもよい。
【0078】
なお、図4のDescriptor欄は、各シンタックスが、どのように符号化されているかを意味している。ue(v)は、符号無し0次指数ゴロム符号であることを意味し、u(1)は、1ビットのフラグであることを意味する。
【0079】
GPS2011は、ツリー合成部2020でインター予測を行うか否かを制御するフラグ(interprediction_enabled_flag)を含んでもよい。
【0080】
例えば、interprediction_enabled_flagの値が「0」の時はインター予測を行わないと定義し、interprediction_enabled_flagの値が「1」の時はインター予測を行うと定義してもよい。
【0081】
なお、interprediction_enabled_flagは、GPS2011ではなくSPS2001に含んでいてもよい。
【0082】
幾何情報復号部2020は、インター予測を行うとき、すなわち、interprediction_enabled_flagの値が「1」の時、追加で以下のシンタックスを復号するように構成されていてもよい。
【0083】
GPS2011は、インター予測を行う場合に、アップサンプル部2120によるアップサンプリングを適用するか否かを制御するフラグ(reference_upsampling_enabled_flag)を含んでもよい。
【0084】
例えば、reference_upsampling_enabled_flagの値が「0」の時はアップサンプリングを適用しないと定義し、reference_upsampling_enabled_flagの値が「1」の時はアップサンプリングを適用すると定義してもよい。
【0085】
幾何情報復号部2020は、アップサンプリングを適用するとき、すなわち、reference_upsampling_enabled_flagの値が「1」の時、追加で以下のシンタックスを復号するように構成されていても良い。
【0086】
GPS2011は、アップサンプリング点数を制御するシンタックス(upsampling_number_div2)を含んでもよい。当該シンタックスの値を具体的にどのように使うかについては後述する。
【0087】
GPS2011は、アップサンプリング点の間隔を制御するシンタックス(upsampling_interval)を含んでも良い。当該シンタックスの値を具体的にどのように使うかについては後述する。
【0088】
GPS2011は、近似表面合成部2030でTrisoupを使用するか否かを制御するフラグ(trisoup_enabled_flag)を含んでもよい。
【0089】
例えば、trisoup_enabled_flagの値が「0」の時はTrisoupを使用しないと定義し、trisoup_enabled_flagの値が「1」の時はTrisoupを使用すると定義してもよい。
【0090】
幾何情報復号部2020は、Trisoupを使用するとき、すなわち、trisoup_enabled_flagの値が「1」の時、追加で以下のシンタックスを復号するように構成されていてもよい。
【0091】
なお、trisoup_enabled_flagは、GPS2011ではなくSPS2001に含んでいてもよい。
【0092】
GPS2011は、複数レベルでのTrisoupを許可するか否かを制御するフラグ(trisoup_multilevel_enabled_flag、第1フラグ)を含んでもよい。
【0093】
例えば、trisoup_multilevel_enabled_flagの値が「0」の時は複数レベルでのTrisoupを許可しない、すなわち、単一のレベルでのTrisoupを行うと定義し、trisoup_multilevel_enabled_flagの値が「1」の時は複数レベルでのTrisoupを許可すると定義してもよい。
【0094】
なお、当該シンタックスがGPS2011に含まれない場合、当該シンタックスの値を単一のレベルでのTrisoupを行う場合の値、すなわち、「0」とみなしてよい。
【0095】
なお、trisoup_multilevel_enabled_flagは、GPS2011ではなくSPS2001に含まれるよう定義してもよい。この場合、SPS2001にtrisoup_multilevel_enabled_flagが含まれていない場合、当該シンタックスの値を単一のレベルでのTrisoupを行う場合の値、すなわち、「0」とみなしてよい。
【0096】
幾何情報復号部2020は、複数レベルでのTrisoupを許可するとき、すなわち、trisoup_multilevel_enabled_flagの値が「1」の時、追加で以下のシンタックスを復号するように構成されていても良い。
【0097】
GPS2011は、複数レベルでのTrisoupを許可するとき、Trisoupノードサイズの最大値を規定するシンタックス(log2_trisoup_max_node_size_minus3)を含んでもよい。
【0098】
当該シンタックスは、実際のTrisoupノードサイズの最大値について、2を底とする対数に変換した値として表現されていてもよい。更に、当該シンタックスは、実際のTrisoupノードサイズの最大値について、2を底とする対数に変換した後に3を引いた後の値として表現されていてもよい。
【0099】
GPS2011は、複数レベルでのTrisoupを許可するとき、Trisoupノードサイズの最小値を規定するシンタックス(log2_trisoup_min_node_size_minus3)を含んでもよい。
【0100】
当該シンタックスは、実際のTrisoupノードサイズの最小値について、2を底とする対数に変換した値として表現されていてもよい。更に、当該シンタックスは、実際のTrisoupノードサイズの最小値について、2を底とする対数に変換した後に3を引いた後の値として表現されていてもよい。
【0101】
また、当該シンタックスの値は、必ず0以上かつlog2_trisoup_max_node_size_minus3以下となるように制約されていてもよい。
【0102】
幾何情報復号部2020は、複数レベルでのTrisoupを許可しないとき、すなわち、trisoup_multilevel_enabled_flagの値が「0」の時、追加で以下のシンタックスを復号するように構成されていても良い。
【0103】
GPS2011は、複数レベルでのTrisoupを許可しないとき、Trisoupノードサイズを規定するシンタックス(log2_trisoup_node_size_minus3)を含んでもよい。
【0104】
当該シンタックスは、実際のTrisoupノードサイズについて、2を底とする対数に変換した値として表現されていてもよい。更に、当該シンタックスは、実際のTrisoupノードサイズについて、2を底とする対数に変換した後に3を引いた後の値として表現されていてもよい。
【0105】
(アップサンプル部2120)
以下、図5図6を用いてアップサンプル部2120でのアップサンプリングについて説明する。
【0106】
図5は、アップサンプル部2120におけるアップサンプリングの一例を示すフローチャートである。
【0107】
図5に示すように、ステップS501において、アップサンプル部2120は、幾何情報再構成部から出力される幾何情報、すなわち、位置情報を再構成した点群に含まれる全ての点について、アップサンプリングが終了したか否かを判定する。
【0108】
全ての点の処理を終了した場合は、アップサンプル部2120は、ステップS504において、処理を終了する。一方、全ての点の処理を終了していない場合は、アップサンプル部2120は、ステップS502へ進む。
【0109】
ステップS502において、アップサンプル部2120は、オフセットベクトルを算出する。
【0110】
以下、図6Aに示すxyz空間上の点Pに対してオフセットベクトルを求める場合を例に説明する。ここで、点Pの座標は(X、Y、Z)とし、原点Oを始点とし点Pを終点とするベクトルをvとする。
【0111】
オフセットベクトルvは、例えば、vのL2ノルムが1となるように正規化したものとして算出されてもよい。すなわち、アップサンプル部2120は、以下の式に基づいて、オフセットベクトルvを算出してもよい。
【0112】
u=v/(X+Y+Z1/2
なお、アップサンプル部2120は、上述の平方根の計算及び除算については、近似計算を用いて整数演算となるようにしてもよい。また、上述の近似計算の際に、vの絶対値が小さすぎると整数演算による誤差が大きくなりすぎるため、vuの代わりに後述するi・vuを求めてもよい。
【0113】
オフセットベクトルvは、アップサンプリングの対象となる点Pについて、原点Oを始点として点Pを指すベクトルvと同じ方向を指し且つ所定の大きさ(例えば、L2ノルム)を持つベクトルとして算出されていれば、上述以外の手法で算出されても差し支えない。
【0114】
言い換えると、点Pが原点Oを中心とした球上に存在すると考えた場合に、球面に対して法線方向となるようにオフセットベクトルvが算出されていれば、上述以外の手法で算出されても差し支えない。
【0115】
また、アップサンプル部2120は、上述の方向や大きさについて、多少の近似誤差を含む方法でオフセットベクトルvを導出してもよい。
【0116】
アップサンプル部2120は、オフセットベクトルvを算出した後、ステップS503へ移る。
【0117】
ステップS503において、アップサンプル部2120は、ステップS502で算出したオフセットベクトルvに基づいてアップサンプリングを行う。
【0118】
ここでも、図6Aの点Pのアップサンプリングを行う場合を例に説明する。図6Bは、点Pのアップサンプリング後の様子の例を示している。
【0119】
ここで、図6B中に示すiは、アップサンプリング間隔を制御するパラメータであり、GPS2011に含まれるアップサンプリング点の間隔を制御するシンタックス(upsampling_interval)として復号した値を用いる。
【0120】
また、図6B中に示すNは、1つの入力点に対してアップサンプリングによって生成する点数を制御するパラメータであり、GPS2011に含まれるアップサンプリング点数を制御するシンタックス(upsampling_number_div2)として復号した値を用いる。
【0121】
アップサンプリングは、例えば、点Pの座標をvとしたとき、以下の通り、座標値vを持つ点を追加することで実現できる。
【0122】
=v±ni・vu(n=1,2,...,N)
この場合、1つの入力点に対して、2N点がアップサンプリングによって追加される。
【0123】
以上のように、アップサンプル部2120は、アップサンプリングを行った後、ステップS501へ戻り、次の点の処理を行う。
【0124】
(ツリー合成部2020)
以下、図7図8を用いてツリー合成部2020の処理について説明する。図7は、ツリー合成部2020における処理の一例を示すフローチャートである。なお、以下では「Octree」を使用してツリーを合成する場合の例について説明する。
【0125】
ステップS701において、ツリー合成部2020は、全てのDepthの処理が完了したかどうかを確認する。なお、Depth数は、点群符号化装置100から点群復号装置200に伝送するビットストリーム内に制御データとして含まれていてもよい。
【0126】
ツリー合成部2020は、当該Depthのノードサイズを算出する。「Octree」の場合、最初のDepthのノードサイズは、「2のDepth数乗」と定義されてもよい。すなわち、Depth数をNとする場合、最初のDepthのノードサイズは、2のN乗と定義されてもよい。
【0127】
また、2番目以降のDepthでのノードサイズは、Nの数を1つずつ減じていくことで定義されてもよい。すなわち、2番目のDepthのノードサイズは、「2の(N-1)乗」として定義され、3番目のDepthのノードサイズは、「2の(N-2)乗」として定義され、・・・と定義されてもよい。
【0128】
或いは、ノードサイズは、常に2のべき乗で定義されるため、単純に指数部分(N、N-1、N-2、等)の値をノードサイズと考えてもよい。以降の説明では、ノードサイズとは、指数部分の値を指すこととする。
【0129】
全てのDepthの処理が完了した場合は、ツリー合成部2020は、ステップS709へ進み、全てのDepthの処理が完了していない場合は、ツリー合成部2020は、ステップS702へ進む。
【0130】
言い換えると、当該Depthがn番目のDepthの時、(N-n)=0の場合は、ツリー合成部2020は、ステップS709へ進み、(N-n)>0の場合は、ツリー合成部2020は、ステップS702へ進む。
【0131】
ここで、Trisoupを使用するか否かを制御するフラグ(trisoup_enabled_flag)がTrisoupを使用することを示している場合、すなわち、trisoup_enabled_flagの値が「1」の時は、ツリー合成部2020は、処理するDepth数を、Trisoupノードサイズの最小値を規定するシンタックス(log2_trisoup_min_node_size_minus3)又はTrisoupノードサイズを規定するシンタックス(log2_trisoup_node_size_minus3)の値に基づいて変化させてもよい。かかる場合、例えば、以下のように定義してもよい。
処理Depth数=全Depth数―(最小の)Trisoupノードサイズ
ここで、最小のTrisoupノードサイズについては、例えば、(log2_trisoup_min_node_size_minus3+3)で定義できる。同様に、Trisoupノードサイズについては、(log2_trisoup_node_size_minus3+3)で定義できる。
【0132】
この場合、全ての処理Depth数の処理が完了した場合は、ツリー合成部2020は、ステップS709へ進み、そうでない場合は、ツリー合成部2020は、ステップS702へ進む。
【0133】
言い換えると、(処理Depth数―n)=0の場合は、ツリー合成部2020は、ステップS709へ進み、(処理Depth数-n)>0の場合は、ツリー合成部2020は、ステップS702へ進む。
【0134】
また、ツリー合成部2020は、ステップS709へ進む際のノードサイズ(N―処理Depth数)を持つ全てのノードには、Trisoupが適用されると判定してもよい。
【0135】
ステップS702において、ツリー合成部2020は、当該Depthにて後述するTrisoup_applied_flagを復号する必要があるか否かを判定する。
【0136】
例えば、「複数レベルでのTrisoupが許可(trisoup_multilevel_enabled_flagの値が「1」)」で、且つ、「当該Depthのノードサイズ(N-n)が最大のTrisoupノードサイズ以下」の場合に、ツリー合成部2020は、「Trisoup_applied_flagの復号が必要である」と判定してもよい。
【0137】
また、ツリー合成部2020は、上述の条件が満たされない場合、「Trisoup_applied_flagの復号が必要ない」と判定してもよい。
【0138】
ここで、最大のTrisoupノードサイズについては、例えば、(log2_trisoup_max_node_size_minus3+3)で定義できる。
【0139】
上述の判定が完了したら、ツリー合成部2020は、ステップS703へ移る。
【0140】
ステップS703において、ツリー合成部2020は、当該Depthに含まれる全てのノードの処理が完了したかどうかを判定する。
【0141】
当該Depthの全てのノードの処理が完了したと判定した場合、ツリー合成部2020は、ステップS701へ移り、次のDepthの処理を行う。
【0142】
一方、当該Depthの全てのノードの処理が完了していない場合、ツリー合成部2020は、ステップS704へ移る。
【0143】
ステップS704において、ツリー合成部2020は、ステップS702で判定したTrisoup_applied_flagの復号の要否について確認する。
【0144】
Trisoup_applied_flagの復号が必要であると判定されている場合は、ツリー合成部2020は、ステップS705へ進み、Trisoup_applied_flagの復号が必要でないと判定されている場合は、ツリー合成部2020は、ステップS708へ移る。
【0145】
ステップS705において、ツリー合成部2020は、Trisoup_applied_flagを復号する。
【0146】
Trisoup_applied_flagは、対象ノードにTrisoupを適用するか否かを示す1ビットのフラグ(第2フラグ)である。例えば、かかるフラグの値が「1」の時に対象ノードにTrisoupを適用すると定義し、かかるフラグの値が「0」の時に対象ノードにTrisoupを適用しないと定義してもよい。
【0147】
ツリー合成部2020は、Trisoup_applied_flagを復号した後、ステップS706へ移る。
【0148】
ステップS706において、ツリー合成部2020は、ステップS705で復号したTrisoup_applied_flagの値を確認する。
【0149】
対象ノードにTrisoupを適用する場合、すなわち、Trisoup_applied_flagの値が「1」の場合は、ツリー合成部2020は、ステップS707へ移る。
【0150】
対象ノードにTrisoupを適用しない場合、すなわち、Trisoup_applied_flagの値が「0」の場合は、ツリー合成部2020は、ステップS708へ移る。
【0151】
ステップS707において、ツリー合成部2020は、対象ノードを、Trisoupを適用するノード、すなわち、Trisoupノードとして記憶する。かかる対象ノードに対しては、これ以上、「Octree」によるノードの分割を適用しないこととする。その後、ツリー合成部2020は、ステップS703に進み、次のノードの処理へ移る。
【0152】
ステップS708において、ツリー合成部2020は、occpancy codeと呼ばれる情報を復号する。
【0153】
occpancy codeは、「Octree」の場合は、対象ノードをx、y、z軸方向にそれぞれ半分に分割して、8つのノード(子ノードと呼ぶ)に分割した際に、それぞれの子ノード内に復号対象の点が含まれているか否かを示す情報である。
【0154】
例えば、occpancy codeは、各子ノードに対して1ビットの情報を割り当て、かかる1ビットの情報が「1」の場合は、かかる子ノード内に復号対象の点が含まれると定義され、かかる1ビットの情報が「0」の場合は、かかる子ノード内に復号対象の点が含まれないと定義されてもよい。
【0155】
ツリー合成部2020は、かかるoccpancy codeを復号する際に、各子ノードに復号対象の点が存在する確率を予め推定し、その確率に基づいて各子ノードに対応するビットをエントロピー復号してもよい。
【0156】
同様に、点群符号化装置100においては、エントロピー符号化してもよい。更に、かかる確率の推定に、インター予測を用いてもよい。インター予測の具体的な方法としては、例えば、非特許文献1に記載の方法を適用できる。更に、インター予測を行う際の参照点群に、アップサンプル部2120でアップサンプルした点群を用いてもよい。
【0157】
ツリー合成部2020は、occpancy codeを復号した後、ステップS703へ進み、次のノードの処理へ移る。
【0158】
ステップS709において、ツリー合成部2020は、Trisoup情報の復号を行う。ツリー合成部2020は、ステップS709の処理については、Trisoupを使用する場合、すなわち、trisoup_enabled_flagの値が「1」の時のみ実行する。すなわち、Trisoupを使用しない場合は、ツリー合成部2020は、ステップS710へ進み、処理を終了する。
【0159】
図8は、Trisoup情報の復号処理の一例を示すフローチャートである。
【0160】
図8に示すように、ステップS801において、ツリー合成部2020は、復号点のサンプリング間隔を制御するシンタックスを復号する。
【0161】
ステップS802において、ツリー合成部2020は、全Trisoup階層の処理が完了したかどうかを判定する。ここで、全Trisoup階層の数は、以下の通り定義できる。
【0162】
複数レベルでのTrisoupを許可するとき、すなわち、trisoup_multilevel_enabled_flagの値が「1」の時は、全Trisoup階層数は、(最大Trisoupノードサイズ-最小Trisoupノードサイズ+1)で定義できる。
【0163】
すなわち、かかる場合、全Trisoup階層数は、(log2_trisoup_max_node_size_minus3―log2_trisoup_min_node_size_minus3+1)で定義できる。
【0164】
複数レベルでのTrisoupを許可しないとき、すなわち、trisoup_multilevel_enabled_flagの値が「0」の時は、全Trisoup階層数は、1である。
【0165】
全てのTrisoup階層の処理が完了した場合は、ツリー合成部2020は、ステップS807へ進み、処理を終了する。全てのTrisoup階層の処理が完了していない場合は、ツリー合成部2020は、ステップS803へ移る。
【0166】
ステップS803において、ツリー合成部2020は、当該Trisoup階層におけるユニークセグメント数を復号する。ユニークセグメント数は、当該Trisoup階層に属するTrisoupノードを構成する辺の数である。
【0167】
ステップS803では、ツリー合成部2020は、上述のように、ユニークセグメント数を復号する代わりに、当該Trisoup階層にユニークセグメントが(1つ以上)存在するか否かを示すフラグを復号してもよい。
【0168】
更に、複数レベルでのTrisoupを許可しないとき、すなわち、trisoup_multilevel_enabled_flagの値が「0」の時は、当該Trisoup階層にユニークセグメントが存在することは自明であるため、ツリー合成部2020は、当該Trisoup階層にユニークセグメントが(1つ以上)存在するか否かを示すフラグの復号を省略してもよい。
【0169】
ツリー合成部2020は、ユニークセグメント数を復号した後、ステップS804へ移る。
【0170】
ステップS804において、ツリー合成部2020は、当該Trisoup階層に属するユニークセグメント数を確認する。
【0171】
ユニークセグメント数が0の場合、すなわち、当該Trisoup階層にはTrisoupノードが1つも含まれない場合は、ツリー合成部2020は、ステップS802へ進み、次のTrisoup階層の処理へ移る。
【0172】
ユニークセグメント数が0より大きい場合は、ツリー合成部2020は、ステップS805へ移る。
【0173】
なお、ステップS803で当該Trisoup階層にユニークセグメントが(1つ以上)存在するか否かを示すフラグを復号した場合、ツリー合成部2020は、当該Trisoup階層にユニークセグメントが存在する場合は、当該Trisoup階層におけるユニークセグメント数を復号した後、ステップS805へ進み、当該Trisoup階層にユニークセグメントが存在しない場合はステップS802へ進む。
【0174】
ステップS805において、ツリー合成部2020は、各ユニークセグメントに対してTrisoup処理に用いる頂点が含まれるか否かを復号する。
【0175】
なお、各ユニークセグメントに対して存在できる頂点は、1点のみに制限してもよい。この場合、頂点が存在するユニークセグメント数が=頂点数と解釈できる。
【0176】
ツリー合成部2020は、当該Trisoup階層の全てのユニークセグメントについて頂点の有無を復号した後、ステップS806へ移る。
【0177】
ステップS806において、ツリー合成部2020は、ステップS805において頂点が存在すると判定された各ユニークセグメントに対して、各ユニークセグメント上のどこに頂点が存在するのかという位置情報を復号する。
【0178】
位置情報は、例えば、当該Trisoup階層におけるTrisoupノードサイズがL(2のL乗)の場合、Lビットの等長符号で符号化されていてもよい。
【0179】
ツリー合成部2020は、当該Trisoup階層において、頂点が存在する全てのユニークセグメントに対して頂点位置を復号した後、ステップS802へ移り、次のTrisoup階層の処理へ進む。
【0180】
(点群符号化装置100)
以下、図9を参照して、本実施形態に係る点群符号化装置100について説明する。図9は、本実施形態に係る点群符号化装置100の機能ブロックの一例について示す図である。
【0181】
図9に示すように、点群符号化装置100は、座標変換部1010と、幾何情報量子化部1020と、ツリー解析部1030と、近似表面解析部1040と、幾何情報符号化部1050と、幾何情報再構成部1060と、色変換部1070と、属性転移部1080と、RAHT部1090と、LoD算出部1100と、リフティング部1110と、属性情報量子化部1120と、属性情報符号化部1130と、アップサンプル部1140と、フレームバッファ1150とを有する。
【0182】
座標変換部1010は、入力点群の3次元座標系から、任意の異なる座標系への変換処理を行うよう構成されている。座標変換は、例えば、入力点群を回転することにより、入力点群のx、y、z座標を任意のs、t、u座標に変換してもよい。また、変換のバリエーションの1つとして、入力点群の座標系をそのまま使用してもよい。
【0183】
幾何情報量子化部1020は、座標変換後の入力点群の位置情報の量子化及び座標が重複する点の除去を行うように構成されている。なお、量子化ステップサイズが1の場合は、入力点群の位置情報と量子化後の位置情報とが一致する。すなわち、量子化ステップサイズが1の場合は、量子化を行わない場合と等価になる。
【0184】
ツリー解析部1030は、量子化後の点群の位置情報を入力として、後述のツリー構造に基づいて、符号化対象空間のどのノードに点が存在するかについて示すoccupancy codeを生成するように構成されている。
【0185】
ツリー解析部1030は、本処理において、符号化対象空間を再帰的に直方体で区切ることにより、ツリー構造を生成するように構成されている。
【0186】
ここで、ある直方体内に点が存在する場合、かかる直方体を複数の直方体に分割する処理を、直方体が所定のサイズになるまで再帰的に実行することでツリー構造を生成することができる。なお、かかる各直方体をノードと呼ぶ。また、ノードを分割して生成される各直方体を子ノードと呼び、子ノード内に点が含まれるか否かについて0又は1で表現したものがoccupancy codeである。
【0187】
以上のように、ツリー解析部1030は、所定のサイズになるまでノードを再帰的に分割しながら、occupancy codeを生成するように構成されている。
【0188】
本実施形態では、上述の直方体を常に立方体として8分木分割を再帰的に行う「Octree」と呼ばれる手法、及び、8分木分割に加え、4分木分割及び2分木分割を行う「QtBt」と呼ばれる手法を使用することができる。
【0189】
ここで、「QtBt」を使用するか否かについては、制御データとして点群復号装置200に伝送される。
【0190】
或いは、任意のツリー構成を用いるPredicitive codingを使用するように指定されてもよい。かかる場合、ツリー解析部1030が、ツリー構造を決定し、決定されたツリー構造は、制御データとして点群復号装置200へ伝送される。
【0191】
例えば、ツリー構造の制御データは、図7及び図8で説明した手順で復号できるよう構成されていてもよい。
【0192】
近似表面解析部1040は、ツリー解析部1030によって生成されたツリー情報を用いて、近似表面情報を生成するように構成されている。
【0193】
近似表面情報は、例えば、物体の3次元点群データを復号する際等において、点群が物体表面に密に分布しているような場合に、個々の点群を復号するのではなく、点群の存在領域を小さな平面で近似して表現したものである。
具体的には、近似表面解析部1040は、例えば、「Trisoup」と呼ばれる手法で、近似表面情報を生成するように構成されていてもよい。また、Lidar等で取得した疎な点群を復号する場合は、本処理を省略することができる。
【0194】
幾何情報符号化部1050は、ツリー解析部1030によって生成されたoccupancy code及び近似表面解析部1040によって生成された近似表面情報等のシンタックスを符号化してビットストリーム(幾何情報ビットストリーム)を生成するように構成されている。ここで、ビットストリームには、例えば、図4で説明したシンタックスを含まれていてもよい。
【0195】
符号化処理は、例えば、コンテキスト適応二値算術符号化処理である。ここで、例えば、シンタックスは、位置情報の復号処理を制御するための制御データ(フラグやパラメータ)を含む。
【0196】
幾何情報再構成部1060は、ツリー解析部1030によって生成されたツリー情報及び近似表面解析部1040によって生成された近似表面情報に基づいて、符号化対象の点群データの各点の幾何情報(符号化処理が仮定している座標系、すなわち、座標変換部1010における座標変換後の位置情報)を再構成するように構成されている。
【0197】
アップサンプル部1140は、幾何情報再構成部1060によって再構成された幾何情報を入力として、例えば、図5及び図6で説明したアップサンプリングを行うように構成されている。
【0198】
フレームバッファ1150は、アップサンプル部1140でアップサンプリングされた点群を入力とし、参照フレームとして保存するように構成されている。
【0199】
保存された参照フレームは、ツリー解析部1030において時間的に異なるフレームのインター予測を行う場合に、フレームバッファ1150から読み出されて参照フレームとして使用される。
【0200】
ここで、各フレームに対してどの時刻の参照フレームを用いるかどうかが、例えば、符号化効率を表すコスト関数の値に基づいて決定され、使用する参照フレームの情報が制御データとして点群復号装置200へ伝送されてもよい。
【0201】
なお、ここでは、アップサンプル部1140でアップサンプリングした後にフレームバッファ1150に保存する場合の例を説明したが、この順番は逆でもよい。
【0202】
すなわち、幾何情報再構成部1060から出力される幾何情報が参照フレームとしてフレームバッファ1150へ保存され、その後、ツリー解析部1030にてインター予測を行う際に、フレームバッファ1150に保存されていた参照フレームがアップサンプル部1140でアップサンプリングされてからツリー解析部1030に入力されてもよい。
【0203】
さらに別の例として、アップサンプル部1140は、ツリー解析部1030内部に含まれるよう構成されていてもよい。
【0204】
色変換部1070は、入力の属性情報が色情報であった場合に、色変換を行うように構成されている。色変換は、必ずしも実行する必要は無く、色変換処理の実行の有無については、制御データの一部として符号化され、点群復号装置200へ伝送される。
【0205】
属性転移部1080は、入力点群の位置情報、幾何情報再構成部1060における再構成後の点群の位置情報及び色変換部1070での色変化後の属性情報に基づいて、属性情報の歪みが最小となるように属性値を補正するように構成されている。具体的な補正方法は、例えば、非特許文献2に記載の方法を適用できる。
【0206】
RAHT部1090は、属性転移部1080による転移後の属性情報及び幾何情報再構成部1060によって生成された幾何情報を入力とし、RAHT(Region Adaptive Hierarchical Transform)と呼ばれるHaar変換の一種を用いて、各点の残差情報を生成するように構成されている。RAHTの具体的な処理としては、例えば、非特許文献2に記載の方法を用いることができる。
【0207】
LoD算出部1100は、幾何情報再構成部1060によって生成された幾何情報を入力とし、LoD(Level of Detail)を生成するように構成されている。
【0208】
LoDは、ある点の属性情報から、他のある点の属性情報を予測し、予測残差を符号化或いは復号するといった予測符号化を実現するための参照関係(参照する点及び参照される点)を定義するための情報である。
【0209】
言い換えると、LoDは、幾何情報に含まれる各点を複数のレベルに分類し、下位のレベルに属する点については上位のレベルに属する点の属性情報を用いて属性を符号化或いは復号するといった階層構造を定義した情報である。
【0210】
LoDの具体的な決定方法としては、例えば、非特許文献2に記載の方法を用いてもよい。
【0211】
リフティング部1110は、LoD算出部1100によって生成されたLoD及び属性転移部1080での属性転移後の属性情報を用いて、リフティング処理により残差情報を生成するように構成されている。
【0212】
リフティングの具体的な処理としては、例えば、非特許文献2に記載の方法を用いてもよい。
【0213】
属性情報量子化部1120は、RAHT部1090又はリフティング部1110から出力される残差情報を量子化するように構成されている。ここで、量子化ステップサイズが1の場合は、量子化を行わない場合と等価である。
【0214】
属性情報符号化部1130は、属性情報量子化部1120から出力される量子化後の残差情報等をシンタックスとして符号化処理を行い、属性情報に関するビットストリーム(属性情報ビットストリーム)を生成するように構成されている。
【0215】
符号化処理は、例えば、コンテキスト適応二値算術符号化処理である。ここで、例えば、シンタックスは、属性情報の復号処理を制御するための制御データ(フラグ及びパラメータ)を含む。
【0216】
点群符号化装置100は、以上の処理により、点群内の各点の位置情報及び属性情報を入力として符号化処理を行い、幾何情報ビットストリーム及び属性情報ビットストリームを出力するように構成されている。
【0217】
また、上述の点群符号化装置100及び点群復号装置200は、コンピュータに各機能(各工程)を実行させるプログラムであって実現されていてもよい。
【0218】
なお、上記の各実施形態では、本発明を点群符号化装置100及び点群復号装置200への適用を例にして説明したが、本発明は、かかる例のみに限定されるものではなく、点群符号化装置100及び点群復号装置200の各機能を備えた点群符号化/復号システムにも同様に適用できる。
【産業上の利用可能性】
【0219】
なお、本実施形態によれば、例えば、動画像通信において総合的なサービス品質の向上を実現できることから、国連が主導する持続可能な開発目標(SDGs)の目標9「レジリエントなインフラを整備し、持続可能な産業化を推進するとともに、イノベーションの拡大を図る」に貢献することが可能となる。
【符号の説明】
【0220】
10…点群処理システム
100…点群符号化装置
1010…座標変換部
1020…幾何情報量子化部
1030…ツリー解析部
1040…近似表面解析部
1050…幾何情報符号化部
1060…幾何情報再構成部
1070…色変換部
1080…属性転移部
1090…RAHT部
1100…LoD算出部
1110…リフティング部
1120…属性情報量子化部
1130…属性情報符号化部
1140…アップサンプル部
1150…フレームバッファ
200…点群復号装置
2010…幾何情報復号部
2020…ツリー合成部
2030…近似表面合成部
2040…幾何情報再構成部
2050…逆座標変換部
2060…属性情報復号部
2070…逆量子化部
2080…RAHT部
2090…LoD算出部
2100…逆リフティング部
2110…逆色変換部
2120…アップサンプリング部
2130…フレームバッファ

図1
図2
図3
図4
図5
図6A
図6B
図7
図8
図9
図10