HoudiniをPython3でやる!!!


はじめに

今年2回目のアドカレ記事。一つ目は、『SideFX Labs Toolの新規のインストール方法、Package機能に関して検証してみる』といったものでした。
なので、今度は別角度のものをば。

Pythonネタです。

諸事情で、僕の業務のベースはすでにPython3系に移行していて、Python3系を常用している。スタンドアロンのツールを作る時も3系。
M○y○などの関係で、Python処理を書かなければならないときも、ベースはPython3でパイプランを書いて、M○y○の処理をPython2で回す処理を別プロセスで回したりする。
むしろ、「ほかのさまざまな自動処理は3系で書くのが前提なのに、DCCツールのためにPython2を使わなければならない」という制限されることによる心理状況や、その対応をちまちまやることの不毛さによるストレスを抱いてしまうくらい。

VFX Reference Platformの記事を追っていくと、以前は、2019年の時点でPython3に移行することが示唆されていた。ただ、やはり、対応が難しかったようで、今では2020年になっている。(といいつつも、M○y○ 2020でPython3バージョンはまだ出てないようだが…?)
もう年はずらさないという意気込みの噂は聞こえてきていて、「本当か?」という疑問は持ちつつも、今回の「 Houdini 18にて、Python 3のプレビュー版が配布され始めた 」というのには、一つの歴史を区切るイベントがいよいよ起こり始めたなと感じる。

まぁ、そういうことで、待ちに待ったPython 3対応のプレビュー版がオープンになったので、バグがおおいらしいというのはともかく、体当たりしてみようじゃないかというわけ。

ちなみに、Python3での処理自体は、17.5のPDGの時点で可能になっていて、フローの中にPython3の処理を挟む方法に関しては、すでにこちらで方法を記載しているので参照されたし!


ちなみにちなみに、断っておくが、このバージョンはあくまでプレビュー版で、バグに体当たりしにいくというドMプレイをしているだけなので、マネをする際には覚悟して飛び込んでネ

さぁ、いってみよう

プレビュー環境

Houdini 18.0.310
Windows 10

インストール

まずはインストーラーをダウンロードしに行きます。

まずは、 Get > ダウンロード に行って、

Production Build か Daily Buildのダウンロード項目で、それらのページに行きます。どっちでもいいです。

デフォルトでは、指定のフィルターがかかってみているので、フィルターメニューのHoudini Python 3でフィルターを切り替えます。

そしてダウンロード

そしてインストール
おらぁ

試してみる

とまぁ、ダウンロードとインストールだけで終わるしょーもない記事でもよかったけれども、実際の挙動が気になるので、もうちょっと試してみる。

起動

起動開始後、コンソール表示に出てくるエラーに早速不穏な空気を感じつつ、起動が完了した。

どうやらここら辺はまだPython 3対応してないっぽい。

Python Shell

とりあえず、Python Shellを立ち上げてみる。
現状の3.7系の最新版である、Python 3.7.4が採用されている。

Window Title

WindowタイトルにもPython 3が記述されており、今どのバリアントを使っているかが認識できる。

ノードエディットのイベントが対応されていないバグ一個目

どうやら、Houdiniのノード名を書き換えたときのイベントもPythonを使っているのか、ノード名の変更でさえも許可してもらえない。Unicodeエラーを起こしている。

ノードの名前も変えさせてくれないのか…アツいぜっ

Python 3系にバッテリーインクルードされているモジュールが通るかのテスト

Pathlibで試してみる。

とおった!
個人的には、これが使えるだけで、評価の価値がある

Houdini Python 3 with TensorFlow on Windows

Windows版のTensorFlowは、はたからPython 2に対応するつもりもなく開発されてたので、サポート外をゆくか、もしくはLinuxをあえて使うといった選択肢だった。
しかしながら、Python 3にHoudiniが対応したとなれば、もうそんなのも関係なくなるので、堂々とサポート下でTensorFlowを使える
ということで、いけるか試してみた。

とりあえず結果だけ。

んん、いけない(。´・ω・)

ちなみに、2回目たたくと別のimportエラーが出る

>>> import tensorflow as tf
Traceback (most recent call last):
  File "<console>", line 1, in <module>
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow\__init__.py", line 98, in <module>
    from tensorflow_core import *
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\__init__.py", line 45, in <module>
    from . _api.v2 import compat
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\_api\v2\compat\__init__.py", line 23, in <module>
    from . import v1
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\_api\v2\compat\v1\__init__.py", line 40, in <module>
    from . import experimental
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\_api\v2\compat\v1\experimental\__init__.py", line 11, in <module>
    from tensorflow.python.ops.control_flow_v2_toggles import output_all_intermediates
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\ops\control_flow_v2_toggles.py", line 24, in <module>
    from tensorflow.python.ops import control_flow_util_v2
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\ops\control_flow_util_v2.py", line 28, in <module>
    from tensorflow.python.keras.engine import base_layer_utils
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\__init__.py", line 27, in <module>
    from tensorflow.python.keras import applications
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\applications\__init__.py", line 25, in <module>
    from tensorflow.python.keras import engine
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\engine\__init__.py", line 23, in <module>
    from tensorflow.python.keras.engine.base_layer import Layer
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\engine\base_layer.py", line 56, in <module>
    from tensorflow.python.keras.saving.saved_model import layer_serialization
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\saving\__init__.py", line 20, in <module>
    from tensorflow.python.keras.saving.hdf5_format import load_attributes_from_hdf5_group
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\saving\hdf5_format.py", line 32, in <module>
    from tensorflow.python.keras.utils import conv_utils
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\utils\__init__.py", line 38, in <module>
    from tensorflow.python.keras.utils.multi_gpu_utils import multi_gpu_model
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\utils\multi_gpu_utils.py", line 22, in <module>
    from tensorflow.python.keras.engine.training import Model
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\engine\training.py", line 42, in <module>
    from tensorflow.python.keras import metrics as metrics_module
  File "D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\metrics.py", line 34, in <module>
    from tensorflow.python.keras.engine.base_layer import Layer
ImportError: cannot import name 'Layer' from 'tensorflow.python.keras.engine.base_layer' (D:\Develop\Houdini\Qiita\tf2\python3.7.4\site-packages\tensorflow_core\python\keras\engine\base_layer.py)

検証方法A

とりあえず、pip install時に切り出してテストするやり方。

  1. Anacondaで、Python3.7.4環境を作って、その環境に入る。
  2. コマンドラインで、pip install -t <検証用パス> tensorflow=2.0.0でインストールする。
  3. コマンドラインで、set PYTHONPATH=<検証用パス> でセットする。
  4. 一応、コマンドライン上でちゃんと動くかテストしておく。
  5. コマンドラインで、 call "C:\Program Files\Side Effects Software\Houdini 18.0.310\bin\happrentice.exe" でHoudiniを実行する or houdini.env に書き込む。
  6. import tensorflow as tf;tf.__version__ とか実行してみる。

結果

上記エラー

検証方法B

素直にAnacondaのconda installに任せてみるやり方。

  1. Anacondaで、Python3.7.4環境を作って、その環境に入る。
  2. コマンドラインで、conda install tensorflow=2.0.0でインストールする。
  3. 一応、コマンドライン上でちゃんと動くかテストしておく。
  4. コマンドラインで、 call "C:\Program Files\Side Effects Software\Houdini 18.0.310\bin\happrentice.exe" でHoudiniを実行する or houdini.env に書き込む。
  5. import tensorflow as tf;tf.__version__ とか実行してみる。

結果

同じく上記エラー

検証方法C

そもそも、Houdiniインストール時についてくるPythonは大丈夫なのかテストするやり方。

  1. 検証方法Aのステップ3までやっておく。
  2. コマンドラインで、"C:\Program Files\Side Effects Software\Houdini 18.0.310\python37\python.exe" で、Houdiniのインストール時についてくるPythonを起動してみる。
  3. import tensorflow as tf;tf.__version__ とか実行してみる。 -> こいつはちゃんと動いてる

検証方法D

そもそも、新しいDaily Buildを試してみる。

検証環境
Houdini 18.0.315

  1. 新しいビルドをダウンロードしてきていんすこ。
  2. 検証Aの手順でテスト。

結果

同じだった…(。´・ω・)

うーん…(。´・ω・)
どうやら、Houdini Python3についてくる別のモジュールあたりが悪さしてる可能性。houモジュール自体が、まだPython3に対応してない感じかな。
これ以上は追う気力が失せてしまった……。
まぁ、またしばらくしたら試してみようと思う。好奇心の灯は再び

まとめ

………、と、とりあえずPython3が動く(嘘は言っていない)のは確認できた。
しかしながら、なかなかにまだまだ茨の道なのか、開発の方々も大変苦労しておられる様子…。もうしばらく見守りつつ、さらなる検証をしていくという事の方がいいかもしれない。