(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-10-17
(45)【発行日】2024-10-25
(54)【発明の名称】点群復号装置、点群復号方法及びプログラム
(51)【国際特許分類】
G06T 9/00 20060101AFI20241018BHJP
H04N 19/597 20140101ALI20241018BHJP
【FI】
G06T9/00
H04N19/597
(21)【出願番号】P 2022001468
(22)【出願日】2022-01-07
【審査請求日】2024-01-26
【国等の委託研究の成果に係る記載事項】(出願人による申告)令和元年度、総務省、「多様な用途、環境下での高精細映像の活用に資する次世代映像伝送・通信技術の研究開発」委託事業、産業技術力強化法第17条の適用を受ける特許出願
(73)【特許権者】
【識別番号】000208891
【氏名又は名称】KDDI株式会社
(74)【代理人】
【識別番号】110001564
【氏名又は名称】フェリシテ弁理士法人
(72)【発明者】
【氏名】海野 恭平
(72)【発明者】
【氏名】河村 圭
【審査官】岩井 健二
(56)【参考文献】
【文献】国際公開第2021/261142(WO,A1)
【文献】国際公開第2021/256486(WO,A1)
【文献】Antoine Dricot, and Joao Ascenso,Adaptive Multi-level Triangle Soup for Geometry-based Point Cloud Coding,2019 IEEE 21st International Workshop on Multimedia Signal Processing (MMSP),IEEE,2019年09月,pp.1-6
【文献】Chaofei Wang, et al.,Point-Voting based Point Cloud Geometry Compression,2021 IEEE 23rd International Workshop on Multimedia Signal Processing (MMSP),IEEE,2021年10月,pp.1-5
【文献】Khaled Mammou, Philip A. Chou, David Flynn, Maja Krivokuca, Ohji Nakagami and Toshiyasu Sugio,G-PCC codec description v2,CODING OF MOVING PICTURES AND AUDIO,INTERNATIONAL ORGANISATION FOR STANDARDISATION,2019年01月,pp.2-3,17-19
(58)【調査した分野】(Int.Cl.,DB名)
G06T 9/00 - 9/40
H04N 19/00 - 19/98
(57)【特許請求の範囲】
【請求項1】
点群復号装置であって、
複数の投影面候補の中から、ノードの各辺上に存在する複数の頂点を前記投影面候補の各々に投影した際に前記頂点で定義される多角形の面積が最大となる投影面を、投影面として選択するように構成されている近似表面合成部を備えることを特徴とする点群復号装置。
【請求項2】
点群復号方法であって、
複数の投影面候補の中から、ノードの各辺上に存在する複数の頂点を前記投影面候補の各々に投影した際に前記頂点で定義される多角形の面積が最大となる投影面を、投影面として選択する工程を備えることを特徴とする点群復号方法。
【請求項3】
コンピュータを、点群復号装置として機能させるプログラムであって、
前記点群復号装置は、複数の投影面候補の中から、ノードの各辺上に存在する複数の頂点を前記投影面候補の各々に投影した際に前記頂点で定義される多角形の面積が最大となる投影面を、投影面として選択するように構成されている近似表面合成部を備えることを特徴とするプログラム。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、点群復号装置、点群復号方法及びプログラムに関する。
【背景技術】
【0002】
非特許文献1では、Trisoupにおいて、ノードに属する頂点座標の一次元的な広がりを評価することで投影面を決定する技術が開示されている。
【先行技術文献】
【非特許文献】
【0003】
【文献】G-PCC Future Enhancement、ISO/IEC JTC1/SC29/WG11 N19328
【発明の概要】
【発明が解決しようとする課題】
【0004】
しかしながら、非特許文献1の方法では、頂点を投影面に投影した際の座標の2次元的な広がりを考慮できていないため、適切な投影面が選択できず、復号点群の主観画質が損なわれることがあるという問題点があった。
【0005】
そこで、本発明は、上述の課題に鑑みてなされたものであり、復号点群の主観画質を向上させることができる点群復号装置、点群復号方法及びプログラムを提供することを目的とする。
【課題を解決するための手段】
【0006】
本発明の第1の特徴は、点群復号装置であって、複数の投影面候補の中から、ノードの各辺上に存在する複数の頂点を前記投影面候補の各々に投影した際に前記頂点で定義される多角形の面積が最大となる投影面を、投影面として選択するように構成されている近似表面合成部を備えることを要旨とする。
【0007】
本発明の第2の特徴は、点群復号装置であって、ノードの各辺を三次元座標のどの座標軸と平行かどうかで分類し、各座標軸に分類された辺上の頂点の数を用いて、複数の投影面候補の中から投影面を決定するように構成されている近似表面合成部を備えることを要旨とする。
【0008】
本発明の第3の特徴は、点群復号方法であって、複数の投影面候補の中から、ノードの各辺上に存在する複数の頂点を前記投影面候補の各々に投影した際に前記頂点で定義される多角形の面積が最大となる投影面を、投影面として選択する工程を備えることを要旨とする。
【0009】
本発明の第4の特徴は、コンピュータを、点群復号装置として機能させるプログラムであって、前記点群復号装置は、複数の投影面候補の中から、ノードの各辺上に存在する複数の頂点を前記投影面候補の各々に投影した際に前記頂点で定義される多角形の面積が最大となる投影面を、投影面として選択するように構成されている近似表面合成部を備えることを要旨とする。
【発明の効果】
【0010】
本発明によれば、復号点群の主観画質を向上させることができる点群復号装置、点群復号方法及びプログラムを提供することができる。
【図面の簡単な説明】
【0011】
【
図1】
図1は、一実施形態に係る点群処理システム10の構成の一例を示す図である。
【
図2】
図2は、一実施形態に係る点群復号装置200の機能ブロックの一例を示す図である。
【
図3】
図3は、一実施形態に係る点群復号装置200の幾何情報復号部2010で受信する符号化データ(ビットストリーム)の構成の一例を示す図である。
【
図4】
図4は、GPS2011のシンタックス構成の一例を示す図である。
【
図5】
図5は、GSH2012のシンタックス構成の一例を示す図である。
【
図6】
図6は、一実施形態に係る点群復号装置200のツリー合成部2020における処理の一例を示すフローチャートである
【
図7】
図7は、一実施形態に係る点群復号装置200のツリー合成部2020によるノード毎のoccpancy codeの復号処理の一例を示すフローチャートである。
【
図8】
図8は、一実施形態に係る点群復号装置200のツリー合成部2020によるインター予測を用いて4種類のコンテクスト(no pred/pred0/pred1/predL)からいずれか1つを選択する処理の一例を示すフローチャートである。
【
図9】
図9は、一実施形態に係る点群復号装置200の近似表面合成部2030の処理の一例を示すフローチャートである。
【
図10】
図10は、一実施形態に係る点群復号装置200の近似表面合成部2030によるTrisoupの頂点位置の復号処理の一例を示すフローチャートである。
【
図11】
図11は、
図10におけるステップS1006の処理の一例を説明するための図である。
【
図12】
図12は、
図10におけるステップS1006の処理の一例を説明するための図である。
【
図13】
図13は、
図10におけるステップS1006の処理の別の一例を説明するための図である。
【
図14】
図14は、
図10におけるステップS1006の処理の別の一例を説明するための図である。
【
図15】
図15は、
図9におけるステップS902の処理の一例を説明するための図である。
【
図16】
図16は、
図9におけるステップS902の処理の一例を説明するための図である。
【
図17】
図17は、
図9におけるステップS902の処理の別の一例を説明するための図である。
【
図18】
図18は、
図9におけるステップS902の処理の別の一例を説明するための図である。
【
図19】
図19は、
図9におけるステップS902の処理の別の一例を説明するための図である。
【
図20】
図20は、
図9におけるステップS902の処理の別の一例を説明するための図である。
【
図21】
図21は、一実施形態に係る点群符号化装置100の機能ブロックの一例を示す図である。
【
図22】
図22は、
図9におけるステップS902の処理の一例を説明するための図である。
【発明を実施するための形態】
【0012】
以下、本発明の実施の形態について、図面を参照しながら説明する。なお、以下の実施形態における構成要素は、適宜、既存の構成要素等との置き換えが可能であり、また、他の既存の構成要素との組み合わせを含む様々なバリエーションが可能である。したがって、以下の実施形態の記載をもって、特許請求の範囲に記載された発明の内容を限定するものではない。
【0013】
(第1実施形態)
以下、
図1~
図22を参照して、本発明の第1実施形態に係る点群処理システム10について説明する。
図1は、本実施形態に係る実施形態に係る点群処理システム10を示す図である。
【0014】
図1に示すように、点群処理システム10は、点群符号化装置100及び点群復号装置200を有する。
【0015】
点群符号化装置100は、入力点群信号を符号化することによって符号化データ(ビットストリーム)を生成するように構成されている。点群復号装置200は、ビットストリームを復号することによって出力点群信号を生成するように構成されている。
【0016】
なお、入力点群信号及び出力点群信号は、点群内の各点の位置情報と属性情報とから構成される。属性情報は、例えば、各点の色情報や反射率である。
【0017】
ここで、かかるビットストリームは、点群符号化装置100から点群復号装置200に対して伝送路を介して送信されてもよい。また、ビットストリームは、記憶媒体に格納された上で、点群符号化装置100から点群復号装置200に提供されてもよい。
【0018】
(点群復号装置200)
以下、
図2を参照して、本実施形態に係る点群復号装置200について説明する。
図2は、本実施形態に係る点群復号装置200の機能ブロックの一例について示す図である。
【0019】
図2に示すように、点群復号装置200は、幾何情報復号部2010と、ツリー合成部2020と、近似表面合成部2030と、幾何情報再構成部2040と、逆座標変換部2050と、属性情報復号部2060と、逆量子化部2070と、RAHT部2080と、LoD算出部2090と、逆リフティング部2100と、逆色変換部2110と、フレームバッファ2120とを有する。
【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によって再構成された幾何情報を入力として、参照フレームとして保存するように構成されている。保存した参照フレームは、ツリー合成部2020において時間的に異なるフレームのインター予測を行う場合に、フレームバッファ2120から読み出されて参照フレームとして使用される。
【0034】
ここで、各フレームに対してどの時刻の参照フレームを用いるかどうかは、例えば、点群符号化装置100からビットストリームとして伝送されてくる制御データに基づいて決定されてもよい。
【0035】
属性情報復号部2060は、点群符号化装置100から出力されるビットストリームのうち、属性情報に関するビットストリーム(属性情報ビットストリーム)を入力とし、シンタックスを復号するように構成されている。
【0036】
復号処理は、例えば、コンテクスト適応二値算術復号処理である。ここで、例えば、シンタックスは、属性情報の復号処理を制御するための制御データ(フラグ及びパラメータ)を含む。
【0037】
また、属性情報復号部2060は、復号したシンタックスから、量子化済み残差情報を復号するように構成されている。
【0038】
逆量子化部2070は、属性情報復号部2060によって復号された量子化済み残差情報と、属性情報復号部2060によって復号された制御データの一つである量子化パラメータとを元に、逆量子化処理を行い、逆量子化済み残差情報を生成するように構成されている。
【0039】
逆量子化済み残差情報は、復号対象の点群の特徴に応じて、RAHT部2080及びLoD算出部2090のいずれかに出力される。いずれに出力されるかは、属性情報復号部2060によって復号される制御データによって指定される。
【0040】
RAHT部2080は、逆量子化部2070によって生成された逆量子化済み残差情報及び幾何情報再構成部2040によって生成された幾何情報を入力とし、RAHT(Region Adaptive Hierarchical Transform)と呼ばれるHaar変換(復号処理においては、逆Haar変換)の一種を用いて、各点の属性情報を復号するように構成されている。RAHTの具体的な処理としては、例えば、文献1([PCC]An exploratory model for inter geometry-based PCC、ISO/IEC JTC1/SC29/WG11 m44754)に記載の方法を用いることができる。
【0041】
LoD算出部2090は、幾何情報再構成部2040によって生成された幾何情報を入力とし、LoD(Level of Detail)を生成するように構成されている。
【0042】
LoDは、ある点の属性情報から、他のある点の属性情報を予測し、予測残差を符号化或いは復号するといった予測符号化を実現するための参照関係(参照する点及び参照される点)を定義するための情報である。
【0043】
言い換えると、LoDは、幾何情報に含まれる各点を複数のレベルに分類し、下位のレベルに属する点については上位のレベルに属する点の属性情報を用いて属性を符号化或いは復号するといった階層構造を定義した情報である。
【0044】
LoDの具体的な決定方法としては、例えば、上述の文献1に記載の方法を用いてもよい。
【0045】
逆リフティング部2100は、LoD算出部2090によって生成されたLoD及び逆量子化部2070によって生成された逆量子化済み残差情報を用いて、LoDで規定した階層構造に基づいて各点の属性情報を復号するように構成されている。逆リフティングの具体的な処理としては、例えば、上述の文献1に記載の方法を用いることができる。
【0046】
逆色変換部2110は、復号対象の属性情報が色情報であり且つ点群符号化装置100側で色変換が行われていた場合に、RAHT部2080又は逆リフティング部2100から出力される属性情報に逆色変換処理を行うように構成されている。かかる逆色変換処理の実行の有無については、属性情報復号部2060によって復号された制御データによって決定される。
【0047】
点群復号装置200は、以上の処理により、点群内の各点の属性情報を復号して出力するように構成されている。
【0048】
(幾何情報復号部2010)
以下、
図3~
図5を用いて幾何情報復号部2010で復号される制御データについて説明する。
【0049】
図3は、幾何情報復号部2010で受信する符号化データ(ビットストリーム)の構成の一例である。
【0050】
第1に、ビットストリームは、GPS2011を含んでいてもよい。GPS2011は、ジオメトリパラメータセットとも呼ばれ、幾何情報の復号に関する制御データの集合である。具体例については後述する。各GPS2011は、複数のGPS2011が存在する場合に個々を識別するためのGPS id情報を少なくとも含む。
【0051】
第2に、ビットストリームは、GSH2012A/2012Bを含んでいてもよい。GSH2012A/2012Bは、ジオメトリスライスヘッダ或いはジオメトリデータユニットヘッダとも呼ばれ、後述するスライスに対応する制御データの集合である。以降では、スライスという呼称を用いて説明するが、スライスをデータユニットと読み替えることもできる。具体例については後述する。GSH2012A/2012Bは、各GSH2012A/2012Bに対応するGPS2011を指定するためのGPS id情報を少なくとも含む。
【0052】
第3に、ビットストリームは、GSH2012A/2012Bの次に、スライスデータ2013A/2013Bを含んでいてもよい。スライスデータ2013A/2013Bには、幾何情報を符号化したデータが含まれている。スライスデータ2013A/2013Bの一例としては、後述するoccupancy codeが挙げられる。
【0053】
以上のように、ビットストリームは、各スライスデータ2013A/2013Bに、1つずつGSH2012A/2012B及びGPS2011が対応する構成となる。
【0054】
上述のように、GSH2012A/2012Bにて、どのGPS2011を参照するかをGPS id情報で指定するため、複数のスライスデータ2013A/2013Bに対して共通のGPS2011を用いることができる。
【0055】
言い換えると、GPS2011は、スライスごとに必ずしも伝送する必要がない。例えば、
図3のように、GSH2012B及びスライスデータ2013Bの直前では、GPS2011を符号化しないようなビットストリームの構成とすることもできる。
【0056】
なお、
図3の構成は、あくまで一例である。各スライスデータ2013A/2013Bに、GSH2012A/2012B及びGPS2011が対応する構成となっていれば、ビットストリームの構成要素として、上述以外の要素が追加されてもよい。
【0057】
例えば、
図3に示すように、ビットストリームは、シーケンスパラメータセット(SPS)2001を含んでいてもよい。また、同様に、伝送に際して、
図3と異なる構成に整形されてもよい。更に、後述する属性情報復号部2060で復号されるビットストリームと合成して単一のビットストリームとして伝送されてもよい。
【0058】
図4は、GPS2011のシンタックス構成の一例である。
【0059】
なお、以下で説明するシンタックス名は、あくまで一例である。以下で説明したシンタックスの機能が同様であれば、シンタックス名は異なっていても差し支えない。
【0060】
GPS2011は、各GPS2011を識別するためのGPS id情報(gps_geom_parameter_set_id)を含んでもよい。
【0061】
なお、
図4のDescriptor欄は、各シンタックスが、どのように符号化されているかを意味している。ue(v)は、符号無し0次指数ゴロム符号であることを意味し、u(1)は、1ビットのフラグであることを意味する。
【0062】
GPS2011は、ツリー合成部2020でインター予測を行うか否かを制御するフラグ(interprediction_enabled_flag)を含んでもよい。
【0063】
例えば、interprediction_enabled_flagの値が「0」の時はインター予測を行わないと定義し、interprediction_enabled_flagの値が「1」の時はインター予測を行うと定義してもよい。
【0064】
なお、interprediction_enabled_flagは、GPS2011ではなくSPS2001に含んでいてもよい。
【0065】
GPS2011は、近似表面合成部2030でTrisoupを使用するか否かを制御するフラグ(trisoup_enabled_flag)を含んでもよい。
【0066】
例えば、trisoup_enabled_flagの値が「0」の時はTrisoupを使用しないと定義し、trisoup_enabled_flagの値が「1」の時はTrisoupを使用すると定義してもよい。
【0067】
幾何情報復号部2020は、Trisoupを使用するとき、すなわち、trisoup_enabled_flagの値が「1」の時、追加で以下のシンタックスを復号するように構成されていてもよい。
【0068】
なお、trisoup_enabled_flagは、GPS2011ではなくSPS2001に含まれていてもよい。
【0069】
GPS2011は、複数レベルでのTrisoupを許可するか否かを制御するフラグ(trisoup_multilevel_enabled_flag、第1フラグ)を含んでもよい。
【0070】
例えば、trisoup_multilevel_enabled_flagの値が「0」の時は複数レベルでのTrisoupを許可しない、すなわち、単一のレベルでのTrisoupを行うと定義し、trisoup_multilevel_enabled_flagの値が「1」の時は複数レベルでのTrisoupを許可すると定義してもよい。
【0071】
なお、当該シンタックスがGPS2011に含まれない場合、当該シンタックスの値を単一のレベルでのTrisoupを行う場合の値、すなわち、「0」とみなしてよい。
【0072】
なお、trisoup_multilevel_enabled_flagは、GPS2011ではなくSPS2001に含まれるよう定義してもよい。この場合、SPS2001にtrisoup_multilevel_enabled_flagが含まれていない場合、当該シンタックスの値を単一のレベルでのTrisoupを行う場合の値、すなわち、「0」とみなしてよい。
【0073】
図5は、GSH2012のシンタックス構成の一例である。なお、前述の通り、GSHは、GDUH(Geometry Data Unit Header)とも呼ばれる。
【0074】
幾何情報復号部2020は、複数レベルでのTrisoupを許可するとき、すなわち、trisoup_multilevel_enabled_flagの値が「1」の時、追加で以下のシンタックスを復号するように構成されていてもよい。
【0075】
GSH2012は、複数レベルでのTrisoupを許可するとき、Trisoupノードサイズの最大値を規定するシンタックス(log2_trisoup_max_node_size_minus2)を含んでもよい。
【0076】
当該シンタックスは、実際のTrisoupノードサイズの最大値について、2を底とする対数に変換した値として表現されていてもよい。更に、当該シンタックスは、実際のTrisoupノードサイズの最大値について、2を底とする対数に変換した後に2を引いた後の値として表現されていてもよい。
【0077】
GSH2012は、複数レベルでのTrisoupを許可するとき、Trisoupノードサイズの最小値を規定するシンタックス(log2_trisoup_min_node_size_minus2)を含んでもよい。
【0078】
当該シンタックスは、実際のTrisoupノードサイズの最小値について、2を底とする対数に変換した値として表現されていてもよい。更に、当該シンタックスは、実際のTrisoupノードサイズの最小値について、2を底とする対数に変換した後に2を引いた後の値として表現されていてもよい。
【0079】
また、当該シンタックスの値は、必ず0以上且つlog2_trisoup_max_node_size_minus2以下となるように制約されていてもよい。
【0080】
また、この時、
図5に示すようにtrisoup_depthをtrisoup_depth=log2_trisoup_max_node_size_minus2-log2_trisoup_min_node_size_minus2+1と定義してもよい。
【0081】
幾何情報復号部2020は、複数レベルでのTrisoupを許可しないとき、すなわち、trisoup_multilevel_enabled_flagの値が「0」の時、追加で以下のシンタックスを復号するように構成されていてもよい。
【0082】
GSH2012は、複数レベルでのTrisoupを許可しないとき、かつ、Trisoupを使用するとき、Trisoupノードサイズを規定するシンタックス(log2_trisoup_node_size_minus2)を含んでもよい。
【0083】
当該シンタックスは、実際のTrisoupノードサイズについて、2を底とする対数に変換した値として表現されていてもよい。更に、当該シンタックスは、実際のTrisoupノードサイズについて、2を底とする対数に変換した後に2を引いた後の値として表現されていてもよい。
【0084】
また、この時、
図5に示すようにtrisoup_depthをtrisoup_depth=1と定義してもよい。
【0085】
GSH2012は、Trisoupを使用するとき、復号点のサンプリング間隔を制御するシンタックス(trisoup_sampling_value_minus1)を含んでもよい。当該シンタックスの具体的な定義は、例えば、上述の文献1に記載の定義と同様とすることができる。
【0086】
GSH2012は、Trisoupを使用するとき、かつ、複数レベルでのTrisoupを許可するとき、階層i(i=0,...,trisoup_depth-1)ごとにユニークセグメントが対象階層に存在するか否かを示すフラグ(unique_segments_exist_flag[i])を含んでもよい。例えば、unique_segments_exist_flag[i]の値が「1」の場合は、階層iに少なくとも1つ以上のユニークセグメントが存在することを意味する。また、unique_segments_exist_flag[i]の値が「0」の場合は、階層iにユニークセグメントが1つも存在しないことを意味する。
【0087】
GSH2012は、階層i(i=0,...,trisoup_depth-1)ごとにユニークセグメントが対象階層に存在する場合、すなわち、unique_segments_exist_flag[i]の値が「1」の場合、追加で対象階層のユニークセグメント数を示すシンタックスのビット数を示すシンタックス(num_unique_segments_bits_minus1[i])及び対象階層のユニークセグメント数を示すシンタックス(num_unique_segments_minus1[i])を含んでもよい。
【0088】
ここで、num_unique_segments_bits_minus1[i]及びnum_unique_segments_minus1[i]の両方について、それぞれ本来の値から「1」を引いた値をシンタックスの値として符号化してもよい。
【0089】
(ツリー合成部2020)
以下、
図6~
図8を用いてツリー合成部2020の処理について説明する。
図6は、ツリー合成部2020における処理の一例を示すフローチャートである。なお、以下では「Octree」を使用してツリーを合成する場合の例について説明する。
【0090】
ステップS601において、ツリー合成部2020は、全てのDepthの処理が完了したかどうかを確認する。なお、Depth数は、点群符号化装置100から点群復号装置200に伝送するビットストリーム内に制御データとして含まれていてもよい。
【0091】
ツリー合成部2020は、対象Depthのノードサイズを算出する。「Octree」の場合、最初のDepthのノードサイズは、「2のDepth数乗」と定義されてもよい。すなわち、Depth数をNとする場合、最初のDepthのノードサイズは、2のN乗と定義されてもよい。
【0092】
また、2番目以降のDepthでのノードサイズは、Nの数を1つずつ減じていくことで定義されてもよい。すなわち、2番目のDepthのノードサイズは、「2の(N-1)乗」として定義され、3番目のDepthのノードサイズは、「2の(N-2)乗」として定義され、・・・と定義されてもよい。
【0093】
或いは、ノードサイズは、常に2のべき乗で定義されるため、単純に指数部分(N、N-1、N-2、等)の値をノードサイズと考えてもよい。以降の説明では、ノードサイズとは、指数部分の値を指すこととする。
【0094】
全てのDepthの処理が完了した場合は、ツリー合成部2020は、ステップS609へ進み、全てのDepthの処理が完了していない場合は、ツリー合成部2020は、ステップS602へ進む。
【0095】
言い換えると、対象Depthがn番目のDepthの時、(N-n)=0の場合は、ツリー合成部2020は、ステップS609へ進み、(N-n)>0の場合は、ツリー合成部2020は、ステップS602へ進む。
【0096】
ここで、Trisoupを使用するか否かを制御するフラグ(trisoup_enabled_flag)がTrisoupを使用することを示している場合、すなわち、trisoup_enabled_flagの値が「1」の時は、ツリー合成部2020は、処理するDepth数を、Trisoupノードサイズの最小値を規定するシンタックス(log2_trisoup_min_node_size_minus2)又はTrisoupノードサイズを規定するシンタックス(log2_trisoup_node_size_minus2)の値に基づいて変化させてもよい。かかる場合、例えば、以下のように定義してもよい。
【0097】
処理Depth数=全Depth数-(最小の)Trisoupノードサイズ
ここで、最小のTrisoupノードサイズについては、例えば、(log2_trisoup_min_node_size_minus2+2)で定義できる。同様に、Trisoupノードサイズについては、(log2_trisoup_node_size_minus2+2)で定義できる。
【0098】
この場合、全ての処理Depth数の処理が完了した場合は、ツリー合成部2020は、ステップS609へ進み、そうでない場合は、ツリー合成部2020は、ステップS602へ進む。
【0099】
言い換えると、(処理Depth数-n)=0の場合は、ツリー合成部2020は、ステップS609へ進み、(処理Depth数-n)>0の場合は、ツリー合成部2020は、ステップS602へ進む。
【0100】
また、ツリー合成部2020は、ステップS609へ進む際のノードサイズ(N-処理Depth数)を持つ全てのノードには、Trisoupが適用されると判定してもよい。
【0101】
ステップS602において、ツリー合成部2020は、対象Depthにて後述するTrisoup_applied_flagを復号する必要があるか否かを判定する。
【0102】
例えば、「複数レベルでのTrisoupが許可(trisoup_multilevel_enabled_flagの値が「1」)」で、且つ、「対象Depthのノードサイズ(N-n)が最大のTrisoupノードサイズ以下」の場合に、ツリー合成部2020は、「Trisoup_applied_flagの復号が必要である」と判定してもよい。
【0103】
また、ツリー合成部2020は、上述の条件が満たされない場合、「Trisoup_applied_flagの復号が必要ない」と判定してもよい。
【0104】
ここで、最大のTrisoupノードサイズについては、例えば、(log2_trisoup_max_node_size_minus3+2)で定義できる。
【0105】
上述の判定が完了したら、ツリー合成部2020は、ステップS703へ移る。
【0106】
ステップS603において、ツリー合成部2020は、対象Depthに含まれる全てのノードの処理が完了したかどうかを判定する。
【0107】
対象Depthの全てのノードの処理が完了したと判定した場合、ツリー合成部2020は、ステップS601へ移り、次のDepthの処理を行う。
【0108】
一方、対象Depthの全てのノードの処理が完了していない場合、ツリー合成部2020は、ステップS604へ移る。
【0109】
ステップS604において、ツリー合成部2020は、ステップS602で判定したTrisoup_applied_flagの復号の要否について確認する。
【0110】
Trisoup_applied_flagの復号が必要であると判定されている場合は、ツリー合成部2020は、ステップS605へ進み、Trisoup_applied_flagの復号が必要でないと判定されている場合は、ツリー合成部2020は、ステップS608へ移る。
【0111】
ステップS605において、ツリー合成部2020は、Trisoup_applied_flagを復号する。
【0112】
Trisoup_applied_flagは、対象ノードにTrisoupを適用するか否かを示す1ビットのフラグ(第2フラグ)である。例えば、かかるフラグの値が「1」の時に対象ノードにTrisoupを適用すると定義し、かかるフラグの値が「0」の時に対象ノードにTrisoupを適用しないと定義してもよい。
【0113】
ツリー合成部2020は、Trisoup_applied_flagを復号した後、ステップS606へ移る。
【0114】
ステップS606において、ツリー合成部2020は、ステップS605で復号したTrisoup_applied_flagの値を確認する。
【0115】
対象ノードにTrisoupを適用する場合、すなわち、Trisoup_applied_flagの値が「1」の場合は、ツリー合成部2020は、ステップS607へ移る。
【0116】
対象ノードにTrisoupを適用しない場合、すなわち、Trisoup_applied_flagの値が「0」の場合は、ツリー合成部2020は、ステップS608へ移る。
【0117】
ステップS607において、ツリー合成部2020は、対象ノードを、Trisoupを適用するノード、すなわち、Trisoupノードとして記憶する。かかる対象ノードに対しては、これ以上、「Octree」によるノードの分割を適用しないこととする。その後、ツリー合成部2020は、ステップS603に進み、次のノードの処理へ移る。
【0118】
ステップS608において、ツリー合成部2020は、occpancy codeと呼ばれる情報を復号する。
【0119】
occpancy codeは、「Octree」の場合は、対象ノードをx、y、z軸方向にそれぞれ半分に分割して、8つのノード(子ノードと呼ぶ)に分割した際に、それぞれの子ノード内に復号対象の点が含まれているか否かを示す情報である。
【0120】
例えば、occpancy codeは、各子ノードに対して1ビットの情報を割り当て、かかる1ビットの情報が「1」の場合は、かかる子ノード内に復号対象の点が含まれると定義され、かかる1ビットの情報が「0」の場合は、かかる子ノード内に復号対象の点が含まれないと定義されてもよい。
【0121】
ツリー合成部2020は、かかるoccpancy codeを復号する際に、各子ノードに復号対象の点が存在する確率を予め推定し、その確率に基づいて各子ノードに対応するビットをエントロピー復号してもよい。
【0122】
同様に、点群符号化装置100においては、エントロピー符号化してもよい。更に、かかる確率の推定に、インター予測を用いてもよい。インター予測の具体的な方法としては、例えば、上述の文献1に記載の方法を適用できる。更に、インター予測を行う際の参照点群に、アップサンプルした点群を用いてもよい。
【0123】
図7~8を用いて、インター予測を用いる場合のoccpancy codeの復号処理の具体例について説明する。
【0124】
図7は、ノード毎のoccpancy codeの復号処理の具体例を示すフローチャートである。言い換えると、
図7は、
図6のステップS608の処理の具体例を示すフローチャートである。
【0125】
図7に示すように、ステップS701において、ツリー合成部2020は、コンテクストの選択を行う。コンテクストは、後段の占有情報復号の際のエントロピー復号において使用する確率分布に対応している。
【0126】
図8は、インター予測を用いて4種類のコンテクスト(no pred/pred0/pred1/predL)からいずれか1つを選択する場合のフローチャートの一例である。
【0127】
以下、
図8を用いてコンテクスト選択の一例を説明する。なお、
図8では、コンテクストが4種類の例について説明するが、コンテクストの数は、4種類でなくともよい。
【0128】
図8に示すように、ステップS801において、ツリー合成部2020は、インター予測の精度を判定する。
【0129】
インター予測の精度については、例えば、対象ノードの親ノードにおける子ノード(Octreeの場合、8つの子ノード)について、選択したコンテクスト及び実際の点の有無によって判断できる。
【0130】
例えば、pred0のコンテクストを選択した子ノードについて、実際に点が存在しなかった場合を正解とし、実際に点が存在した場合を不正解とする。一方、pred1又はpredLを選択した子ノードについては、実際に点が存在した場合を正解とし、実際に点が存在しなかった場合を不正解とする。
【0131】
ここで、親ノードに属する子ノードについて、正解となった子ノードの数が予め定めた閾値より大きい場合、インター予測の精度は「良い」と判断できる。一方、親ノードに属する子ノードについて、正解となった子ノードの数が予め定めた閾値以下の場合、インター予測の精度は「悪い」と判断できる。
【0132】
インター予測の精度が「良い」と判断された場合、ツリー合成部2020は、ステップS802へ進む。インター予測の精度が「悪い」と判断された場合、ツリー合成部2020は、ステップS805へ進み、対象ノードに属する全ての子ノードについてコンテクストを「no pred」とし、処理を終了する。
【0133】
ステップS802において、ツリー合成部2020は、動き補償した参照フレームにおいて、対象ノードと同じ位置の領域に少なくとも1点の参照点が存在するか否かを確認する。
【0134】
対象ノードと同じ位置の領域に少なくとも1点の参照点が存在する場合、ツリー合成部2020は、ステップS803へ進む。一方、対象ノードと同じ位置の領域に参照点が1点もない場合、ツリー合成部2020は、ステップS805へ進み、対象ノードに属する全ての子ノードについてコンテクストを「no pred」とし、処理を終了する。
【0135】
ステップS803以降では、ツリー合成部2020は、対象ノードに属する子ノード毎に判定を行う。
【0136】
ステップS803において、ツリー合成部2020は、動き補償した参照フレームにおいて、対象子ノードと同じ位置の領域に少なくとも1点の参照点が存在するか否かを確認する。
【0137】
対象子ノードと同じ位置の領域に少なくとも1点の参照点が存在する場合、ツリー合成部2020は、ステップS804へ進む。一方、対象子ノードと同じ位置の領域に参照点が1点もない場合、ツリー合成部2020は、ステップS806へ進み、対象子ノードのコンテクストを「pred0」とする。
【0138】
対象ノードの全ての子ノードについてコンテクスト選択が完了していない場合、ツリー合成部2020は、ステップS803へ戻り、次の子ノードについて同様の処理を行う。
【0139】
対象ノードの全ての子ノードについてコンテクスト選択が完了した場合、ツリー合成部2020は、処理を終了する。
【0140】
ステップS804において、ツリー合成部2020は、動き補償した参照フレームにおいて、対象子ノードと同じ位置の領域に予め定めた閾値以上の数の参照点が存在するか否かを確認する。
【0141】
対象子ノードと同じ位置の領域に予め定めた閾値以上の数の参照点が存在する場合、ツリー合成部2020は、ステップS808へ進み、対象子ノードのコンテクストを「predL」とする。
【0142】
一方、対象子ノードと同じ位置の領域に予め定めた閾値未満の数の参照点しか存在しない場合、ツリー合成部2020は、ステップS807へ進み、対象子ノードのコンテクストを「pred1」とする。
【0143】
ステップS807又はS808の処理の後、対象ノードの全ての子ノードについてコンテクスト選択が完了していない場合、ツリー合成部2020は、ステップS804へ戻り、次の子ノードについて同様の処理を行う。
【0144】
対象ノードの全ての子ノードについてコンテクスト選択が完了した場合、ツリー合成部2020は、処理を終了する。
【0145】
以上のようにコンテクストを選択した後、ツリー合成部2020は、ステップS702へ進む。
【0146】
ステップS702において、ツリー合成部2020は、ステップS701で選択したコンテクストに基づいて、対象ノードの各子ノードの占有情報、すなわち、occpancy codeを復号する。
【0147】
ここで、コンテクストは、それぞれ独立した確率分布に対応している。後述するステップS703のコンテクスト更新によって、コンテクストごとに復号対象の点が存在する確率が学習される。
【0148】
なお、各コンテクストにおける確率分布の初期値は、例えば、点が存在する確率50%(=存在しない確率も50%)と定義することができる。
【0149】
ステップS702において、ツリー合成部2020は、コンテクストに対応する確率分布を基にエントロピー復号を行い、各子ノードに点が存在するか(「1」であるか)否か(「0」であるか)を復号する。occpancy codeの復号完了後、ツリー合成部2020は、ステップS703へ進む。
【0150】
ステップS703において、ツリー合成部2020は、コンテクストを更新する。
【0151】
例えば、ツリー合成部2020は、ステップS703において、各コンテクストにおいて、占有情報を復号した結果点が存在した場合、各コンテクストに紐づく確率分布を、点が存在する確率が高くなるように更新する。
【0152】
一方、ツリー合成部2020は、ステップS703において、各コンテクストにおいて、占有情報を復号した結果点が存在しなかった場合、各コンテクストに紐づく確率分布を、点が存在する確率が低くなるように更新する。
【0153】
コンテクストの更新が完了したら、ツリー合成部2020は、ステップS704へ進み、処理を終了する。
【0154】
ツリー合成部2020は、occpancy codeを復号した後、ステップS603へ進み、次のノードの処理へ移る。
【0155】
(近似表面合成部2030)
近似表面合成部2030は、
図6で説明したようにツリー合成部2020にてTrisoupノードと判定された各ノードについて、復号処理を行うように構成されている。
【0156】
以下、
図9~
図20を用いて近似表面合成部2030の処理の例について説明する。
【0157】
図9は、近似表面合成部2030の処理の一例を示すフローチャートである。
【0158】
図9に示すように、ステップS901において、近似表面合成部2030は、ノード毎の頂点位置を復号する。
【0159】
ここで、近似表面合成部2030は、複数レベルでのTrisoupを許可するとき、すなわち、trisoup_multilevel_enabled_flagの値が「1」の時は、最小Trisoupノードサイズにおけるノード毎に頂点位置を復号する。
【0160】
一方、近似表面合成部2030は、複数レベルでのTrisoupを許可しないとき、すなわち、trisoup_multilevel_enabled_flagの値が「0」の時は、Trisoupノードサイズにおけるノード毎に頂点位置を復号する。具体的な処理については後述する。
【0161】
頂点位置の復号が完了した後、近似表面合成部2030は、ステップS902へ進む。
【0162】
ステップS902において、近似表面合成部2030は、頂点位置を復号したノード毎(最小Trisoupノードサイズ、又は、Trisoupノードサイズにおけるノード毎)に、投影面を決定する。
【0163】
例えば、x軸、y軸、z軸の3つの軸があるとき、どれか一つの軸を縮退した平面を投影面と呼ぶ。
【0164】
ステップS902では、近似表面合成部2030は、上述の軸のうちどの軸を縮退するか、すなわち、x-y平面、x-z平面、y-z平面のうちどの平面を投影面とするかを決定する。具体的な処理については後述する。
【0165】
投影面を決定した後、近似表面合成部2030は、ステップS903へ進む。
【0166】
ステップS903において、近似表面合成部2030は、投影面に投影した頂点を、例えば反時計回りの順になるようにソートし、前記の順序に従ってindexを付与する。
【0167】
indexを付与した後、近似表面合成部2030は、ステップS904へ進む。
【0168】
ステップS904において、近似表面合成部2030は、上述のindex及び対象ノードに存在する頂点数に基づいて、三角形を生成する。
【0169】
例えば、近似表面合成部2030は、予め頂点数毎にどのindexから三角形を生成するかを定義した表を作成しておき、それを参照することで三角形を生成できる。具体的な表の例については、例えば、上述の文献1に記載の表を用いることができる。
【0170】
三角形を生成した後、近似表面合成部2030は、ステップS905へ進む。
【0171】
ステップS905において、近似表面合成部2030は、ステップS904で生成した三角形を基に、点を生成する。具体的な方法は、例えば、上述の文献1に記載の方法を用いることができる。
【0172】
全てのノードについて点の生成が完了した後、近似表面合成部2030は、ステップS906へ進み、処理を終了する。
【0173】
次に、ステップS901の頂点位置の復号について、処理の具体例を説明する。
図10は、Trisoupの頂点位置の復号処理の一例を示すフローチャートである。
【0174】
図10に示すように、ステップS1001において、近似表面合成部2030は、全Trisoup階層の処理が完了したかどうかを判定する。ここで、全Trisoup階層の数は、以下の通り定義できる。
【0175】
複数レベルでのTrisoupを許可するとき、すなわち、trisoup_multilevel_enabled_flagの値が「1」の時は、全Trisoup階層数は、(最大Trisoupノードサイズ-最小Trisoupノードサイズ+1)で定義できる。
【0176】
すなわち、かかる場合、全Trisoup階層数は、(log2_trisoup_max_node_size_minus2-log2_trisoup_min_node_size_minus2+1)で定義できる。
【0177】
複数レベルでのTrisoupを許可しないとき、すなわち、trisoup_multilevel_enabled_flagの値が「0」の時は、全Trisoup階層数は、1である。
【0178】
全てのTrisoup階層の処理が完了した場合は、近似表面合成部2030は、ステップS1007へ進む。全てのTrisoup階層の処理が完了していない場合は、近似表面合成部2030は、ステップS1002へ移る。
【0179】
ステップS1002において、近似表面合成部2030は、対象Trisoup階層に属するユニークセグメント数を確認する。
【0180】
ユニークセグメント数が「0」の場合、すなわち、対象Trisoup階層にはTrisoupノードが1つも含まれない場合は、近似表面合成部2030は、ステップS1001へ進み、次のTrisoup階層の処理へ移る。
【0181】
ユニークセグメント数が「0」より大きい場合は、近似表面合成部2030は、ステップS1003へ移る。
【0182】
ステップS1003において、近似表面合成部2030は、各ユニークセグメントに対してTrisoup処理に用いる頂点が含まれるか否かを復号する。
【0183】
なお、各ユニークセグメントに対して存在できる頂点は、1点のみに制限してもよい。この場合、頂点が存在するユニークセグメント数が頂点数と等しいと解釈できる。
【0184】
近似表面合成部2030は、対象Trisoup階層の全てのユニークセグメントについて頂点の有無を復号した後、ステップS1004へ移る。
【0185】
ステップS1004において、近似表面合成部2030は、ステップS1003において頂点が存在すると判定された各ユニークセグメントに対して、各ユニークセグメント上のどこに頂点が存在するのかという位置情報を復号する。
【0186】
位置情報は、例えば、対象Trisoup階層におけるTrisoupノードサイズがL(2のL乗)の場合、Lビットの等長符号で符号化されていてもよい。
【0187】
近似表面合成部2030は、対象Trisoup階層において、頂点が存在する全てのユニークセグメントに対して頂点位置を復号した後、ステップS1006へ進む。
【0188】
ステップS1006において、近似表面合成部2030は、対象Trisoup階層におけるノードサイズが最小Trisoupノードサイズの場合、何も処理をせずS1001へ進む。
【0189】
同様に、近似表面合成部2030は、複数レベルでのTrisoupが許可されていない場合、何も処理をせず、ステップS1001へ進む。
【0190】
そうでない場合、すなわち、複数レベルでのTrisoupが許可されており、かつ、対象Trisoup階層におけるノードサイズが最小Trisoupノードサイズより大きい場合は、近似表面合成部2030は、ステップS1004で復号した対象Trisoup階層に対応するノードサイズにおける頂点位置に基づいて、最小Trisoupノードサイズにおける頂点位置を生成する。具体的な処理例については後述する。
【0191】
最小ノードサイズにおける頂点位置生成が完了した後、近似表面合成部2030は、ステップS1001へ進む。
【0192】
ステップS1007において、近似表面合成部2030は、頂点位置の統合を行う。
【0193】
例えば、近似表面合成部2030は、ステップS1006において、大きなノードサイズでの頂点位置から、最小Trisoupノードサイズにおける頂点位置を生成した場合、ノードの各辺に頂点が2点以上生成される可能性がある。
【0194】
もし、頂点が2点以上生成されている辺があった場合、近似表面合成部2030は、これを1点に統合して、辺ごとに頂点が1点ずつになるようにする。
【0195】
例えば、近似表面合成部2030は、辺上に存在する頂点の座標の平均値をとることで、複数の点を1点に統合することができる。
【0196】
別の例としては、頂点の数が奇数の場合、近似表面合成部2030は、座標の中央値を持つ点を選択することで頂点を1つに絞ることができる。
【0197】
また、頂点の数が偶数の場合は、近似表面合成部2030は、座標の中央値を持つ2点を抽出した後、かかる2点の座標値の平均をとることで頂点を1つに絞ることができる。
【0198】
全ての辺についてそれぞれ頂点を1つずつに統合した後、近似表面合成部2030は、ステップS1008へ進み、処理を終了する。
【0199】
次に、前記ステップS1006の処理の具体例について説明する。
【0200】
以下、
図11及び
図12を用いて、上述のステップS1006の処理の一例を説明する。
【0201】
図12に、ステップS1004で復号した対象Trisoup階層に対応するノードサイズをN(ノードの一辺の長さが2のN乗)として、最小のTrisoupノードサイズをN-1とした場合の例を示す。
【0202】
ステップS1006の処理の目的は、
図12-1に示す対象Trisoup階層に対応するノードサイズ(
図12では、N)における頂点(
図12では、4点)から、
図12-3に示す最小のTrisoupノードサイズ(
図12では、N-1)における頂点(
図12では、9点)を生成することである。
【0203】
図11は、上述のステップS1006の処理の一例を示すフローチャートである。
【0204】
図11に示すように、近似表面合成部2030は、ステップS1004で復号した対象Trisoup階層に対応するノードサイズにおける頂点位置を入力として、ステップS1101~S1104の処理を行う。
【0205】
ステップS1101~S1104の処理については、
図9におけるステップS902~S905と同様な方法で実現できる。
【0206】
ここで、
図12-1は、ステップS1103の処理結果の例(すなわち、ステップS1104の入力データの例)を示し、
図12-2は、ステップS1104の処理結果の例を示す。
【0207】
図12-1に示すように、近似表面合成部2030は、ステップS1104では、
図12-1に示す三角形の面と整数座標位置との交点の全てに点を生成する。
【0208】
近似表面合成部2030は、
図12-1に示す三角形を基に、
図12-2に示すように点への変換を行った後、ステップS1105へ進む。
【0209】
ステップS1105において、近似表面合成部2030は、ステップS1104で生成した点から、最小のTrisoupノードサイズにおける頂点位置を決定する。
【0210】
具体的には、近似表面合成部2030は、例えば、ステップS1104で生成した点の中から、最小のTrisoupノードサイズに対応する各ノードの辺に隣接する点をそれぞれ抽出し、抽出した点の座標の平均値を求めることで、各辺に対する頂点位置を決定できる。
【0211】
例えば、近似表面合成部2030は、辺の位置がx軸方向に沿っている場合、例えば(x,y,z)=(a~a+2(N-1),b,c)を満たす位置に辺があった場合、例えば(a~a+2(N-1),b-1~b,c-1~c)の領域に存在する点を抽出し、それらの点のx軸座標の平均値eを算出することで、(e,b,c)を頂点位置として決定できる。
【0212】
近似表面合成部2030は、辺がy軸方向及びz軸方向に沿っている場合も、上記と同様に計算できる。
【0213】
なお、近似表面合成部2030は、辺に隣接する領域に点が存在しない場合は、かかる辺上には頂点を生成しない。
【0214】
以上のようにして、近似表面合成部2030は、例えば、
図12-3に示すように、最小Trisoupノードサイズにおける頂点位置を生成することができる。
【0215】
次に、
図13及び
図14を用いて、ステップS1106の処理の別の具体例について説明する。
【0216】
図13は、前記ステップS1006の処理の一例を示すフローチャートである。
【0217】
図13に示すように、近似表面合成部2030は、ステップS1004で復号した対象Trisoup階層に対応するノードサイズにおける頂点位置を入力として、ステップS1301~S1303の処理を行う。
【0218】
ステップS1301~S1303の処理については、
図9におけるステップS902~S904と同様な方法で実現できる。
【0219】
図14-1は、ステップS1303の処理結果の例を示している。
図14-1から分かる通り、ステップS1303の処理結果及び、ステップS1103の処理結果は同様である。
【0220】
近似表面合成部2030は、
図14-1に示すように、三角形を生成した後、ステップS1304へ進む。
【0221】
ステップS1304において、近似表面合成部2030は、ステップS1303で生成した各三角形の面と最小Trisoupノードサイズに対応するノードの各辺との交点に点を生成する。
【0222】
図14-2は、ステップS1304の処理結果の一例を示している。近似表面合成部2030は、各辺上に点を生成した後、ステップS1305へ進む。
【0223】
ステップS1305において、近似表面合成部2030は、ステップS1304において最小Trisoupノードサイズに対応する各辺上に生成された点を統合する。
【0224】
ステップS1304の処理は、各三角形面と辺との交点に点を生成するため、例えば、ある1つの辺に対して2つ以上の三角面が交差していた場合、同一辺上に2つ以上の頂点が生成される可能性がある。
【0225】
その場合、近似表面合成部2030は、同一の辺上に存在する点を統合して、辺ごとに頂点を一点とする様に処理してもよい。
【0226】
具体的には、例えば、辺上に存在する頂点の座標の平均値をとることで、複数の点を1点に統合することができる。
【0227】
別の例としては、頂点の数が奇数の場合、近似表面合成部2030は、座標の中央値を持つ点を選択することで頂点を1つに絞ることができる。
【0228】
また、頂点の数が偶数の場合は、近似表面合成部2030は、座標の中央値を持つ2点を抽出した後、かかる2点の座標値の平均をとることで頂点を1つに絞ることができる。
【0229】
近似表面合成部2030は、上述のように各辺上の点を統合した後、ステップS1306へ進み、処理を終了する。
【0230】
以上のように、本発明における近似表面合成部2030は、複数レベルでのTrisoupを許容する場合、
図10のステップS1004に示すように、頂点位置についてはTrisoupノードサイズ毎に復号し、ステップS1005に示すように、上述の頂点位置から最小Trisoupノードサイズにおける頂点位置を生成し、ステップS905に示すように、最小Trisoupノードサイズにおいて点を生成するように構成されていてもよい。
【0231】
言い換えると、近似表面合成部2030は、複数のノードサイズ毎に頂点の復号処理を実行し、単一のノードサイズで頂点に基づく点の再構成処理を実行するように構成されていてもよい。
【0232】
また、以上のように、近似表面合成部2030は、制御データから復号した最大ノードサイズ及び最小ノードサイズに基づいて、最大と最小との間の各ノードサイズにおいて頂点の復号処理を実行するように構成されており、かかるノードサイズが最小ノードサイズではない場合、復号した頂点に基づいて、最小ノードサイズにおける頂点位置を生成するように構成されており、単一のノードサイズを最小ノードサイズとするように構成されており、最小ノードサイズにおける頂点位置に基づいて、点の再構成処理を行うように構成されていてもよい。
このような構成とすることで、頂点位置の復号単位を可変とすることで点群の幾何的な特性に応じて頂点に係る情報の符号量を削減しつつ、点の再構成については単一且つ小さなノードサイズで実行することで、復号点群の主観品質を高めることができる。
【0233】
また、以上のように、近似表面合成部2030は、ノードサイズが最小ノードサイズではない場合、復号した頂点に基づいて点を生成し、生成した点のうち、かかるノードサイズのノードを最小ノードサイズで分割した際の各辺の近傍に存在する点の座標値に基づいて、最小ノードサイズにおける頂点位置を生成するように構成されていてもよい。
【0234】
このように、近似表面合成部2030における点の再構成処理の一部を流用して最小ノードサイズにおける頂点位置を生成することで、処理回路及び処理関数が流用できるため設計コストを下げることができる。
【0235】
また、以上のように、近似表面合成部2030は、ノードサイズが最小ノードサイズではない場合、復号した頂点に基づいて点を生成する際、かかるノードサイズのノードを最小ノードサイズで分割した際の各辺上にのみ点を生成するように構成されていてもよい。このように、生成する点数を最小限とすることで、当該処理に必要なメモリ量や、処理量を削減することができる。
【0236】
また、以上のように、近似表面合成部2030は、ノードサイズが最小ノードサイズではない場合、復号した頂点に基づいて点を生成する際、かかるノードサイズのノードを最小ノードサイズで分割した際の各辺上に複数の点が存在した場合、それらの点を統合し各辺上に頂点が1点ずつとなるように最小ノードサイズにおける頂点位置を生成するように構成されていてもよい。このように、各辺上に頂点数を1点ずつとなるように制限することで、点の再構成処理を簡素化することができる。
【0237】
また、以上のように、近似表面合成部2030は、ある辺上に、かかる辺に隣接する異なるノードサイズのノードから生成された複数の頂点が存在する場合、それらの点を統合し、各辺上に頂点が1点ずつとなるように頂点位置を生成するように構成されていてもよい。このような構成とすることで、点の再構成処理を簡素化することができる。
【0238】
また、以上のように、近似表面合成部2030は、ある辺上に、かかる辺に隣接する異なるノードサイズのノードから生成された複数の頂点が存在する場合、かかる隣接するノードのうち、最も小さなノードサイズを持つノードによって生成された頂点を、かかる辺の頂点位置とするように構成されていてもよい。このように、小さなノードサイズにおける頂点位置を使用するようにすることで、より局所的な特徴を再現した点群の再構成が可能となり、主観品質が向上する。
【0239】
次に、
図9におけるステップS902の処理の具体例について説明する。
【0240】
以下、
図15及び
図16を用いて、
図9におけるステップS902の処理の一例を説明する。
図15は、ステップS902の処理の一例を示すフローチャートである。
【0241】
図15に示すように、ステップS1501において、近似表面合成部2030は、頂点を各投影面に投影した際の頂点で形成される多角形の面積をそれぞれ算出する。
【0242】
図16に、ステップS1501の処理の具体例を示す。
【0243】
例えば、
図16-1に示すように、対象ノードについてA~Eの五つの頂点がある場合を考える。
【0244】
図16-2~
図16-4は、
図16-1に示す頂点を、それぞれの投影面に投影した際の図である。
【0245】
ここで、近似表面合成部2030は、各投影面における多角形の面積(
図16-2~
図16-4において、それぞれ網掛けになっている部分の面積)を算出する。
【0246】
具体的には、近似表面合成部2030は、各投影面における正方形の中心を原点Oとし、原点O、原点Oと隣り合う2つの頂点(例えば、
図16-2における点E及び点D)の計3点で構成される三角形の面積Sは、以下の式で算出できる。
【0247】
S=|E×D|/2
ここで、E及びDは、原点Oに対する点E及び点Dの三次元座標を示すベクトルを意味し、×記号は、ベクトルの外積を計算する演算子を意味し、|・|は、ベクトルのL2ノルムを意味している。
【0248】
近似表面合成部2030は、上述の事項を応用して、ステップS903と同様な方法で、各投影面における頂点を、例えば、反時計回りの順になるようにソートし、上述と同様な手法で、全ての隣り合う頂点同士と原点とで作られる三角形の面積を求めたうえで合計することで、
図16-2~
図16-4の網掛け部分の面積をそれぞれ算出することができる。
【0249】
以上では、原点Oを各投影面における正方形の中心と定義した場合について説明したが、原点Oは、各投影面の平面上であれば、他の位置に定義しても、上述と同様な方法で多角形の面積を算出することができる。
【0250】
例えば、近似表面合成部2030は、原点Oについて、投影面における正方形の辺上に位置してもよい。また、例えば、近似表面合成部2030は、各投影面に投影した頂点のうちの一点を、原点Oと定義してもよい。例えば、近似表面合成部2030は、各投影面に投影した頂点を反時計回りの順になるようにソートした後、先頭の頂点を原点Oとして用いてもよい。
【0251】
近似表面合成部2030は、以上のように各投影面における多角形の面積をそれぞれ算出した後、ステップS1502へ進む。
【0252】
ステップS1502において、近似表面合成部2030は、ステップS1501で求めた多角形の面積が最も大きい投影面を、投影面として決定する。
【0253】
近似表面合成部2030は、投影面を決定した後、ステップS1503へ進み、処理を終了する。
【0254】
なお、近似表面合成部2030は、
図15に示す手法で投影面を決定する場合、既にステップS1501において頂点をソートしているため、ステップS903の処理について省略することができる。
【0255】
以上のように、近似表面合成部2030は、ノードの各辺上に存在する複数の頂点を複数の投影面候補の各々に投影した際に、かかる頂点で定義される多角形の面積が最大となる投影面を、上述の投影面として選択するように構成されてもよい。
【0256】
このような構成とすることで、投影面上での2次元的な広がりが最も大きな投影面を選択できる。これにより、適切でない投影面を選択することで復号点群の主観画質が劣化することを防止することができる。
【0257】
以上のように、近似表面合成部2030は、所定の原点と、上述の投影面候補に投影した頂点のうち1つ(第1頂点)と、かかる第一頂点と隣り合う第2頂点と、の三点で構成される三角形の面積を、隣り合う全ての頂点のペアに対して算出することで、上述の多角形(三角形)の面積を算出するように構成されてもよい。
【0258】
このように、多角形を小領域に分割して面積を求めることで、それぞれの小領域の面積算出処理を並列に実行できるため、処理速度を向上させることができる。
【0259】
また、以上のように、近似表面合成部2030は、上述の原点から第1頂点を指す第1ベクトルと、上述の原点から第2頂点を指す第2ベクトルを定義し、かかる第1ベクトルと第2ベクトルとの外積を用いて、上述の三角形の面積を算出するように構成されていてもよい。このように、ベクトルの外積を用いて演算することで、他の処理で外積処理を行う場合は、処理回路又は処理関数を共通化することで設計を簡素化できる。
【0260】
また、以上のように、近似表面合成部2030は、上述の投影面候補に投影した頂点を反時計回り或いは時計回りに並べ替え、並べ替えた順に連続する2つの頂点を第1頂点及び第2頂点としてもよい。このように、後段のステップS903と同様な方法でソートを行うことで、処理を共通化して処理量の増加を防ぐことができる。
【0261】
また、以上のように、近似表面合成部2030は、上述の投影面候補に投影した頂点のうち1つ(第3頂点)を、所定の原点とするように構成されていてもよい。このような構成とすることで、所定の原点を頂点以外の位置に設定した場合と比較して、多角形の面積を算出するために計算が必要な三角形の個数が1つ少なくなるため、演算量の増加を防ぐことができる。
【0262】
次に、
図17~
図20を用いて、ステップS902の処理の別の例について説明する。
【0263】
図17は、ステップS902の処理の一例を示すフローチャートである。
【0264】
図17に示すように、ステップS1701において、近似表面合成部2030は、頂点座標のx軸、y軸、z軸方向それぞれの最大値と最小値の差分を算出する。
【0265】
例えば、
図19-1に示すように、対象ノードにA~Eの計5点の頂点があった場合、近似表面合成部2030は、
図19-2に示すxmax-xmin(x軸方向の座標値の最大値と最小値の差分)、ymax-ymin(y軸方向の座標値の最大値と最小値の差分)及び
図19-3に示すzmax-zmin(z軸方向の座標値の最大値と最小値の差分)をそれぞれ算出し、ステップS1702へ進む。
【0266】
ステップS1702において、近似表面合成部2030は、ステップS1701で算出した「最大値と最小値の差分」のうちの差分が最小となる軸方向がいくつあるかを確認する。
【0267】
例えば、zmax-zmin<xmax-xmin<ymax-yminという関係となっていた場合(或いは、zmax-zmin<xmax-xmin=ymax-yminという関係となっていた場合)、「最大値と最小値の差分」の最小値を持つ軸方向は1つのみとなる。この場合は、近似表面合成部2030は、ステップS1703へ進む。
【0268】
一方、例えば、zmax-zmin=xmax-xmin<ymax-yminという関係となっていた場合、「最大値と最小値の差分」の最小値を持つ軸方向は2つとなる。この場合は、近似表面合成部2030は、ステップS1704へ進む。
【0269】
ステップS1703は、差分の最小値を持つ軸方向が一つのみのケースに対応する処理であり、この場合は、近似表面合成部2030は、差分が最小となる軸を縮退することで投影面を決定する。
【0270】
例えば、上述の例のように、zmax-zmin<xmax-xmin<ymax-yminとなっていた場合、z軸を縮退して、x-y平面を投影面として決定する。
【0271】
近似表面合成部2030は、投影面を決定した後、ステップS1706へ進んで処理を終了する。
【0272】
ステップS1704において、近似表面合成部2030は、各軸方向の辺上の頂点数をカウントする。
【0273】
例えば、
図20-1に示すように、対象ノードにA~Eの計5点の頂点があった場合、x軸方向の辺上に存在する頂点は、
図20-2に示す点Aのみであり、y軸方向の辺上に存在する頂点は、
図20-3に示す通り0点であり、z軸方向の辺上に存在する頂点は、
図20-4に示す通りB~Eの計4点である。
【0274】
なお、この処理は、x、y、z軸のうち全ての軸を対象にしてもよいし、ステップS1701で求めた「最大値と最小値の差分」の最小値を持つ軸方向のみを対象としてもよい。
【0275】
例えば、zmax-zmin=xmax-xmin<ymax-yminという関係となっていた場合、本ステップの処理対象をz軸及びx軸のみとしてもよい。
【0276】
近似表面合成部2030は、上述のように頂点数をカウントした後、ステップS1705へ進む。
【0277】
ステップS1705において、近似表面合成部2030は、ステップS1704で算出した各軸方向の頂点数が最も大きい軸を縮退することで、投影面を決定する。
【0278】
例えば、
図20の例では、z軸方向の辺上に存在する頂点が最も多いため、近似表面合成部2030は、z軸を縮退して、x-y平面を投影面として決定する。
【0279】
近似表面合成部2030は、投影面決定後、ステップS1706へ進んで、処理を終了する。
【0280】
以上のように、近似表面合成部2030は、ノードの各辺を三次元座標のどの座標軸と平行かどうかで分類し、各座標軸に分類された辺上の頂点数をカウントし、カウントした値(頂点数)を用いて、複数の投影面候補の中から、上述の投影面を決定するように構成されていてもよい。
【0281】
また、以上のように、近似表面合成部2030は、上述の頂点の数が最も大きい軸を縮退することで定義される面を、上述の投影面と決定するように構成されていてもよい。
【0282】
このような構成とすることで、
図15及び
図16を用いて説明した手法よりも少ない演算量で、頂点位置の二次元的な広がりを考慮した投影面の決定が可能となる。
【0283】
また、以上のように、近似表面合成部2030は、上述の三次元座標の座標軸ごとに、各頂点の座標値の最大値と最小値との差分値を算出し、かかる座標軸のうち差分値の最小値を持つ軸が2つ以上ある場合、各座標軸に分類された辺上の頂点数が最も大きい軸を縮退することで定義される面を、上述の投影面とするように構成されていてもよい。
【0284】
また、以上のように、近似表面合成部2030は、各座標軸に分類された辺上の頂点数が最も大きい軸が2つ以上ある場合、三次元座標の座標軸ごとに、各頂点の座標値の最大値と最小値との差分値を算出し、座標軸のうち差分値が最小となる軸を縮退することで定義される面を、上述の投影面とするように構成されていてもよい。
【0285】
なお、
図17では、近似表面合成部2030は、先にステップS1701及びS1702において「最大値と最小値の差分」を評価した後、必要に応じてステップS1704及びS1705において各軸方向の辺上の頂点数を評価した。この順番は、例えば、
図18に示すように、逆にすることもできる。
【0286】
例えば、
図18の例に示す通り、近似表面合成部2030は、ステップS1801及びステップS1802において各軸方向の辺上の頂点数を評価した後、必要に応じてステップS1804及びステップS1805において「最大値と最小値の差分」を評価してもよい。
【0287】
図18の例では、ステップS1801については、ステップS1704と同様な処理で実現できる。
【0288】
ステップS1802において、近似表面合成部2030は、x軸、y軸、z軸方向の中で最大の頂点数を持つ軸が1つのみである場合は、ステップS1803へ進み、頂点数が最大となる軸を縮退することで投影面を決定する。
【0289】
そうでない場合(頂点数の最大値を持つ軸が2つ以上ある場合)は、近似表面合成部2030は、ステップS1804へ進む。
【0290】
ステップS1804については、ステップS1701と同様な処理で実現できる。
【0291】
ここで、ステップS1804の処理対象は、x軸、y軸、z軸の全てとしてもよいし、ステップS1802で頂点数が最大となった軸方向のみを処理対象としてもよい。
ステップS1805において、近似表面合成部2030は、ステップS1804の処理対象となった軸の中で、差分値が最も小さい軸を縮退することで、投影面を決定する。
【0292】
次に、
図22を用いて、ステップS902の処理の別の例について説明する。
図22は、ステップS902の処理の一例を示すフローチャートである。
【0293】
図22に示すように、ステップS2201において、近似表面合成部2030は、各投影面に投影した際の各頂点の座標に対して、2×2の直交変換を行う。
【0294】
以下では、直交変換としてアダマール変換を用いる場合を例に説明する。例えば、座標値として(Px、Py、Pz)を持つ頂点Pをx-y平面に投影した際の座標は、(Px、Py)となる。これに対して2×2のアダマール変換を行って得られる直交変換後の座標(Ha、Hb)は、以下の式によって算出できる。
【0295】
【0296】
ここで、1/√2は、ノルムを正規化するための係数であるが、後述のように、本処理では、各頂点の直交変換後の座標値をその大小関係を比較するために用いるため、正規化係数1/√2は省略してもよい。すなわち、近似表面合成部2030は、以下の式によって、(Ha、Hb)を算出してもよい。
【0297】
【0298】
上述のように、近似表面合成部2030は、直交変換としてアダマール変換を使用し、正規化係数を省略した場合、座標値PxとPyの加減算のみで直交変換後の座標(Ha、Hb)を算出できる。
【0299】
このように、まず、近似表面合成部2030は、x-y平面に投影した際の各頂点(1~n)座標に直交変換を適用してn組の座標(Ha1、Hb1)、・・・、(Han、Hbn)、を得た後、直交変換後の各座標軸(ここではa軸とb軸)における座標値の最大値Hamax、Hbmaxと最小値Hamin、Hbminをそれぞれ検出する。
【0300】
次に、各軸における最大値と最小値との差分値Had=Hamax―Hamin、Hbd=Hbmax―Hbminを算出する。
【0301】
最後に、近似表面合成部2030は、上述のHad及びHbdを用いて、x-y平面に投影した場合の頂点座標の広がりの大きさを表す変数Axyを算出する。
【0302】
近似表面合成部2030は、Axyについて、例えば、Axy=Had+Hbdのように、直交変換後の座標値の各軸における最大値と最小値の差分を足し合わせることで算出してもよい。
【0303】
また、近似表面合成部2030は、Axyについて、例えば、Axy=Had×Hbdのように、直交変換後の座標値の各軸における最大値と最小値の差分を掛け合わせることで算出してもよい。
【0304】
上述と同様に、近似表面合成部2030は、他の投影面候補であるy-z平面に対応するAyz及びx-z平面に対応するAxzを算出した後、ステップS2202へ進む。
【0305】
ステップS2202において、近似表面合成部2030は、ステップS2201で算出したAxy、Ayz、Axzを基に投影面を決定する。
【0306】
例えば、近似表面合成部2030は、Axy、Ayz、Axzのうち、値が最も大きいものに対応する投影面に決定することができる。具体的には、近似表面合成部2030は、例えば、Ayz>Axz>Axzの場合、投影面をy-z平面と決定することができる。
【0307】
上述のように、近似表面合成部2030は、投影面を決定した後、ステップS2203へ移り、処理を終了する。
【0308】
以上のように、近似表面合成部2030は、各投影面に投影した際の頂点座標値に直交変換を適用して得られる直交変換後の座標値を用いて、投影面を決定するように構成されていてもよい。
【0309】
また、以上のように、近似表面合成部2030は、直交変換後の各座標軸において座標値の最大値と最小値との差分値を計算し、かかる差分値に基づいて投影面を決定するように構成されていてもよい。
【0310】
また、以上のように、近似表面合成部2030は、各投影面候補において、上述の差分値を直交変換後の全ての座標軸について算出し、それらの和或いはそれらの積によって投影面を決定するように構成されていてもよい。
【0311】
このように直交変換によって座標軸を回転した後の座標値を用いることで、頂点の二次元的な広がりを評価しやすくなる。
【0312】
また、以上のように、近似表面合成部2030は、直交変換としてアダマール変換を使用するように構成されていてもよい。
【0313】
また、以上のように、近似表面合成部2030は、直交変換時の正規化係数を省略するように構成されていてもよい。
【0314】
このような構成とすることで、直交変換前の座標値の加減算のみで直交変換後の座標値を得ることができ、計算量の増加を防ぐことができる。
【0315】
(点群符号化装置100)
以下、
図21を参照して、本実施形態に係る点群符号化装置100について説明する。
図21は、本実施形態に係る点群符号化装置100の機能ブロックの一例について示す図である。
【0316】
図21に示すように、点群符号化装置100は、座標変換部1010と、幾何情報量子化部1020と、ツリー解析部1030と、近似表面解析部1040と、幾何情報符号化部1050と、幾何情報再構成部1060と、色変換部1070と、属性転移部1080と、RAHT部1090と、LoD算出部1100と、リフティング部1110と、属性情報量子化部1120と、属性情報符号化部1130と、フレームバッファ1140とを有する。
【0317】
座標変換部1010は、入力点群の3次元座標系から、任意の異なる座標系への変換処理を行うよう構成されている。座標変換は、例えば、入力点群を回転することにより、入力点群のx、y、z座標を任意のs、t、u座標に変換してもよい。また、変換のバリエーションの1つとして、入力点群の座標系をそのまま使用してもよい。
【0318】
幾何情報量子化部1020は、座標変換後の入力点群の位置情報の量子化及び座標が重複する点の除去を行うように構成されている。なお、量子化ステップサイズが1の場合は、入力点群の位置情報と量子化後の位置情報とが一致する。すなわち、量子化ステップサイズが1の場合は、量子化を行わない場合と等価になる。
【0319】
ツリー解析部1030は、量子化後の点群の位置情報を入力として、後述のツリー構造に基づいて、符号化対象空間のどのノードに点が存在するかについて示すoccupancy codeを生成するように構成されている。
【0320】
ツリー解析部1030は、本処理において、符号化対象空間を再帰的に直方体で区切ることにより、ツリー構造を生成するように構成されている。
【0321】
ここで、ある直方体内に点が存在する場合、かかる直方体を複数の直方体に分割する処理を、直方体が所定のサイズになるまで再帰的に実行することでツリー構造を生成することができる。なお、かかる各直方体をノードと呼ぶ。また、ノードを分割して生成される各直方体を子ノードと呼び、子ノード内に点が含まれるか否かについて0又は1で表現したものがoccupancy codeである。
【0322】
以上のように、ツリー解析部1030は、所定のサイズになるまでノードを再帰的に分割しながら、occupancy codeを生成するように構成されている。
【0323】
本実施形態では、上述の直方体を常に立方体として8分木分割を再帰的に行う「Octree」と呼ばれる手法、及び、8分木分割に加え、4分木分割及び2分木分割を行う「QtBt」と呼ばれる手法を使用することができる。
【0324】
ここで、「QtBt」を使用するか否かについては、制御データとして点群復号装置200に伝送される。
【0325】
或いは、任意のツリー構成を用いるPredicitive codingを使用するように指定されてもよい。かかる場合、ツリー解析部1030が、ツリー構造を決定し、決定されたツリー構造は、制御データとして点群復号装置200へ伝送される。
【0326】
例えば、ツリー構造の制御データは、
図6で説明した手順で復号できるよう構成されていてもよい。
【0327】
近似表面解析部1040は、ツリー解析部1030によって生成されたツリー情報を用いて、近似表面情報を生成するように構成されている。
【0328】
近似表面情報は、例えば、物体の3次元点群データを復号する際等において、点群が物体表面に密に分布しているような場合に、個々の点群を復号するのではなく、点群の存在領域を小さな平面で近似して表現したものである。
【0329】
具体的には、近似表面解析部1040は、例えば、「Trisoup」と呼ばれる手法で、近似表面情報を生成するように構成されていてもよい。また、Lidar等で取得した疎な点群を復号する場合は、本処理を省略することができる。
【0330】
幾何情報符号化部1050は、ツリー解析部1030によって生成されたoccupancy code及び近似表面解析部1040によって生成された近似表面情報等のシンタックスを符号化してビットストリーム(幾何情報ビットストリーム)を生成するように構成されている。ここで、ビットストリームには、例えば、
図4及び
図5で説明したシンタックスを含まれていてもよい。
【0331】
符号化処理は、例えば、コンテクスト適応二値算術符号化処理である。ここで、例えば、シンタックスは、位置情報の復号処理を制御するための制御データ(フラグやパラメータ)を含む。
【0332】
幾何情報再構成部1060は、ツリー解析部1030によって生成されたツリー情報及び近似表面解析部1040によって生成された近似表面情報に基づいて、符号化対象の点群データの各点の幾何情報(符号化処理が仮定している座標系、すなわち、座標変換部1010における座標変換後の位置情報)を再構成するように構成されている。
【0333】
フレームバッファ1140は、幾何情報再構成部1060によって再構成された幾何情報を入力とし、参照フレームとして保存するように構成されている。
【0334】
保存された参照フレームは、ツリー解析部1030において時間的に異なるフレームのインター予測を行う場合に、フレームバッファ1140から読み出されて参照フレームとして使用される。
【0335】
ここで、各フレームに対してどの時刻の参照フレームを用いるかどうかが、例えば、符号化効率を表すコスト関数の値に基づいて決定され、使用する参照フレームの情報が制御データとして点群復号装置200へ伝送されてもよい。
【0336】
色変換部1070は、入力の属性情報が色情報であった場合に、色変換を行うように構成されている。色変換は、必ずしも実行する必要は無く、色変換処理の実行の有無については、制御データの一部として符号化され、点群復号装置200へ伝送される。
【0337】
属性転移部1080は、入力点群の位置情報、幾何情報再構成部1060における再構成後の点群の位置情報及び色変換部1070での色変化後の属性情報に基づいて、属性情報の歪みが最小となるように属性値を補正するように構成されている。具体的な補正方法は、例えば、文献2(Text of ISO/IEC 23090-9 DIS Geometry-based PCC、ISO/IEC JTC1/SC29/WG11 N19088)に記載の方法を適用できる。
【0338】
RAHT部1090は、属性転移部1080による転移後の属性情報及び幾何情報再構成部1060によって生成された幾何情報を入力とし、RAHT(Region Adaptive Hierarchical Transform)と呼ばれるHaar変換の一種を用いて、各点の残差情報を生成するように構成されている。RAHTの具体的な処理としては、例えば、上述の文献2に記載の方法を用いることができる。
【0339】
LoD算出部1100は、幾何情報再構成部1060によって生成された幾何情報を入力とし、LoD(Level of Detail)を生成するように構成されている。
【0340】
LoDは、ある点の属性情報から、他のある点の属性情報を予測し、予測残差を符号化或いは復号するといった予測符号化を実現するための参照関係(参照する点及び参照される点)を定義するための情報である。
【0341】
言い換えると、LoDは、幾何情報に含まれる各点を複数のレベルに分類し、下位のレベルに属する点については上位のレベルに属する点の属性情報を用いて属性を符号化或いは復号するといった階層構造を定義した情報である。
【0342】
LoDの具体的な決定方法としては、例えば、上述の文献2に記載の方法を用いてもよい。
【0343】
リフティング部1110は、LoD算出部1100によって生成されたLoD及び属性転移部1080での属性転移後の属性情報を用いて、リフティング処理により残差情報を生成するように構成されている。
【0344】
リフティングの具体的な処理としては、例えば、上述の文献2に記載の方法を用いてもよい。
【0345】
属性情報量子化部1120は、RAHT部1090又はリフティング部1110から出力される残差情報を量子化するように構成されている。ここで、量子化ステップサイズが1の場合は、量子化を行わない場合と等価である。
【0346】
属性情報符号化部1130は、属性情報量子化部1120から出力される量子化後の残差情報等をシンタックスとして符号化処理を行い、属性情報に関するビットストリーム(属性情報ビットストリーム)を生成するように構成されている。
【0347】
符号化処理は、例えば、コンテクスト適応二値算術符号化処理である。ここで、例えば、シンタックスは、属性情報の復号処理を制御するための制御データ(フラグ及びパラメータ)を含む。
【0348】
点群符号化装置100は、以上の処理により、点群内の各点の位置情報及び属性情報を入力として符号化処理を行い、幾何情報ビットストリーム及び属性情報ビットストリームを出力するように構成されている。
【0349】
また、上述の点群符号化装置100及び点群復号装置200は、コンピュータに各機能(各工程)を実行させるプログラムであって実現されていてもよい。
【0350】
なお、上記の各実施形態では、本発明を点群符号化装置100及び点群復号装置200への適用を例にして説明したが、本発明は、かかる例のみに限定されるものではなく、点群符号化装置100及び点群復号装置200の各機能を備えた点群符号化/復号システムにも同様に適用できる。
【産業上の利用可能性】
【0351】
なお、本実施形態によれば、例えば、動画像通信において総合的なサービス品質の向上を実現できることから、国連が主導する持続可能な開発目標(SDGs)の目標9「レジリエントなインフラを整備し、持続可能な産業化を推進するとともに、イノベーションの拡大を図る」に貢献することが可能となる。
【符号の説明】
【0352】
10…点群処理システム
100…点群符号化装置
1010…座標変換部
1020…幾何情報量子化部
1030…ツリー解析部
1040…近似表面解析部
1050…幾何情報符号化部
1060…幾何情報再構成部
1070…色変換部
1080…属性転移部
1090…RAHT部
1100…LoD算出部
1110…リフティング部
1120…属性情報量子化部
1130…属性情報符号化部
1140…フレームバッファ
200…点群復号装置
2010…幾何情報復号部
2020…ツリー合成部
2030…近似表面合成部
2040…幾何情報再構成部
2050…逆座標変換部
2060…属性情報復号部
2070…逆量子化部
2080…RAHT部
2090…LoD算出部
2100…逆リフティング部
2110…逆色変換部
2120…フレームバッファ