オープンソースの物理ベースレンダラ『Mitsuba』をMayaで使う

オープンソースのグローバルイルミネーションレンダラのMitsuba

Mitsuba – physically based renderer

Mitsubaは、PBRTのスタイルに則った研究指向のレンダリングシステムで、多くのインスピレーションを得ています。
Mitsubaは移植性の高いC++で記述されており、偏りのない手法と偏りのない手法を実装し、現在のCPUアーキテクチャを対象とした高度な最適化が含まれています。
Mitsubaは非常にモジュール式です:コアライブラリの小さなセットと、マテリアルや光源から完全なレンダリングアルゴリズムに至るまでの機能を実装する100種類を超えるプラグインで構成されています。

他のオープンソースレンダラーと比較して、MitsubaはMetropolis Light Transportのパスベースの定式化やボリュメトリックモデリングアプローチなどの実験的レンダリング技術に重点を置いています。
そのため、まだ主流のレンダラーへの道を見つけていないようなテクニックを試してみたい人にとっては本当に興味があるかもしれませんし、この領域での研究のための強固な基盤も提供します。

このレンダラーは現在Linux, MacOS X, Microsoft Windowsに対応し、x86, x86_64プラットフォームでのSSE2最適化を利用しています。
これまでのところ、その主な用途はコンピューターグラフィックスのアルゴリズム開発のテストベッドとしてでしたが、他にも多くの興味深いアプリケーションがあります。

Mitsubaには、シーンをインタラクティブに探索するためのコマンドラインインターフェイスとグラフィカルフロントエンドが付属しています。
ナビゲート中、大まかなプレビューが表示され、すべての動きが停止するとすぐに精度が向上します。
視点が選択されると、幅広いレンダリング技術を使用して画像を生成し、それらのパラメーターをプログラム内から調整できます。

ソースコードはGitHubにある↓
https://github.com/mitsuba-renderer/mitsuba



いつか試そうと思ってだいぶ時間が経ってしまったんだけど、MitsubaにはMayaと連携するためのプラグインもあるので試してみた。
https://github.com/mitsuba-renderer/mitsuba

ところが、このプラグイン、想像してたのと違って、あんまり連携感がない。Maya上のオブジェクトを描画できるわけだけど、もろもろの設定はMayaのGUIではなく、結局xmlの設定ファイルを直接いじるタイプだった。(MayaのGUI上でxmlを編集するエディタが立ち上がる。)

そんで、もうちょっと調べてみたら、有志(?)でMitsubaをPythonでラップしてプラグインっぽくした人がいた。→Installing MitsubaForMaya
プラグインコード(Python)とサンプルプロジェクトがGitHubに上がっている。→MitsubaForMaya

で、やってみた。このプラグインは外部のMitsubaのexeを呼び出す操作をラップしてMayaのGUI操作ライクにしてくれてるんだけど、コードの中に絶対パスを書いていて、エラーまみれになった。GUIはよくできてたんだけどね。もうちょっと中身読めば修正できそうな気もする。

で、いったんMayaで動かすのはあきらめて、MitsubaのスタンドアローンのGUIアプリを実行してみた。レンダリングするシーンファイルのサンプルが公式のダウンロードページに置いてある。試したのは毛糸のマフラーみたいなやつSiggraph2010で発表されたこの論文のデータね。

サンプルのscarfシーンをMitsubaでレンダリングした。

サンプルのscarfシーンをMitsubaでレンダリングした画像をPhotoshopで補正した。



まるで実写みたい。
Pythonのインターフェイスがあるみたいだから、上手く使えばAPIっぽく自前のプログラムから使えると思うんだけど、なかなかサンプルが見当たらない。

http://rgl.epfl.ch/publications/NimierDavidVicini2019Mitsuba2

2019年 追記:Siggraph Asia 2019でMitsuba 2が発表された↓
Mitsuba 2:オープンソースの物理ベースレンダラ
5年前にオープンソースの物理ベースレンダラ「Mitsuba」でちょっと遊んでみたことがあった↓Siggraph Asia 2019でMitsuba 2が発表されたらしい↓Mitsuba 2: A Retargetable Forward a...

関連記事

『ピクサー展』へ行ってきた

FCN (Fully Convolutional Netwo...

『パシフィック・リム: アップライジング』のVFXブレイクダ...

OANDAのfxTrade API

OpenCVのバージョン3が正式リリースされたぞ

オープンソースのテクスチャマッピングシステム『Ptex』

C++始めようと思うんだ

ZBrush 2018での作業環境を整える

JavaScriptとかWebGLとかCanvasとか

Multi-View Environment:複数画像から3...

Python.NET:Pythonと.NETを連携させるパッ...

Pythonの自然言語処理ライブラリ『NLTK(Natura...

Leap MotionでMaya上のオブジェクトを操作できる...

ZBrushで仮面ライダー3号を造る 仮面編 リファレンス画...

ZBrushでアヴァン・ガメラを作ってみる モールドの彫り込...

ZBrush 4R8 リリース!

Physically Based Rendering

ZBrushで仮面ライダー3号を造る ベース編

UnityでTweenアニメーションを実装できる3種類の無料...

C++ 標準テンプレートライブラリ (STL)

デザインのリファイン再び

ZBrushのハードサーフェイス用ブラシ

ZBrushでゴジラ2001を作ってみる 姿勢の変更

Caffe:読みやすくて高速なディープラーニングのフレームワ...

WebGL開発に関する情報が充実してきている

COLMAP:オープンソースのSfM・MVSツール

OpenCV 3.1とopencv_contribモジュール...

Unityをレンダラとして活用する

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

ポリゴンジオメトリ処理ライブラリ『pmp-library (...

グローバルイルミネーションに手を出す前に、やり残したことがあ...

スクラッチで既存のキャラクターを立体化したい

ラクガキの立体化 1年半ぶりの続き

機械学習に役立つPythonライブラリ一覧

BlenderのPython環境にPyTorchをインストー...

TensorSpace.js:ニューラルネットワークの構造を...

ZBrushで仮面ライダー3号を造る 仮面編 横顔のシルエッ...

イタリアの自動車ブランドFiatとゴジラがコラボしたCMのメ...

ZBrushで手首のモデリングをリファイン

Live CV:インタラクティブにComputer Visi...

html5のcanvasの可能性

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

コメント