Kaolin:3Dディープラーニング用のPyTorchライブラリ

NVIDIAから3D系のディープラーニング研究のためのPyTorchライブラリが公開された。
まだベータ版だから、これからどんどん充実していくんでしょうね。読み方はカオリンで良いのかな?(なんかかわいい)

Kaolin



Kaolinは3Dディープラーニングの研究を加速させるためのPyTorchライブラリです。Kaolinは、ディープラーニングシステムで使用できる微分可能な3Dモジュールを効率的な実装で提供します。
Kaolinには一般的な公開3Dデータセットの読み込みと前処理を行ったり、メッシュ、点群、符号付き距離関数、ボクセルグリッドを操作するネイティブ関数があり、無駄な定型コードの記述を最小限に抑えています。Kaolinは、レンダリング、ライティング、シェーディング、view warpingなどの微分可能なグラフィックスモジュールをパッケージ化しています。また、Kaolinは一連の損失関数と評価指標をサポートすることでシームレスな評価を可能とし、3Dの結果をレンダリングする可視化機能も提供します。

最も重視しているのは、最先端の様々な3Dディープラーニングアーキテクチャを集めた包括的なModel Zooをキュレートし、将来の研究活動の出発点に立つ手助けとなることです。

ドキュメントのページがまだ作成されていないのか404だけど。

NVIDIAの公式ブログ↓
https://news.developer.nvidia.com/kaolin-library-research-3d/
https://blogs.nvidia.co.jp/2019/11/27/kaolin-library-research-3d/

Kaolinって名前は造形用粘土のKaolinite(カオリナイト)が由来なのね。



ベータ版の時点で何ができるのか。

機能



現在、(ベータ版)リリースには、メッシュ、ボクセル、符号付き距離関数、点群での3Dディープラーニングのための処理関数が含まれています。
一般的なデータセット(例:ShapeNet, ModelNet, SHRECなど)の読み込みもすぐにサポートされます。また、いくつかの3D変換および変換操作を実装します。

Kaolinは以下のような3Dタスクをサポートします:

  • Differentiable rendering (see Neural Mesh Renderer, its PyTorch port, Soft Rasterizer, Differentiable Interpolation-based Renderer, and a modular and extensible abstract DifferentiableRenderer specification).
  • Single-image based mesh reconstruction (Pixel2Mesh, GEOMetrics, OccupancyNets, and more…)
  • Pointcloud classification and segmentation (PointNet, PoinNet++, DGCNN, …)
  • Mesh classification and segmentation (MeshCNN, GCN)
  • 3D superresolution on voxel grids (ODM, VoxelUNet, and more…)
  • Basic graphics utilities (lighting, shading, etc.)

Model Zoo

Kaolinは、一般的な3Dディープラーニングアーキテクチャのリファレンス実装を含む大規模なModel Zooをキュレーションします。詳しくはこちらでご確認ください。

https://note.com/npaka/m/m85457421b99f

TensorFlowを使うならTensorFlow Graphicsがあるけど、PyTorch派ならKaolinだろうか。



あ、Siggraph 2019で発表されて話題になったMeshCNNのモデルもKaolinに含まれてるんですね。



MeshCNNのコードもPyTorchで実装されてるからまあ、すでに割と手軽ではあるんだけど。
https://github.com/ranahanocka/MeshCNN/

関連記事

PeopleSansPeople:機械学習用の人物データをUnityで生成する

Siggraph Asia 2009 カンファレンスの詳細

Twitter APIのPythonラッパー『python-twitter』

Adobe Photoshop CS4 Extendedの3Dモデル編集機能

オープンソースのロボットアプリケーションフレームワーク『ROS (Robot Operating S...

Python for Unity:UnityEditorでPythonを使えるパッケージ

iOSデバイスと接続して連携するガジェットの開発方法

日立のフルパララックス立体ディスプレイ

ManimML:機械学習の概念を視覚的に説明するためのライブラリ

OpenMesh:オープンソースの3Dメッシュデータライブラリ

Google製オープンソース機械学習ライブラリ『TensorFlow』のWindows版が公開された

ZBrushでアヴァン・ガメラを作ってみる 頭頂部の作り込み・舌の追加

ラクガキの立体化 胴体の追加

Photogrammetry (写真測量法)

ZBrushでアヴァン・ガメラを作ってみる 腕の作り込み

網元AMIで作ったWordpressサイトのインスタンスをt1microからt2microへ移行した

ジュラシック・パークのメイキング

Facebookの顔認証技術『DeepFace』

Zibra Liquids:Unity向け流体シミュレーションプラグイン

ZBrushトレーニング

ZBrushでアヴァン・ガメラを作ってみる 頭頂部と首周りを作り込む

Dlib:C++の機械学習ライブラリ

WordPressのテーマを自作する

Google App Engine上のWordPressでAmazonJSを利用する

UnityのMonoBehaviourクラスをシングルトン化する

TorchStudio:PyTorchのための統合開発環境とエコシステム

自前Shaderの件 解決しました

ニンテンドー3DSのGPU PICA200

ZBrushでアヴァン・ガメラを作ってみる 脚のトゲの作り直し

Amazon EC2ログイン用の秘密鍵を無くした場合の対処方法

Blendify:コンピュータービジョン向けBlenderラッパー

NVIDIA Quadro OpenGL DriverのDeep Color不具合の対処方法

Maya には3 種類のシェーダSDKがある?

SONY製のニューラルネットワークライブラリ『NNabla』

Windows Server 2008にAutodesk Maya 2009をインストール

ゴジラの造形

ZBrushで仮面ライダー3号を造る 仮面編 失敗のリカバー

タダでRenderManを体験する方法

mentalrayのSubsurface Scattering Shader『misss_fast_...

ZBrushでアヴァン・ガメラを作ってみる 歯を配置

ちょっと凝り過ぎなWebキャンペーン:全日本バーベイタム選手権 (MITSUBISHI KAGAKU...

Unreal Engine Tokyo MeetUp!へ行ってきた

コメント