(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-12-09
(45)【発行日】2024-12-17
(54)【発明の名称】データクラスタリングプログラム、データクラスタリング方法および情報処理装置
(51)【国際特許分類】
G06T 17/20 20060101AFI20241210BHJP
【FI】
G06T17/20
(21)【出願番号】P 2021094357
(22)【出願日】2021-06-04
【審査請求日】2024-01-11
【国等の委託研究の成果に係る記載事項】(出願人による申告)令和元年度、国立研究開発法人科学技術振興機構、戦略的創造研究推進事業「幾何的アプローチによる革新的なデータ解析の研究」委託研究、産業技術力強化法第17条の適用を受ける特許出願
(73)【特許権者】
【識別番号】000005223
【氏名又は名称】富士通株式会社
(74)【代理人】
【識別番号】110002147
【氏名又は名称】弁理士法人酒井国際特許事務所
(72)【発明者】
【氏名】池 祐一
(72)【発明者】
【氏名】浅尾 泰彦
【審査官】益戸 宏
(56)【参考文献】
【文献】国際公開第2020/049682(WO,A1)
【文献】特開2017-016192(JP,A)
【文献】特開2019-003527(JP,A)
【文献】特開2014-228879(JP,A)
【文献】米国特許出願公開第2020/0371214(US,A1)
【文献】岩切宗利 他2名,法線ベクトル分布に着目した3次元点群からのエッジ抽出,画像電子学会誌,2016年12月31日,Vol.45, No.1,pp.53-61
【文献】 堀田富宝 他1名,法線ベクトル分布の主成分分析に基づく3次元点群のクラスタ解析,映像情報メディア学会技術報告,2014年10月21日,Vol.38, No.42,pp.1-4
【文献】赤塚紘輝 他2名,主成分分析を用いた点群特徴抽出に関する一検討,情報処理学会 研究報告 オーディオビジュアル複合情報処理(AVM),2019年02月21日,Vol.2019-AVM-104, No.3,pp.1-2
【文献】Agustinus Kristiadi,Hessian and Curvatures in Machine Learning: A Differential-Geometric View,[online],2020年11月02日,[retrieved on 2024.10.25] Retrieved from the Internet:<URL:https://agustinus.kristia.de/blog/hessian-curvatures/>
【文献】Yikai Wu et al.,Dissecting Hessian: Understanding Common Structure of Hessian in Neural Networks,arXiv:2010.04261v1 [online],2020年10月08日,[retrieved on 2024.10.25] Retrieved from the Internet:<URL:https://arxiv.org/pdf/2010.04261v1>
(58)【調査した分野】(Int.Cl.,DB名)
G06T 17/00
G06T 7/00
(57)【特許請求の範囲】
【請求項1】
コンピュータに、
点群データに含まれる複数の点それぞれについて、点から所定の距離以内に存在する点群データに対する主成分分析を用いて固有ベクトルを算出し、
算出された前記固有ベクトルに対し最近傍に位置する点を極値点とする多次元関数の曲率を算出し、
前記点群データの前記複数の点それぞれに対する前記曲率に基づき、前記複数の点のクラスタリングを実行し、
前記クラスタリングの実行結果を出力する、
処理を実行させるデータクラスタリングプログラム。
【請求項2】
前記実行する処理は、
前記複数の点を、前記曲率を用いて高次元化した複数の点に対してクラスタリングを実行し、
前記クラスタリングの結果を、高次元化する前の状態における前記複数の点に対するクラスタリングの結果として出力する、
ことを特徴とする請求項1に記載のデータクラスタリングプログラム。
【請求項3】
前記実行する処理は、
前記クラスタリングの結果に基づき、複数のポリゴンの中から適切なポリゴンを選択し、
選択されたポリゴンを前記点群データにフィッティングし、
前記出力する処理は、
フィッティング結果を出力する、
ことを特徴とする請求項1または2に記載のデータクラスタリングプログラム。
【請求項4】
コンピュータが、
点群データに含まれる複数の点それぞれについて、点から所定の距離以内に存在する点群データに対する主成分分析を用いて固有ベクトルを算出し、
算出された前記固有ベクトルに対し最近傍に位置する点を極値点とする多次元関数の曲率を算出し、
前記点群データの前記複数の点それぞれに対する前記曲率に基づき、前記複数の点のクラスタリングを実行し、
前記クラスタリングの実行結果を出力する、
処理を実行させるデータクラスタリング方法。
【請求項5】
点群データに含まれる複数の点それぞれについて、点から所定の距離以内に存在する点群データに対する主成分分析を用いて固有ベクトルを算出するベクトル算出部と、
算出された前記固有ベクトルに対し最近傍に位置する点を極値点とする多次元関数の曲率を算出する曲率算出部と、
前記点群データの前記複数の点それぞれに対する前記曲率に基づき、前記複数の点のクラスタリングを実行し、前記クラスタリングの実行結果を出力するクラスタリング実行部と、
を有することを特徴とする情報処理装置。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、データクラスタリングプログラム、データクラスタリング方法および情報処理装置に関する。
【背景技術】
【0002】
様々な分野において多くの場合、解析したいデータは、いくつかの実数値の組として表され、データはn次元の空間の点群として捉えられる。近年では、これらの点群データから特徴量を抽出したり、分類したりすることが行われている。具体的には、点群データに対応付けるポリゴンを選択し、最小二乗法などを用いてポリゴンを点群データにフィッティングし、フィッティングしたポリゴンとの最小距離を用いて特異点の集合を抽出する。
【先行技術文献】
【特許文献】
【0003】
【発明の概要】
【発明が解決しようとする課題】
【0004】
しかしながら、上記技術では、点群データの各点の特徴を抽出することが難しい。例えば、誤差フィッティング技術は、あらかじめ点群データ全体の形が分かっており、それをポリゴンで表現しておく必要がある。また、適切なポリゴンが表現できない場合は、フィッティングを繰り返すことになり、時間もかかる。
【0005】
一つの側面では、点群データの各点の特徴を抽出することができるデータクラスタリングプログラム、データクラスタリング方法および情報処理装置を提供することを目的とする。
【課題を解決するための手段】
【0006】
第1の案では、クラスタリングプログラムは、コンピュータに、点群データに含まれる複数の点それぞれについて、点から所定の距離以内に存在する点群データに対する主成分分析を用いて固有ベクトルを算出し、算出された前記固有ベクトルに対し最近傍に位置する点を極値点とする多次元関数の曲率を算出し、前記点群データの前記複数の点それぞれに対する前記曲率に基づき、前記複数の点のクラスタリングを実行し、前記クラスタリングの実行結果を出力する、処理を実行させることを特徴とする。
【発明の効果】
【0007】
一つの側面では、点群データの各点の特徴を抽出することができる。
【図面の簡単な説明】
【0008】
【
図1】
図1は、実施例1にかかる情報処理装置を説明する図である。
【
図2】
図2は、TDAによる課題を説明する図である。
【
図3】
図3は、実施例1にかかる情報処理装置の機能構成を示す機能ブロック図である。
【
図4】
図4は、点群データの各点に対する固有ベクトルの算出手法を説明する図である。
【
図5】
図5は、各点群データの特徴量の抽出結果を説明する図である。
【
図6】
図6は、実施例1にかかる処理の流れを示すフローチャートである。
【
図7】
図7は、実施例2にかかる情報処理装置の機能構成を示す機能ブロック図である。
【
図8】
図8は、実施例2にかかるクラスタリング結果を説明する図である。
【
図9】
図9は、実施例2にかかる処理の流れを示すフローチャートである。
【発明を実施するための形態】
【0009】
以下に、本願の開示するデータクラスタリングプログラム、データクラスタリング方法および情報処理装置の実施例を図面に基づいて詳細に説明する。なお、この実施例によりこの発明が限定されるものではない。また、各実施例は、矛盾のない範囲内で適宜組み合わせることができる。
【実施例1】
【0010】
[全体構成]
図1は、実施例1にかかる情報処理装置10を説明する図である。この情報処理装置10は、点群データPや点群データQなどの様々な点群データに対して、特徴量Pや特徴量Qなどのように、各点群データの特徴を正確に表現した特徴量を生成して出力するコンピュータ装置の一例である。
【0011】
ここで、点群データの特徴量の生成に利用されるTDAについて説明する。TDAは、点群データに対してパーシステントホモロジ変換を実行することで、m次元の穴の遷移を特徴づけるパーシステント図を生成して、点群データの特徴量を生成する。
【0012】
ここで、「ホモロジ」とは、対象の特徴をm(m≧0)次元の穴の数によって表現する手法である。ここで言う「穴」とはホモロジ群の元のことであり、0次元の穴は連結成分であり、1次元の穴は穴(トンネル)であり、2次元の穴は空洞である。各次元の穴の数はベッチ数と呼ばれる。そして、「パーシステントホモロジ」とは、対象(ここでは、点の集合(Point Cloud))におけるm次元の穴の遷移を特徴付けるための手法であり、パーシステントホモロジによって点の配置に関する特徴を調べることができる。この手法においては、対象における各点が球状に徐々に膨らまされ、その過程において各穴が発生した時刻(発生時の球の半径で表される)と消滅した時刻(消滅時の球の半径で表される)とが特定される。
【0013】
次に、TDAを用いて、シリンダの形をした点群データPと、球の形をした点群データQとのそれぞれの特徴量を生成した結果を説明する。
図2は、TDAによる課題を説明する図である。
【0014】
具体的には、
図2には、点群データPに対するTDAにより、0次元の穴の発生(Birth)と消滅(Death)のタイミングであるH
0、1次元の穴の発生と消滅のタイミングであるH
1、2次元の穴の発生と消滅のタイミングであるH
2を表したパーシステント図が図示される。同様に、点群データQに対するTDAにより、0次元の穴の発生と消滅のタイミングであるH
0、1次元の穴の発生と消滅のタイミングであるH
1、2次元の穴の発生と消滅のタイミングであるH
2を表したパーシステント図が図示される。
【0015】
図2の各パーシステント図を比較してもわかるように、TDAによる特徴量生成(解析)では、位相的に同じ形の点群データからは類似する特徴量が生成され、各点群データを区別することが難しい。すなわち、形が不明な点群データを解析した場合に、異なる形のデータについて同じ特徴量を生成することになる。このため、例えば点群データを用いてラベル付き訓練データを生成する場合に、異なるラベルを付すべき点群データに同じラベルを付すことになり、訓練精度の劣化に繋がる。
【0016】
また、TDAで得られた特徴量を用いてポリゴンを選択して、点群データにフィッティングさせることも考えられるが、選択材料となる特徴量が正確でないと、適切なポリゴンを選択することができない。
図2の場合、点群データPと点群データQのそれぞれに同じポリゴンを選択することになり、正確なフィッティングができない。
【0017】
そこで、実施例1にかかる情報処理装置10は、点群データに含まれる複数の点それぞれについて、点から所定の距離以内に存在する点群データに対する主成分分析を用いて固有ベクトルを算出する。情報処理装置10は、算出された固有ベクトルに対し最近傍に位置する点を極値点(または停留点)とする多次元関数の曲率を算出する。情報処理装置10は、点群データの複数の点それぞれに対する曲率に基づき、点群データの特徴量を生成する。
【0018】
すなわち、情報処理装置10は、点群データから局所的に定まる曲率的な量(曲がり具合を表す量)を算出して、その値の頻度分布を特徴量とする。この結果、情報処理装置10は、位相的には同じであるが曲率的に形が違う点群データが区別可能となり、点群データの正確な特徴量を抽出することができる。
【0019】
[機能構成]
図3は、実施例1にかかる情報処理装置10の機能構成を示す機能ブロック図である。
図3に示すように、情報処理装置10は、通信部11、記憶部12、制御部20を有する。
【0020】
通信部11は、他の装置との間の通信を制御する処理部であり、例えば通信インタフェースなどにより実現される。例えば、通信部11は、管理者端末や3Dセンサなどから点群データを受信し、抽出結果(解析結果)などを管理者端末に送信する。
【0021】
記憶部12は、各種データや制御部20が実行するプログラムなどを記憶する記憶装置の一例である。例えば、記憶部12は、点群データDB13と抽出結果DB14を記憶する。
【0022】
点群データDB13は、例えば3Dセンサや測域センサなどを用いて、3次元空間内でスキャンされた様々な物体の点群データを記憶するデータベースである。上記例で説明すると、点群データDB13は、点群データPと点群データQとを記憶する。説明上、点群データPはシリンダの形をしており、点群データQは球の形をしているが、制御部20によって特徴づけられるまで、これらの形は未知である。
【0023】
抽出結果DB14は、制御部20による抽出結果を記憶するデータベースである。例えば、抽出結果DB14は、点群データPの特徴量、点群データQの特徴量を記憶する。
【0024】
制御部20は、情報処理装置10全体を司る処理部であり、例えばプロセッサなどにより実現される。この制御部20は、ベクトル算出部21、曲率算出部22、特徴生成部23を有する。なお、ベクトル算出部21、曲率算出部22、特徴生成部23は、プロセッサが有する電子回路やプロセッサが実行するプロセスとして実現することもできる。
【0025】
ベクトル算出部21は、点群データに含まれる複数の点それぞれについて、各点から所定の距離以内に存在する点群データに対する主成分分析を用いて固有ベクトルを算出する処理部である。例えば、ベクトル算出部21は、点群データPのそれぞれの点および点群データQそれぞれの点について、固有ベクトルを算出する。
【0026】
図4は、点群データの各点に対する固有ベクトルの算出手法を説明する図である。まず、ベクトル算出部21は、管理者等の入力等を受け付けて、d次元の実数空間R
dの部分集合である点群データXに対して、0より大きい値である閾値εと閾値δを設定する。
【0027】
次に、
図4の(a)に示すように、ベクトル算出部21は、点群データXの要素である点xを選択する。そして、
図4の(b)に示すように、ベクトル算出部21は、点xに対して、半径εの球内に入る点群Bを式(1)にように定義する。続いて、
図4の(c)に示すように、ベクトル算出部21は、点群Bに対して主成分分析(PCA:Principal Component Analysis)を適用し、固有値が閾値δ以上である固有ベクトルで張られる空間を取得する。ベクトル算出部21は、上記処理を点群データ内の各点について実行する。
【0028】
【0029】
曲率算出部22は、算出された固有ベクトルに対し最近傍に位置する点を極値点とする多次元関数の曲率を算出する処理部である。具体的には、曲率算出部22は、点群データP内の各点および点群データQ内の各点について曲率を算出し、特徴生成部23に出力する。
【0030】
例えば、曲率算出部22は、ベクトル算出部21で算出された固有値のうち、所定値以上である固有値に対応する固有ベクトル方向に値を持つ上記空間上の点xを頂点に持つ二次関数をBに対して最小二乗法で当てはめる。
【0031】
すなわち、曲率算出部22は、固有値がδ以上のk次元空間に座標x1、x2、・・・xkを設定し、k+1番目の固有ベクトルの方向に軸xk+1を設定する。続いて、曲率算出部22は、最小二乗法で当てはめた式(2)に示す二次関数を生成し、その二次関数に対して式(3)に示すヘシアンを算出する。そして、曲率算出部22は、そのヘシアンを各点の曲率と定める。
【0032】
【0033】
特徴生成部23は、点群データの複数の点それぞれに対する曲率に基づき、点群データの特徴量を生成する処理部である。具体的には、特徴生成部23は、点群データPおよび点群データQそれぞれついて、各点群データ内の複数の点ついての曲率の分布(頻度分布)を複数の点で表現される各点群データの特徴として算出し、抽出結果DB14に格納する。
【0034】
図5は、各点群データの特徴量の抽出結果を説明する図である。
図5に示すように、特徴生成部23は、横軸に曲率の値、縦軸に度数(その曲率を有する点の数)を設定した頻度分布を生成する。つまり、特徴生成部23は、点群データの各点が有する曲率の数を集計する。この結果、特徴生成部23は、点群データPについては、曲率0.0の点が集中しており、曲面(曲線)が比較的少ない形と特徴づけることができる。一方、特徴生成部23は、点群データQについては、曲率1.0周辺の点が集中しており、曲面(曲線)が多い形と特徴づけることができる。
【0035】
[処理の流れ]
図6は、実施例1にかかる処理の流れを示すフローチャートである。
図6に示すように、情報処理装置10のベクトル算出部21は、点群データを取得し(S101)、点群データ内の点(データ)を1つ選択する(S102)。
【0036】
続いて、ベクトル算出部21は、主成分分析を実行して空間(固有ベクトル)を算出する(S103)。そして、曲率算出部22は、点群データから局所的に定まる曲率的な量である曲率を算出する(S104)。
【0037】
ここで、点群データ内で未選択の点(データ)がある場合(S105:Yes)、未選択の点に対してS102以降を繰り返す。一方、点群データ内で未選択の点(データ)がない場合(S105:No)、特徴生成部23は、算出された各点の曲率を用いて、点群データの特徴量の抽出結果を生成して出力する(S106)。
【0038】
[効果]
上述したように、情報処理装置10は、点群データの各点について曲率を算出し、曲率を用いた特徴量を生成することができる。この結果、情報処理装置10は、曲率的な局所的な違いに着目することで、位相的には同じだが曲率的に形が違う点群を区別することができる。また、情報処理装置10は、各点の曲率の頻度分布を生成するので、特徴量を可視化することができ、ユーザの解釈性を向上させることができる。
【0039】
また、情報処理装置10は、機械学習モデルの訓練データを点群データから生成する場合に、点群データを正確に区別することができるので、各点群データに正確なラベル(教師情報)を付与することができる。したがって、情報処理装置10は、機械学習モデルの訓練精度を向上させることができる。
【実施例2】
【0040】
ところで、情報処理装置10は、実施例1で説明した特徴量を用いることで、点群データのクラスタリングを実行することができる。そこで、実施例2では、点群データのクラスタリングを実行して、点群データとポリゴンとの正確なフィッティングを行う例を説明する。
【0041】
[機能構成]
図7は、実施例2にかかる情報処理装置10の機能構成を示す機能ブロック図である。
図7に示すように、実施例1と同様、情報処理装置10は、通信部11、記憶部12、制御部20を有する。実施例と異なる点は、ポリゴンDB15とクラスタリング実行部24とを有している点であるので、ここでは、これらについて説明する。
【0042】
ポリゴンDB15は、フィッティング対象である複数のポリゴンを記憶するデータベースである。例えば、ポリゴンDB15は、形が異なる複数のポリゴンや、形が類似する複数のポリゴンを記憶する。
【0043】
クラスタリング実行部24は、点群データの複数の点それぞれに対する曲率に基づき、複数の点のクラスタリングを実行し、クラスタリングの実行結果を出力する処理部である。具体的には、クラスタリング実行部24は、n次元の空間の点群データを幾何学的特徴によりクラスタリングする。このようにすることで、例えば三次元空間内でスキャンされた点群(点群データ)にメッシュ形状をフィッティングさせる際に、角などの特異点集合を抽出することができる。
【0044】
例えば、クラスタリング実行部24は、管理者等の入力等を受け付けて、スケールパラメータtと閾値dを設定する。次に、クラスタリング実行部24は、n次元の実数空間Rnの部分集合である点群データXについて、閾値に依存する点群データの曲率c(x)を各点x(Xの要素)に対して算出する。ここでは、クラスタリング実行部24は、曲率c(x)を実施例1の手法で算出する。
【0045】
続いて、クラスタリング実行部24は、c(x)<-dであればa(x)=-t、|c(x)|≦dであればa(x)=0、c(x)>dであればa(x)=tと定める。そして、クラスタリング実行部24は、曲率の値を用いて点群データXの次元を一次元増やし、n+1次元の実数空間Rn+1の部分集合とする。その後、クラスタリング実行部24は、式(4)により、一次元増やした点群データの各点を、実数空間Rn+1に埋め込む。すなわち、クラスタリング実行部24は、同相写像により、一次元増やした点群データの各点を、実数空間Rn+1に写像する。
【0046】
【0047】
その後、クラスタリング実行部24は、写像の像に対して最短距離法によるクラスタリングを実行し、点群データの各点をクラスタリングし、作成されたクラスタを埋め込む前の点群に対して割り当てる。すなわち、クラスタリング実行部24は、一次元増やされた各点を元の次元で表現する。
【0048】
このようにして、クラスタリング実行部24は、点群データの各点の次元数に曲率を追加して一次元増やし、一次元増やした状態でクラスタリングを実行することで、点群データの各点を正確にクラスタリングでき、類似する点群データを区別することができる。
【0049】
図8は、実施例2にかかるクラスタリング結果を説明する図である。クラスタリング実行部24は、点群データの各点をクラスタリングすることができるので、例えば曲率が第1閾値未満でほぼ曲率がない点のクラスタであるクラスタA、曲率が第1閾値以上かつ第2閾値未満で曲率が少しある点のクラスタであるクラスタB、曲率が第2閾値以上で曲率が大きい点のクラスタであるクラスタCに分類することができる。
【0050】
この結果、
図8に示すように、クラスタリング実行部24は、点群データPに対するクラスタリング結果と、点群データQのクラスタリング結果とを比較してもわかるように、位相的に類似する形で合っても、全く異なる形と判定することができる。
【0051】
したがって、クラスタリング実行部24は、点群データPに対してはシリンダ型のポリゴンを選択してフィッティングすることができ、点群データQに対しては球型のポリゴンを選択してフィッティングすることができる。このため、クラスタリング実行部24は、はじめから適切なポリゴンを選択して別々にフィッティングすることができ、ポリゴンの選択ミスを減らすことができるので、処理時間の短縮を実現することもできる。
【0052】
[処理の流れ]
図9は、実施例2にかかる処理の流れを示すフローチャートである。
図9に示すように、情報処理装置10のベクトル算出部21は、点群データを取得し(S201)、点群データ内の点を1つ選択する(S202)。
【0053】
続いて、ベクトル算出部21は、主成分分析を実行して空間(固有ベクトル)を算出する(S203)。そして、曲率算出部22は、点群データから局所的に定まる曲率的な量である曲率を算出する(S204)。
【0054】
ここで、点群データ内で未選択の点がある場合(S205:Yes)、未選択の点に対してS202以降を繰り返す。一方、点群データ内で未選択の点がない場合(S205:No)、クラスタリング実行部24は、点群データの各点について算出された曲率を用いて、各点のクラスタリングを実行する(S206)。
【0055】
その後、クラスタリング実行部24は、クラスタリング結果を出力する(S207)。例えば、クラスタリング実行部24は、クラスタリング結果を記憶部12に格納したり、管理者等の指摘された宛先に送信したりする。
【0056】
これと並行して、クラスタリング実行部24は、クラスタリング結果を用いて、ポリゴンDB15から適切なポリゴンを選択し(S208)、選択したポリゴンを点群データにフィッティングし、フィッティング結果を出力する(S209)。例えば、クラスタリング実行部24は、フィッティング結果を記憶部12に格納したり、管理者等の指摘された宛先に送信したりする。
【0057】
[効果]
上述したように、情報処理装置10は、点群データから局所的に定まる曲率を算出して、その情報に依存する値を別の成分として付け加えて一次元高い空間の点群データを構成して、それをクラスタリングする。すなわち、情報処理装置10は、与えられた点群データから特徴量を構成して、座標成分と合わせてクラスタリングを行うことができる。
【0058】
この結果、情報処理装置10は、例えば三次元空間内でスキャンされた点群データにメッシュ形状(ポリゴン)をフィッティングさせる際に、角などの特異点の集合を抽出することができる。このとき、情報処理装置10は、特異点を持つ点たちを別にクラスタリングすることもできる。このように、情報処理装置10は、特に尖っている部分や次元が異なる部分を抽出することができ、予め全体の形が分からない点群データであっても、点群データの幾何的特徴も考慮したクラスタリングを実行することができ、正確なフィッティングを実行することができる。
【実施例3】
【0059】
さて、これまで本発明の実施例について説明したが、本発明は上述した実施例以外にも、種々の異なる形態にて実施されてよいものである。
【0060】
[数値等]
上記実施例で用いた数値例、行列、次元数、各種変数等は、あくまで一例であり、任意に変更することができる。また、各フローチャートで説明した処理の流れも矛盾のない範囲内で適宜変更することができる。また、クラスタリング手法としては、K平均法や平均シフト法など様々なクラスタリング手法を用いることもできる。
【0061】
[システム]
上記文書中や図面中で示した処理手順、制御手順、具体的名称、各種のデータやパラメータを含む情報については、特記する場合を除いて任意に変更することができる。
【0062】
また、図示した各装置の各構成要素は機能概念的なものであり、必ずしも物理的に図示の如く構成されていることを要しない。すなわち、各装置の分散や統合の具体的形態は図示のものに限られない。つまり、その全部または一部を、各種の負荷や使用状況などに応じて、任意の単位で機能的または物理的に分散・統合して構成することができる。
【0063】
さらに、各装置にて行なわれる各処理機能は、その全部または任意の一部が、CPUおよび当該CPUにて解析実行されるプログラムにて実現され、あるいは、ワイヤードロジックによるハードウェアとして実現され得る。
【0064】
[ハードウェア]
図10は、ハードウェア構成例を説明する図である。
図10に示すように、情報処理装置10は、通信装置10a、HDD(Hard Disk Drive)10b、メモリ10c、プロセッサ10dを有する。また、
図2に示した各部は、バス等で相互に接続される。
【0065】
通信装置10aは、ネットワークインタフェースカードなどであり、他の装置との通信を行う。HDD10bは、
図2に示した機能を動作させるプログラムやDBを記憶する。
【0066】
プロセッサ10dは、
図2に示した各処理部と同様の処理を実行するプログラムをHDD10b等から読み出してメモリ10cに展開することで、
図2等で説明した各機能を実行するプロセスを動作させる。例えば、このプロセスは、情報処理装置10が有する各処理部と同様の機能を実行する。具体的には、プロセッサ10dは、ベクトル算出部21、曲率算出部22、特徴生成部22等と同様の機能を有するプログラムをHDD10b等から読み出す。そして、プロセッサ10dは、ベクトル算出部21、曲率算出部22、特徴生成部22等と同様の処理を実行するプロセスを実行する。
【0067】
このように、情報処理装置10は、プログラムを読み出して実行することで抽出方法を実行する情報処理装置として動作する。また、情報処理装置10は、媒体読取装置によって記録媒体から上記プログラムを読み出し、読み出された上記プログラムを実行することで上記した実施例と同様の機能を実現することもできる。なお、この他の実施例でいうプログラムは、情報処理装置10によって実行されることに限定されるものではない。例えば、他のコンピュータまたはサーバがプログラムを実行する場合や、これらが協働してプログラムを実行するような場合にも、本発明を同様に適用することができる。
【0068】
このプログラムは、インターネットなどのネットワークを介して配布することができる。また、このプログラムは、ハードディスク、フレキシブルディスク(FD)、CD-ROM、MO(Magneto-Optical disk)、DVD(Digital Versatile Disc)などのコンピュータで読み取り可能な記録媒体に記録され、コンピュータによって記録媒体から読み出されることによって実行することができる。
【符号の説明】
【0069】
10 情報処理装置
11 通信部
12 記憶部
13 点群データDB
14 抽出結果DB
15 ポリゴンDB
20 制御部
21 ベクトル算出部
22 曲率算出部
23 特徴生成部
24 クラスタリング実行部