サイトアイコン NegativeMindException

オープンソースの人体モデリングツール『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
    camera
      zoom()
      move()
      rotate()
      ...
    human
      applyTarget()
      setAge()
      ...
    clothes
      equipClothing()
      setClothingColor()
      ...
    interface
      addButton()
      addTab()
      ...
    messages
      showMessageBox()
      writeMessageToLog()
      ...

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

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


スポンサーリンク

関連記事

  • CGのためのディープラーニング
  • ちょっと凝り過ぎなWebキャンペーン:全日本バーベイタム選手権 (MITSUBISHI KAGAKU...
  • グローバルイルミネーションに手を出す前に、やり残したことがあるんじゃない?
  • Physically Based Rendering
  • Raspberry PiでIoTごっこ
  • python-twitterで自分のお気に入りを取得する
  • Photogrammetry (写真測量法)
  • Seleniumを使ったFXや株の自動取引
  • OpenSfM:PythonのStructure from Motionライブラリ
  • チャットツール用bot開発フレームワーク『Hubot』
  • Maya LTのQuick Rigを試す
  • ラクガキの立体化 1年半ぶりの続き
  • PolyPaint
  • HD画質の無駄遣い その2
  • Twitter APIのPythonラッパー『python-twitter』
  • ディープラーニング
  • VCG Library:C++のポリゴン操作ライブラリ
  • OANDAのfxTrade API
  • OpenAR:OpenCVベースのマーカーARライブラリ
  • 写真から3Dメッシュの生成・編集ができる無料ツール『Autodesk Memento』
  • OpenMayaRender
  • hloc:SuperGlueで精度を向上させたSfM実装
  • 為替レートの読み方 2WAYプライス表示
  • MPC社によるゴジラ(2014)のVFXブレイクダウン
  • openMVG:複数視点画像から3次元形状を復元するライブラリ
  • BlenderProc:Blenderで機械学習用の画像データを生成するPythonツール
  • オープンソースの顔の動作解析ツールキット『OpenFace』
  • AMIMOTO(PVM版)で作成したインスタンスをAMIMOTO (HVM版)へ移行する
  • 頭蓋骨からの顔復元と進化過程の可視化
  • WordPressのサーバ引っ越し方法を考える
  • Raspberry PiのGPIOを操作するPythonライブラリ『RPi.GPIO』の使い方
  • Mayaのレンダリング アトリビュート
  • Live CV:インタラクティブにComputer Visionコーディングができるツール
  • 映画『シン・ウルトラマン』 メイキング記事まとめ
  • HerokuでMEAN stack
  • trimesh:PythonでポリゴンMeshを扱うライブラリ
  • PyMC:Pythonのベイズ統計ライブラリ
  • Kubric:機械学習用アノテーション付き動画生成パイプライン
  • iPhone・iPod touchで動作する知育ロボット『ROMO』
  • Mayaのプラグイン開発
  • openMVGをWindows10 Visual Studio 2015環境でビルドする
  • トランスフォーマーの変形パターンを覚えるのは楽しいと思うんだ
  • モバイルバージョンを終了