Open3D:3Dデータ処理ライブラリ

Intel Visual Computing Labが中心に開発しているらしい、まだ新しい3Dデータ処理ライブラリ。MITライセンスなので、ライセンスと著作権を表示すれば商用利用も可能。

Open3D


Open3Dは、3Dデータを扱うソフトウェアの開発をサポートするオープンソースライブラリです。Open3DはC++とPythonのフロントエンドを提供し、厳選されたデータ構造とアルゴリズムをどちらの環境でも利用できます。バックエンドは高度に最適化されており、並列処理に対応しています。

Open3Dは、依存関係を最小限に抑えられるよう考慮してゼロから開発されました。そのため、異なるプラットフォームでも最小限の労力でソースコードからコンパイル、環境構築できます。ソースコードは一貫したスタイルで整理されており、明確なコードレビューの仕組みによってメンテナンスされています。

Open3Dはすでに発表されている多くの研究プロジェクトで使用されており、クラウド上で積極的にデプロイされています。Open3Dプロジェクトでは、オープンソースコミュニティからの貢献を歓迎しています。


主な機能

  • 基本的な3Dデータ構造
  • 基本的な3Dデータ処理アルゴリズム
  • シーンの再構築(Scene reconstruction)
  • サーフェイスの整列(Surface alignment)
  • 3Dビジュアリゼーション
  • Pythonバインディング

対応するコンパイラ

  • Linux:GCC 4.8以降
  • OS X:XCode 8.0以降
  • Windows:Visual Studio 2015以降

ソースコードはこちら↓
https://github.com/IntelVCL/Open3D

公式ドキュメントはこちら↓
http://www.open3d.org/docs/index.html

特に各環境でのソースコードのビルド方法はGetting Startedから。

SSII 2018のチュートリアルセッションで紹介されていたんですね↓

チュートリアルのサンプルコード↓
https://github.com/sakizuki/SSII2018_Tutorial_Open3D

いわゆるポリゴンMeshや、画像・点群も扱えるようなので、CGにもコンピュータービジョンにも利用できそう。
Tutorialの一覧をざっと眺めた限り、2D→3Dは対象としておらず、扱う画像はRGBDのような3Dデータのようだ。

最近は、3D点群データを扱うのに以前ほどPoint Cloud Libraryが使われなくなっているんだろうか。Point Cloud Libraryは依存関係の塊でビルドのハードルが高かったけど。

ここ最近のコンピュータービジョン、特に機械学習界隈はPython環境がデファクトスタンダードになっている節もあり、C++ゴリゴリのライブラリよりもPythonバインディングの充実が重要なのかも。

2020年5月 追記:ついにバージョン0.10.0まで来ましたね。



少しずつ日本語の情報も増えてきている。
http://robonchu.hatenablog.com/entry/2018/02/24/200635
http://robonchu.hatenablog.com/entry/2018/02/25/121024
http://robonchu.hatenablog.com/entry/2018/02/25/200510

https://karaage.hatenadiary.jp/entry/2018/03/12/073000

http://lang.sist.chukyo-u.ac.jp/classes/Open3D/

https://qiita.com/n_chiba_/items/fc9605cde5c19a8c7dad

公式YouTubeチャンネルもだいぶ充実してきた↓
https://www.youtube.com/channel/UCRJBlASPfPBtPXJSPffJV-w/

ただ、用途を突き詰めていくとある程度の段階でこんな感じでゲームエンジンに統合されて行くんではないかという気もする↓

UnityからROSを利用できる『ROS#』
.NETアプリケーション(特にUnity)からROSを利用するためのC#でできたライブラリ・ツール ROS#が公開された。→ROS-INDUSTRIALのアナウンスライセンスは Apache 2.0で、freeで商用利用も可能。ROS#RO...

関連記事

DUSt3R:3Dコンピュータービジョンの基盤モデル

Googleが画像解析旅行ガイドアプリのJetpac社を買収

DensePose:画像中の人物表面のUV座標を推定する

BGSLibrary:OpenCVベースの背景差分ライブラリ

Stanford Bunny

Unityからkonashiをコントロールする

CGWORLD CHANNEL 第21回ニコ生配信は『シン・...

Raspberry Piでセンサーの常時稼働を検討する

ZBrushのTranspose Masterでポーズを付け...

ZBrushのUV MasterでUV展開

ZBrushでアヴァン・ガメラを作ってみる 口内の微調整・身...

Qlone:スマホのカメラで3Dスキャンできるアプリ

AMIMOTO(PVM版)で作成したインスタンスをAMIMO...

Google Chromecast

参考書

海外ドラマのChromaKey

映画から想像するVR・AR時代のGUIデザイン

MLDemos:機械学習について理解するための可視化ツール

ZBrushのZmodelerとDynamic Subdiv...

3Dモデルを立体視で確認できるVRアプリを作っている

PythonでMayaのShapeノードプラグインを作る

ZBrushと液晶ペンタブレットでドラゴンをモデリングするチ...

FacebookがDeep learningツールの一部をオ...

FreeMoCap Project:オープンソースのマーカー...

Human Generator:Blenderの人体生成アド...

トランスフォーマー :リベンジのメイキング (デジタルドメイ...

Unreal Engineの薄い本

プログラミングスキルとは何か?

Digital Emily Project:人間の顔をそっく...

顔のモデリング

オープンソースのロボットアプリケーションフレームワーク『RO...

OpenCV 3.3.0 contribのsfmモジュールの...

Zibra Liquids:Unity向け流体シミュレーショ...

Oculus Goを購入!

Polyscope:3Dデータ操作用GUIライブラリ

Amazon Web ServicesでWordPress

OpenMVSのサンプルを動かしてみる

『シン・ゴジラ』のコンセプトアニメーションのメイキング動画が...

html5のcanvasの可能性

ガメラ生誕50周年

ZBrushでアヴァン・ガメラを作ってみる パーツ分割

為替レートの読み方 2WAYプライス表示

コメント