コンピュータービジョンで扱う対象が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の補助が手厚くないとオイラには使いこなせない。
関連記事
画像認識による位置情報取得 - Semi-Direct Mo...
OpenCVで動画の手ぶれ補正
ポリ男をリファイン
hloc:SuperGlueで精度を向上させたSfM・Vis...
Googleが画像解析旅行ガイドアプリのJetpac社を買収
VCG Library:C++のポリゴン操作ライブラリ
Deep Fluids:流体シミュレーションをディープラーニ...
GAN (Generative Adversarial Ne...
ZBrushの作業環境を見直す
LuxCoreRender:オープンソースの物理ベースレンダ...
AmazonEC2のインスタンスをt1.microからt2....
UnityのGameObjectの向きをScriptで制御す...
Raspberry Pi 2のGPIOピン配置
顔検出・認識のAPI・ライブラリ・ソフトウェアのリスト
PythonでBlenderのAdd-on開発
Subsurface scatteringの動画
ZBrushで仮面ライダー3号を造る 仮面編 横顔のシルエッ...
ZBrushで仮面ライダー3号を造る 仮面編 Clay Po...
CGAN (Conditional GAN):条件付き敵対的...
注文してた本が届いた
2012のメイキングまとめ(途中)
ZBrushでリメッシュとディティールの転送
デザインのリファイン再び
ちょっと凝り過ぎなWebキャンペーン:全日本バーベイタム選手...
3DCGのモデルを立体化するサービス
MB-Lab:Blenderの人体モデリングアドオン
UnityプロジェクトをGitHubで管理する
CGALDotNet:計算幾何学ライブラリ CGALのC#ラ...
Open3D:3Dデータ処理ライブラリ
ゴジラの造形
ZBrushでアヴァン・ガメラを作ってみる
Windows10でPyTorchをインストールしてVSCo...
OpenCV 3.1のsfmモジュールを試す
Javaで作られたオープンソースの3DCGレンダラ『Sunf...
Physics Forests:機械学習で流体シミュレーショ...
Active Appearance Models(AAM)
PSPNet (Pyramid Scene Parsing ...
ZBrushでアヴァン・ガメラを作ってみる 全体のバランス調...
Transformers ”Reference & Buli...
疑似3D写真が撮れるiPhoneアプリ『Seene』がアップ...
ニューラルネットワークと深層学習
法線マップを用意してCanvas上でShadingするサンプ...



コメント