コンピュータービジョンで扱う対象が2Dの画像だけでなく3Dデータに広がってきて、コンピューターグラフィックスとの垣根がどんどん無くなってきているように感じる。
Blendifyは、Blenderの機能をPythonのモジュールとして呼び出せるbpyモジュールをコンピュータービジョン用途で扱いやすいようにラップしたモジュール。
Blendify
Blendifyは、Blenderでシーンを作成・レンダリングするための高レベルAPIを提供する軽量のPythonフレームワークです。3Dコンピュータービジョンの可視化に重点を置いて開発されたBlendifyなら、Blenderの関数やオブジェクトへのアクセスを簡略化できます。
Blendifyの主な特徴:
- シンプルなインターフェイス:Blendify は、複雑なBlender APIを意識することなく、一般的な可視化タスクを実行できるユーザーフレンドリーなインターフェイスを提供します。
- 組み合わせが容易:Blendifyは開発Scriptとシームレスに統合され、よく使用されるルーチンと関数を実装しています:
- 点群、メッシュ、プリミティブをネイティブでサポート
- 頂点カラーやテクスチャのサポート
- シャドウキャッチャーオブジェクトを使用した高度な影
- カメラがスムーズに移動するビデオのレンダリング
- 一般的なカメラモデルのサポート
- .blendファイルのインポート・エクスポートによるBlenderとの密な連携
- クイックスタート:Blendifyは簡単に使い始めることができ、スタンドアロンのBlenderをインストールする必要はありません。
pip install blendify
を実行するだけで導入できます。Blendifyを使用すればBlenderとの対話を簡略化でき、アプリケーションの開発に集中できます。以下は、Blender APIネイティブとBlendifyによる可視化コードの単純さを比較した例です。
![]()
BlenderのPython APIはちょっととっつきにくいので、用途に合わせて抽象化の切り口を変えたラッパーが欲しくなるのも理解できる。
というか、IDEのコード補完が効かないのでそもそもCG用途でも割ととっつきにくい。疑似的にコード補完を実現するfake-bpy-moduleがあるにはあるけど。
https://github.com/nutti/fake-bpy-module
(2/4) Simple interface: Blendify provides a user-friendly interface for performing common visualization tasks. Many things are easier to render with Blendify – see the comparison below! pic.twitter.com/lfqKW1tsUb
— Vladimir Guzov (@guzov_vladimir) May 10, 2023
(3/4) Blendify supports:
– point clouds, meshes, and primitives;
– per-vertex colors and textures;
– advanced shadows with shadow catcher objects;
– import and export of .blend filesAnd more! Check out our examples at https://t.co/avPQdKMcrp pic.twitter.com/1mpByyNLGP
— Vladimir Guzov (@guzov_vladimir) May 10, 2023
Blenderはオープンソースであることと、もともとAPIがPythonで用意されてる辺りがML界隈でも利用される理由だろうか。
ML系の人達がやたらPythonばかり使いたがる理由がイマイチ分からない。動的型付け言語は読みづらくて、階層の深いコードや大きなアプリケーションを作りにくいと感じるのだが。
ML系ではそういうプログラムをそもそも書かないということなのか?よほどIDEの補助が手厚くないとオイラには使いこなせない。
関連記事
スクラッチで既存のキャラクターを立体化したい
UnityでLight Shaftを表現する
プログラミングスキルとは何か?
LuxCoreRender:オープンソースの物理ベースレンダ...
Unityで画面タッチ・ジェスチャ入力を扱う無料Asset『...
OpenAR:OpenCVベースのマーカーARライブラリ
Manim:Pythonで使える数学アニメーションライブラリ
ZBrushで仮面ライダー3号を造る 仮面編 PolyGro...
AmazonEC2のインスタンスをt1.microからt2....
Google Chromecast
まだ続くブログの不調
Mayaのシェーディングノードの区分
OpenCVの超解像(SuperResolution)モジュ...
Raspberry PiでIoTごっこ
OpenGV:画像からカメラの3次元位置・姿勢を推定するライ...
Point Cloud Libraryに動画フォーマットが追...
映画『ジュラシック・ワールド/炎の王国』のVFXブレイクダウ...
『ハン・ソロ/スター・ウォーズ・ストーリー』のVFXブレイク...
Qlone:スマホのカメラで3Dスキャンできるアプリ
SONY製のニューラルネットワークライブラリ『NNabla』
WordPressプラグインによるサイトマップの自動生成
ニューラルネットワークと深層学習
2012 昨日のクローズアップ現代を見た
ニューラルネットワークで画像分類
OpenFace:Deep Neural Networkによ...
書籍『ゼロから作るDeep Learning』で自分なりに学...
参考書
ドットインストールのWordPress入門レッスン
WebGL開発に関する情報が充実してきている
ZBrushの作業環境を見直す
『シン・ゴジラ』のコンセプトアニメーションのメイキング動画が...
OpenSfM:PythonのStructure from ...
フィーリングに基づくタマムシの質感表現
ZBrushからBlenderへモデルをインポート
ZBrushで人型クリーチャー
Siggraph Asia 2009 カンファレンスの詳細
Photogrammetry (写真測量法)
3D Gaussian Splatting:リアルタイム描画...
リアルタイム レイトレーシングAPI『DirectX Ray...
ZBrushでアヴァン・ガメラを作ってみる 歯茎を別パーツへ...
Accord.NET Framework:C#で使える機械学...
viser:Pythonで使える3D可視化ライブラリ
コメント