オープンソースの人体モデリングツール『MakeHuman』のAPI開発プロジェクトがスタート

オープンソースのクリエイター向けGUIモデリングツールのMakeHumanがついにAPIの準備を始めたぞ。現状でも、中身のPythonコードを読もうと思えば読めなくもないんだけど、まあ、しんどかったね。オープンソースだったのに今まで開発者用のAPIが無かったってのも不思議だけど、クリエイター向けだったからかな。これは期待したい。

公式ブログのアナウンス記事をヘッポコ翻訳してみた。↓
The MakeHuman API Project (MHAPI)

新参の開発者にとって、MakeHumanの内部構造を把握するのはかなり難しいことだと私達は経験的に知っています。
また、MakeHumanのソースコードに多数の修正を加えていくと、必然的にその複雑度は増していきます。
私達は新参開発者のために、そしてMakeHumanより簡単にを拡張できるようにするために、MakeHuman API Project (MHAPI)を始めます。


スポンサーリンク

モチベーション
通常、ソースコードというものは技術指向なものです。
あなたが何かプログラムを作る時、そのプログラムが動くことを第一に考えるはずです。 大抵の場合、あなたは技術的な実装を中心に構造を作り、呼び出し処理や、技術的な実装に対応したサブルーチンを追記していくことでしょう。
このやり方の利点は、コア機能がむき出しの状態なので、あなたは直にそれにアクセス出来るという点だ。つまり、あなたは何の制約もなく自由にできるということだ。
このやり方の欠点は、どのように変更・改良を実装するかを考える前に、まずこの技術はどのような構造で、どのように実装されているのかを詳細に把握しなければならない点だ。
この欠点は、技術指向のAPIでも同様である。機能の呼び出し方が分からない時は、まず実装技術の詳細を理解する必要があり、利用可能かどうかはその後に知ることとなる。言うまでもなく、その技術がどのような構造で実装されているのか理解していなければ、正しく使う呼び出し方を見つけるのは非常に難しいだろう。


スポンサーリンク

別のAPIの構成方法として、技術的な実装ではなく、タスク指向で、概念を中心に捉える方法があります。この方法では、まず最初に、あなたが何をしたいのかを知り、それができる呼び出しを探す。ここでの呼び出しは、実装の詳細ではなく、コンセプトに沿って構成される。これには利点がいくつかあり、新参の開発者でもスムーズに開発に着手でき、APIに対して書かれたコードの意図が明確になり、バックグラウンドの実装が変化してもAPIを安定した状態に保つことができる。
この構成の欠点は、コードの記述方法と実際の動作方法が乖離してしまうという点と、APIを最新の実装技術に保つためのメンテナンスコストがかかる点である。

ビジョン
MHAPIプロジェクトの目標は、DSL(ドメイン固有言語)に近づけること、すなわち、意図で呼び出せて、とても使いやすいPythonベースのスクリプト言語にすることだ。APIは、まずはプラグイン経由で拡張機能を記述するものとして開発するが、長期的に考えれば、必ずしもこのような新しいコードを制限する造りである必要はない。我々のビジョンは、基本的なプログラミングスキルを持った人が、APIの解説にざっと目を通した数分以内にMakeHumanのプラグインのコピーを作成するなど、コード開発を始められるようにすることだ。

構造
先に述べたとおり、呼び出しはタスク指向とコンセプトラインに沿ってソートされる。APIのサブセットは以下のようになる(まだ構想段階のため、検討中のレイアウト)

この種のAPIで、人間に帽子をかぶせるには、例えばapi.clothes.equipClothing(“fedora”)といった1つの簡潔な呼び出し方法が必要だろう。ボタンや機能を持ったタブの追加も、同様に簡単にすることを目指している。
上記はすべて一例にすぎないということに注意してほしい。APIの設計が完了したわけではない。

訳が「ですます」調から途中で「である」調に変わっちゃったけど気にしない。


スポンサーリンク

関連記事

世界一下品なクマと世界一紳士なクマ
UnityのTransformクラスについて調べてみた
Adobe Photoshop CS4 Extendedの3Dモデル編集機能
PyDataTokyo主催のDeep Learning勉強会
ちょっと凝り過ぎなWebキャンペーン:全日本バーベイタム選手権 (MITSUBISHI KAGAKU...
UnityのAR FoundationでARKit 3
機械学習のオープンソースソフトウェアフォーラム『mloss(machine learning ope...
機械学習で遊ぶ
自前Shaderの件 解決しました
Subsurface scatteringの動画
チャットツール用bot開発フレームワーク『Hubot』
MythTV:Linuxでテレビの視聴・録画ができるオープンソースプロジェクト
トランスフォーマー :リベンジのメイキング (デジタルドメイン)
.NETで使えるTensorFlowライクなニューラルネットワークライブラリ『NeuralNetwo...
オープンソースの取引プラットフォーム
3D復元技術の情報リンク集
Stanford Bunny
『シン・ゴジラ』のコンセプトアニメーションのメイキング動画が公開された
仮想関数
ZBrushで仮面ライダー3号を造る 仮面編 PolyGroupを分割する
ジュラシック・パークのメイキング
OpenCVベースのマーカーARライブラリ『OpenAR』
このブログのデザインに飽きてきた
OpenCV 3.1のsfmモジュールのビルド再び
PolyPaint
Pythonのベイズ統計ライブラリ『PyMC』
PythonのStructure from Motionライブラリ『OpenSfM』
ZBrushで仮面ライダー3号を造る 仮面編 PolyGroup作成に再挑戦
注文してた本が届いた
ZBrush 2018へのアップグレード
Mayaのレンダリング アトリビュート
レンダラ制作はOpenGL とか DirectX を使わなくてもできるんだぜ
ヘッドマウントディスプレイとビジュアリゼーションの未来
機械学習について理解するための可視化ツール『MLDemos』
オープンソースのネットワーク可視化ソフトウェアプラットフォーム『Cytoscape』
OpenCVの顔検出過程を可視化した動画
参考書
ZBrushトレーニング
OpenCLに対応したオープンソースの物理ベースレンダラ『LuxRender(ルクスレンダー)』
『PIXARのひみつ展』に行ってきた
ZBrush 4R7
組み込み向けのWindows OS 『Windows Embedded』

コメント