Houdini /obj周りについてメモ
すぐ忘れるのでメモ
随時更新
最終更新履歴 : 2023/04/19
環境
mac os Catalina 10.15.7
Houdini FX(apprentice) version 19.5.303
Houdiniでの用語概念
Houdiniでは面のことをPrimitive
辺を Edge
点をPoint、面や辺を構成する頂点をVertexと呼んでいる。
data:image/s3,"s3://crabby-images/01266/012668f26c067bb6d0d1dc5f00b6302f2d1e27eb" alt=""
Geometry Spread Sheetで確認するとわかりやすい。
Vertexとpointの違いについてColorで説明
GeometryノードとPrimitiveノード(SOP)
Houdiniのモデルは、シーンレベルのジオメトリオブジェクトで表現されます。ジオメトリコンテナオブジェクト内部でジオメトリノードがオブジェクトのジオメトリを定義します。ジオメトリコンテナオブジェクトでは、オブジェクト内部の個々のサーフェスとは別に、移動、回転、スケール、オブジェクト全体をシェーディングすることができます。
Geometry node(コンテナ)と呼ばれる、ノードの中に、具体的な頂点や辺、面を持ったPrimitive (Surface)nodeを入れさせられる。そうやってまとめるのがgeometry node。
他の3DCGソフト系でもよくある構造
このGemetry nodeではTranslateやRotateといった基本Transformをパラメータとしていじることができる。
data:image/s3,"s3://crabby-images/0062e/0062efc5b04dc1aa093e56b7d020bcaf11937297" alt=""
data:image/s3,"s3://crabby-images/e20d4/e20d4f0d068044a143e28757fcc4cffa55f6fff1" alt=""
geometry node中に入っているのはPrimitiveな頂点情報や基本情報を持っているようなものが生成される。
SOPノードと呼ばれる。TouchDesignerなどと感覚は一緒。
tabで検索して作られるnodeも/obj 直下と /obj/geometry 直下では出来上がるnodeが違う。
data:image/s3,"s3://crabby-images/153d8/153d856230ed070e066049ed06f01825826f4810" alt=""
data:image/s3,"s3://crabby-images/9bee7/9bee71711b8295f6d0f52c204291d0108ff8e6e5" alt=""
Spehereと検索した時も、Createだと、Geometryごと作成されて、PrimitiveだとGeometry nodeの中に作成されるnodeとなる。
data:image/s3,"s3://crabby-images/3d154/3d1547c061e0ceaefb180ce8ae6050a141853ddc" alt=""
Primitiveノード内階層でSelect toolを選ぶと、面や辺などを選択できる。
BlenderでいうEdit mode的なイメージ
data:image/s3,"s3://crabby-images/bc684/bc684328746ea9670dec9a99a2f7c12f02548d3d" alt=""
Selectのときに頂点(2)・辺(3)・面(4)を変更できる。
data:image/s3,"s3://crabby-images/77242/772425e0de6cc32bca852bf0f4717af63f38ae8f" alt=""
Group
グループとは、ポイント/フェースの集合体に名前を付けたものです。
Group SOPはジオメトリのポイント/フェースを色々な基準に基づいて並べ替えてから、グループ化します。他のオペレータでも、副作用としてグループを作成します。
ポイントやプリミティブを操作するノードのほとんどには、ノードの効果を追加するオプションがあり、入力としてグループしか対応していないものがあります。そのため、ある特性に基づいてポイントのグループを認識して、それをノードに適用します。
ポイントが削除されても、Houdiniは自動的にそのポイントのグループからポイントを除去します。
Attributeに近い感じで、group条件に入っているpointやPrimitiveは「1」入っていないところは「0」というattributeを追加しているような感じにもなる。
ex : gourp, my_group
1ってちっちゃくgeometry Spread Sheetに書いてあるのは1bitの情報だよってことを表している。
data:image/s3,"s3://crabby-images/4f4d2/4f4d22953acc53aa56a2dea600826d627f529be9" alt=""
Groupが作成されていると、Groupが打ち込めるnodeのパラメーターに候補として出てくる。
data:image/s3,"s3://crabby-images/92ab5/92ab5043f5fe2719783afd897e1abfc7c75c3e8a" alt=""
Primitive / Point Numberの確認
Scene View右側のアイコンより、PrimitiveとPoint Numberを確認することができる。
data:image/s3,"s3://crabby-images/93b7f/93b7f59a88a01716a44a0b4c01f64ab3b20a9e73" alt=""
data:image/s3,"s3://crabby-images/285da/285daa6cc387c22c458ebfacb48f8d666f639b9d" alt=""
data:image/s3,"s3://crabby-images/4c461/4c461a2bf48928179ecadf896ad45e60060b3f59" alt=""
Group パターン
各SOP等で、Group(Pattern)などの名前で、効果を適用させるグループを指定できる。さらにグループでプリミティブやエッジ等々を選択する場合の指定の仕方が決まっている。正規表現的な感じで、詳細はここ。
data:image/s3,"s3://crabby-images/377fa/377fa9b79bd39ba07d614fc7ad559b038d430ab7" alt=""
基本的には、Primitive/Pointは半角スペースで分けて入力するとGroupに追加されていく。
4 3 5 8
Primitive/Pointの範囲選択。連番で選択したい場合は、-(ハイフン)で分ける。
12-18
EdgeのGroupのとき、PointNumberのpと数値とそれぞれを結ぶ-で構成される。
p10-7 p9-10-11 p13-10 p4-5 p12-13 p3-4-13-14
data:image/s3,"s3://crabby-images/7f41a/7f41ac5361297351d57ca6b7fff20229c4501582" alt=""
Edge時に-を使わずに数値のみにすると、そのPrimitive Numberに囲まれるEdgeが選択される。
4
data:image/s3,"s3://crabby-images/6d868/6d868f9ccde0aa50b974e2615ca0f5746b439f79" alt=""
Edge時にPoint Numberで指定するとそのpoint numberに接続されているEdge全てが選択される。
p4
data:image/s3,"s3://crabby-images/206c1/206c15ef97c1dfd4fadeb4c9bbcb507b947560dd" alt=""
n-m:step
step毎にスキップされたコンポーネント番号nからmまで(nを含む)。例えば、1-100:2は、1から100までを1つ飛ばしすることを意味するので、1,3,5,7,9,11,13,15・・・93,95,97,99となります。
n-m:keep,step
コンポーネント番号nからmまでをステップ値stepで定義したもので、さらに、それに該当する番号から連番でkeepの分(該当番号を含めた個数)だけ番号を確保します。例えば、0-20:3,5は、0から20の数字から5ステップの0,5,10,15,20で、さらに、連番をとるので、0,1,2,5,6,7,10,11,12,15,16,17,20となります。
!pattern
パターンにマッチするもの以外のポイント/プリミティブ。例えば、!1-10は、ポイント/プリミティブ番号が1から10以外のものを意味します。
patternには、数値パターン、アトリビュートパターン、グループ名パターンを指定することができます。
^pattern
前のパターンの結果からそのパターンを引いたもの。例えば、0-100:2 ^10-20は、0から100の1つ飛ばしの番号で、10から20までの番号を除いたものです。
patternには、数値パターン、アトリビュートパターン、グループ名パターンを指定することができます。
@attributeopvalue
Attribute
GLSLをやったことがあると、なんとなくわかりやすい概念。
attribute変数的な
各Point / VertexやPrimitiveに対して情報を与えることができる。
例えば各頂点に、Color情報など。
Detailはgeometry全体に対して与えるattributeのことで、
その他、Vertex , Point, Primitiveがある。
例えば、Color nodeを直列に二つつないで、一方はDetail、一方はPrimitiveにColor情報を与えるようにすると、優先されて使われる方は
(優先) Point or Vertex > Primitive > Detailとなっている
PointとVertexにおいては、後につないだ最新の方が優先される。
data:image/s3,"s3://crabby-images/fe3aa/fe3aaf600a68579302b6b96662e1a7e53b82d195" alt=""
同じattribute名でPointやPrimitiveに情報をもたせてしまうと煩雑になって、優先とか色々考えなくてはいけなくなっちゃうので、できるだけ違うattribute名などにしておくと便利。
Attribute create nodeとかで新規でattributeを作ることができる。
Attributeの使い方
attributeを与えたら、各ノードなどでLocal Controlなどの名前で書くparameterをattributeの値で変化させることができて、自由にどのattributeを使いたいかもしていできる。
data:image/s3,"s3://crabby-images/3e84d/3e84d63b7266bd6818d07fd018618c4af3eb6c6a" alt=""
このときparameter上でmouse hoverしておくと、その使い方の説明がでてくるので、
たとえば、polyExtrude nodeのDistance Scaleは元のdistance scaleの値とのMultiplyにすると書いてあるので、1とかにしておかないと0ではいくらAttributeの数値を動かしても動かないので注意。
data:image/s3,"s3://crabby-images/46e65/46e65f408602dd45558b507dcb87c98a4481763d" alt=""
SOP(Geometry) node
Merge
二つのオブジェクトを合成することができる。
ただこのとき、二つのオブジェクトはくっついて一つのオブジェクトになっているわけではなく、個別に存在する。
data:image/s3,"s3://crabby-images/959b2/959b29cbc0322b3a8bd26949ddef2dcd48cb496a" alt=""
data:image/s3,"s3://crabby-images/3922c/3922c236e7ba6bbfd0261d77fd0fb5075ae4cdf3" alt=""
Transform
想像する感じのシンプルなTransform node
data:image/s3,"s3://crabby-images/354c1/354c147f06b73dfd6535349f03cef9c5ac6e29ac" alt=""
Pre-Transformの項目に
Point Normalの再計算などがある。
data:image/s3,"s3://crabby-images/3e9d5/3e9d52180f8e53328987d4b03b8d94b82b1850b3" alt=""
Add
pointの単位でgeometreyを追加することができる。
data:image/s3,"s3://crabby-images/428d9/428d982d5508543d4758524278b0f34e571cd382" alt=""
data:image/s3,"s3://crabby-images/78270/78270ae5c2f243cf875e8ca4a628a6710b4e7eac" alt=""
pointを複数追加したときに、Polygonsのタブで
By Patternであれば、point番号を打ってあげることでそれらをpolygonとしてあげることができる。
Closedにチェックを入れれば閉じたポリゴンになる。
data:image/s3,"s3://crabby-images/4a10b/4a10b461f2fb66ae157f808f3131aea25d095acb" alt=""
data:image/s3,"s3://crabby-images/53190/53190a2d8434394905b6f45fed04f6ce55dc10ba" alt=""
data:image/s3,"s3://crabby-images/2793d/2793dbb8cfb13342e8fe9d215f6ce4902f82139b" alt=""
data:image/s3,"s3://crabby-images/5f0af/5f0af25543e8a710b44b253eea221ef02f494974" alt=""
Attribute create
新規でオリジナルのattributeを追加することができる。
Nameでattribute名
ClassでDetail / Primitive / Point / Vertexのどれに追加するかを選べる。
typeでどういう変数を扱うかを選べる。Float / Vector / Intager / String / Float Array….etc
Precisionで何bitの精度なのか選べる。auto / 8 / 16/32/64 bit
Size : Point座標とかColorRGBみたいな配列のように増やせる
Default : デフォルト値の設定
Write Valuesをonにすると、valuesが使えるようになって、その値で書き換えることができる。
data:image/s3,"s3://crabby-images/a529a/a529a430723896dfebdcab59c6dfb090e7046365" alt=""
data:image/s3,"s3://crabby-images/efcf9/efcf97e300a1bf93760b876ce763072538280d84" alt=""
data:image/s3,"s3://crabby-images/83fbe/83fbed8595f72173cf21e6cbbe30f0ac7ebf8319" alt=""
Allow Local Vars
Turning this off will disable local variables in the Write Values field. This can provide some minor performance improvement when working with very small geometry.
Existing Nameは、もし同じ名前のAttributeが、既にあった場合の処理を変えれる。
data:image/s3,"s3://crabby-images/9ccd8/9ccd8c728d2f3ed969f3c1c9530e10afb6a341ae" alt=""
Attribute Noise
attributeの数値にnoiseを加えることができる。
Attribute Namesとclassを任意のものに指定して、
data:image/s3,"s3://crabby-images/2b8a1/2b8a141cb8472574d48c45b0e90d802e817b142f" alt=""
noise ValueとNoise patternを
data:image/s3,"s3://crabby-images/224ff/224ff8ef95be145897336f916d2199a6ef2c26c0" alt=""
Attribute Randomize
Attribute Noise的な感じで指定したattributeに対して、randomな数値を与える。
Global Scaleで全体の数値をコントロールできる。
data:image/s3,"s3://crabby-images/ec980/ec9806640c510899af90eed0c58c345cdd9bde02" alt=""
Operationで Set Valueならその値のattributeを上書きして、
Add Value / Minimum / Maximum / Multiplyを選べる。
data:image/s3,"s3://crabby-images/aa178/aa178bec4470ae63eb0278416a83951e3354c1d5" alt=""
Min Value / Max Valueで上限下限が決めれる。
data:image/s3,"s3://crabby-images/b10fd/b10fd91b329b9c38d4eb116437c0c6dbffed3a29" alt=""
Distributionの中を変更すると、与える数値の与え方を変えることができる。
data:image/s3,"s3://crabby-images/66bb8/66bb842f6674a272cf13ad178f385b8690302396" alt=""
Direction or Orientationにすると、
角度を扱いたいときに便利なような数値設定になっている。
Dimentionsを4とかにすれば、クウォータニオンを設定したいときなどに便利。
data:image/s3,"s3://crabby-images/5bccc/5bccc4c249039a175bbd3b6e7ef0613c9e8eeb2d" alt=""
Color
data:image/s3,"s3://crabby-images/8dc36/8dc366620188713f9305be39848fe8cc64fe3d6c" alt=""
ColorのAttributeを追加することができる。
ClassでPointやVertex / PrimitiveなどどれにColorのAttirbuteを追加するかを選べる。
Detailを選ぶと、このGeometry全体に対してのColor情報を与えれる。
data:image/s3,"s3://crabby-images/f5487/f5487a68c64b596d1d64bb1babda2a3ee7982ff2" alt=""
data:image/s3,"s3://crabby-images/4c058/4c058cccc31eed3296be5cdc37083138471f0bcf" alt=""
Delete All Exsiting Color Attributesですでに存在していたColorのAttributeを一度消される。
data:image/s3,"s3://crabby-images/ef2de/ef2de7044db5943d9e0f2326ae24be6d5ed2b8a4" alt=""
Color TypeをConstantだと一定の同じ色
Bounding BoxはGLSLでUV出す感じみたいな感じで、x軸がR
Y軸がBに対応していて、Gは固定で0.5
Random
Ramp from Attribute
Random from Attirubte
data:image/s3,"s3://crabby-images/a142f/a142fb625b8ce32a2ff42139948d6a7244ae83c6" alt=""
data:image/s3,"s3://crabby-images/60769/6076940699ddc663475fb9d5b20cc5d1d0e2e1dd" alt=""
Randomよりnoise感に見えるが、それは多分描画がpointとpointの間をマップしているだけで、値的にはpointのcolorの値はrandomな数値になっている。(Primitiveだとわかりやすい。)
※note側の問題で、画像のバンディングが起きているかもしれない。
data:image/s3,"s3://crabby-images/e5d1e/e5d1ea6fbacb8b620767f4cdbff3e3df7e4bfacc" alt=""
data:image/s3,"s3://crabby-images/aa271/aa271326be1c8ead1a0bc5c5e351c2bda6be1098" alt=""
data:image/s3,"s3://crabby-images/ca402/ca402acd6c5c9d4f98f8dad8de699f2d5c98e307" alt=""
Group
面やポイントなどを選択した状態でtab > Group nodeを選択するとGroupが取り込まれた状態で生成することができる。
グループノードは上部のシェルフからModel > Groupからも生成することができる。
data:image/s3,"s3://crabby-images/270f8/270f8d7a24817723af3f1c61ee81f17ca05dd9b2" alt=""
Group TypeでPrimitivesやPointsなど何をグループにしたいかを選べる。
initial Merge :
Replace Existing
新規作成グループが既存グループを置き換えます。
Union With Existing
新規作成グループと既存グループを結合した内容をグループ化します。
Intersect With Existing
新規作成グループと既存グループの共通内容をグループ化します。
Subtract From Existing
既存グループから新規作成グループを引いた内容をグループ化します。
data:image/s3,"s3://crabby-images/03356/03356b929d2b200bd6a5cd3714c88b937d9a4dc1" alt=""
data:image/s3,"s3://crabby-images/25d6a/25d6a07dd70daed5a2112c69dac90e125f64871b" alt=""
data:image/s3,"s3://crabby-images/f950f/f950f262c42980c12f84a6a332ca4ef0133a973b" alt=""
Keep in Bounding Regionsは
バウンディングボックスを指定してその中のPrimitive…etcをgroupにすることができる。
data:image/s3,"s3://crabby-images/39159/39159adb5f2351e5ce47e28cdb61d20fe286f5d1" alt=""
data:image/s3,"s3://crabby-images/33210/3321063292be8999aef2976a0a280fcdfd124396" alt=""
Bounding Typeで、エリアをBox/Sphere/Objectなどでしていできる。
data:image/s3,"s3://crabby-images/27f73/27f738db01228355ede11662cfd1de841df05906" alt=""
Bouding Objectとかにすると、input2にBouding Objectとなるpointsやverticesに指定する
data:image/s3,"s3://crabby-images/92bb8/92bb8e7f97f0ba42eb29fc2b3c3c20e346b8776b" alt=""
ショートカット的なGroupの再選択の方法
案外知らない人が多いのでGroupSOPでの再選択の仕方を書いときます。 #Houdini pic.twitter.com/GBnbfqGbRy
— UnlimitedEffectWorks (@ijiVFX) March 25, 2023
polyExtrude
押し出しとinset(面の差し込み)がセットになっているようなnode
Groupでグループの選択
Divide intoは Connected Componentsにすると面で別れている物体でも同じ量で同様に適用されるが
Individual Elementsにすると、それぞれの面に対してExtrudeをが適用できる。
data:image/s3,"s3://crabby-images/5b870/5b8701e5f254b2f90d2af6d14e06fad503e6fdcf" alt=""
Extrusion Modeで Primitive / Edgeの法線方向に押しだすか、Pointの法線方向に押しだすかを選べる。
Distanceで押し出し距離
Insetで面の差し込み具合
Twistでねじり
Divisionsで押し出し時の面の分割具合
data:image/s3,"s3://crabby-images/fbcff/fbcfff8766e8301655967a122cfbdace60fab6bf" alt=""
data:image/s3,"s3://crabby-images/a4384/a4384b3a4b7e3e02fa8bac345de84c4470ca7a10" alt=""
data:image/s3,"s3://crabby-images/aabb2/aabb26cdc3d5e3bef274f883ab33674128079f2f" alt=""
data:image/s3,"s3://crabby-images/c2e67/c2e67e17b5c49e584efe7e8d2e10d90be61c7248" alt=""
data:image/s3,"s3://crabby-images/6fcf5/6fcf50477aba98f874ad16f3c7da540bcbbb2a3a" alt=""
polyExtrude2D
polySplit
分割することができる。
マウスでぽちぽち切りたいところを操作する方法と
Split Locationsにどうやって分割したいかを記入する方法。
Radial Menuなどでpoly Splitを選ぶと、
data:image/s3,"s3://crabby-images/bb58d/bb58d20561986d90c5833370d62c781c447a6d9b" alt=""
このような分割ラインが勝手に現れる。
適当にぽちぽちエッジをクリックすると、
data:image/s3,"s3://crabby-images/6a59d/6a59d78efd44d9abba623d744a4b016133da9529" alt=""
こんな感じで切れる。
data:image/s3,"s3://crabby-images/7b76b/7b76bb3fa3f6ec58b972cf32e3fd784f3ef9df5d" alt=""
Path Typeは Shortest Distance / Edge Loopが選べて、
ぽちぽちマウスできる時はShortest Distance(最小距離)で点間に切れ込みが入る。
Edge Loopにして、Edgeをクリックすると、
ぐるっと回るように切れ込みがはいる。
data:image/s3,"s3://crabby-images/4da09/4da0970bc84e55ad95f3cef319fb2d1a07da6967" alt=""
data:image/s3,"s3://crabby-images/a818e/a818e087bcf56857ae26b8e0ae7896ab0c5d96fe" alt=""
data:image/s3,"s3://crabby-images/02512/02512fe2d64ea20ea164db55aa64ec4887dc7d27" alt=""
Split Locationsの書き方
カットを作る一連の位置は、以下のコードを使用します。
avb
プリミティブaの頂点bでカットします。aとbは整数です。
aeb
プリミティブaのエッジbの中点でカットします。aとbは整数です。
aeb:t
プリミティブaのエッジbに沿ってtパーセントの位置でカットします。aとbは整数で、tは0.0から1.0の実数です。
af:u,v
プリミティブa上の指定した(u,v)位置でカットします。aは整数で、uとvは0.0から1.0の実数です。
pa-b
aとbのポイント間のエッジの中点でカットします。 aとbは整数です。
pa-b:t
aとbのポイント間のエッジに沿ってtパーセントの位置でカットします。aとbは整数で、tは0.0から1.0の実数です。
Edit
Edit SOPは、カーブ/サーフェスのフェース/エッジ/ポイントをインタラクティブにトランスフォームまたはスカルプトすることができます。
ほとんどのHoudiniノードとは違い、 編集を蓄積します 。つまり、1個のEditノードで(複数選択に対して)複数の編集操作をすることができます。 Editノードは、 そのノード内 で行なったすべての編集の 最終結果 を記憶します。
Editノードは、2つの主な作業方法をサポートしています: 編集 (マニピュレータを使用)と スカルプト (ブラシツールを使用)。
polyExtrudeなどのnodeを使ったとに、Tを押すことで、
Edit Nodeを追加することができる。
Make Circle
右クリックして、Make Circle (Shift+C)で適用できる。
data:image/s3,"s3://crabby-images/ec265/ec265e0f93ef3ed1080cfa1e47aaa60a6e43c6fc" alt=""
Edit SOP に選択した形状を等分した真円 (または選択ジオメトリから最も真円に近い形状) に変換する機能が追加されました。ポイント、エッジ、面のいずれかで選択し、T キーを押してRMB->"Make Circle" または SHIFT+C ホットキーで実行します。
Grid
いわゆるグリッドをつくることができる。
parameterもシンプル
data:image/s3,"s3://crabby-images/0e417/0e417530f9d5c33c5f99c5fce7eb630501250e48" alt=""
data:image/s3,"s3://crabby-images/2dfaa/2dfaa09512fab35feec04de40e6a4e1686dcd168" alt=""
Volume
data:image/s3,"s3://crabby-images/47a24/47a24c5c2cdae654d25c8dbfe254c25934c989d2" alt=""
initial valueを増やすと、とりあえず、雲みたいな感じに見える。
Rankは1つのボクセルにどういう値を入れるかというのを示している
Scalerはスカラー値が入って、VectorとMatrixが選べる。
Vectorを選ぶと初期で3次元ベクトルで入る。
そのままではGeometry Spread Sheatには何も表示されない。
data:image/s3,"s3://crabby-images/22ecf/22ecf597ecd612a9fa58f7a53f50f72dbeb5343a" alt=""
data:image/s3,"s3://crabby-images/946f6/946f6b5d38ffc50dd906b77e453ec826f1f31a7b" alt=""
初期状態のVolumeのinfoを見るとVoxelsというのと、直方体の大きさをかくにんできる [10,10,10] Voxels : 1,000 Volxel Size : 0,1
data:image/s3,"s3://crabby-images/b0cd5/b0cd50e3d4c86693b7651e75e7f2f409a2f1a9a1" alt=""
uniform Sampling Divsという項目を増やすと、ボクセル数が増える。
いわゆる解像度的な分割数。
data:image/s3,"s3://crabby-images/b67cb/b67cb8103331605c38c3175bb94c5f50d1ae0212" alt=""
横長にSizeを2とかにすると、
長辺合わせで、比率を保って増えてくれる。
data:image/s3,"s3://crabby-images/ac2c9/ac2c93ca4d6b9a243ad79b69eb3020355b005222" alt=""
data:image/s3,"s3://crabby-images/1edd4/1edd4de36f54cb3a6d01dff92f0a6f860a0446da" alt=""
Volumeの時は、
Geometry Spread Sheetを見ても、pointは形式的に原点に一個あるがPrimitiveとかもない。
Nameに名前をつけると、Attributeとして名前が追加される。
data:image/s3,"s3://crabby-images/614f3/614f338b52e40e08d2957ececafe782c029bfdaa" alt=""
Uniform Samplingでどのようにdivするかを選べる
デフォルトはMax Axisで、一番長い軸をuniform Sampling Divsの数値にする。
By Sizeでは、Voxel一つ一つのsizeをその数値にするように分割する。
data:image/s3,"s3://crabby-images/0969b/0969b6bfbb5b4df2bf8bd755876c146f2405da4f" alt=""
By Size で Div Sizeが0.01の時のVoxel Size
計算誤差を除けばほぼその数値。
data:image/s3,"s3://crabby-images/b1ed9/b1ed945e17139b1a547625f2e7c70834328df786" alt=""
Volume nodeの前に、Geometryを入れると
それをもとにVolumeが作られる。
data:image/s3,"s3://crabby-images/c391c/c391cc08f6a0fad2b3c093dc2462e1a5291b326c" alt=""
斜めに傾いているようなboxからvolumeを作ろうとすると、それをすっぽり覆うような直方体のvolumeを作ろうとしてしまう。
VDBの場合はネイティブのVolumeとは違う。
data:image/s3,"s3://crabby-images/2dca8/2dca87516e6478b87d5dd78eeaf96d0b180e2ede" alt=""
Volume Slice
VDBにも使える。
ベクトル場の値を作りたい時とかに便利。
Volumeにつなげることで、さっきまでVolumeの状態ではpointとかで存在しなかったものが、1Voxel単位で実際のgeometryとして描画される。
Voxelの中の値が実際描画する形でみることができる。
VectorとなっているVolumeで、uniform Sampling divsが10、sizeが2,1,1のとき、以下のようになっている
data:image/s3,"s3://crabby-images/5b6ac/5b6ac19296d42969343c8fa8dac41c4cd4f58efb" alt=""
これをVolume Sliceノードと繋いで、描画すると、実際point数が横10,縦5のvoxelが出来上がっている。Voxel数が実際のpoint数などになっている。
data:image/s3,"s3://crabby-images/61f57/61f57da725477440aacfc95418122cb5003f7d0c" alt=""
Volumeのinitial Valueを変更すると実際の色として、それぞれがrgbになって変化していることがわかる。
data:image/s3,"s3://crabby-images/ed2bd/ed2bd44ce28ffb23f6065353229e1c34d1cd0d76" alt=""
data:image/s3,"s3://crabby-images/b9535/b9535e37e8ba9e187d1ecc687ae807579c721fbd" alt=""
Sliceをつなげた後の、Geometry SpreadSheetを見ると、attributeにCdやDensityが追加されていることがわかる
CdはVolume nodeのinitialなどの値が埋め込まれている。
data:image/s3,"s3://crabby-images/e7993/e79938f7651369f88fdac2a74e95bd82a6072dc6" alt=""
Offsetの下のAttributeを好きなattribute名にすることで、その名前のattributeが保存される。基本的にはCdと同じ値が保存されている。
data:image/s3,"s3://crabby-images/0c04a/0c04a5ee41efb47c2273d0daf3f52fcf253ff3ee" alt=""
data:image/s3,"s3://crabby-images/62869/62869444c098c8efa79798c43185442eeb2a2479" alt=""
Methodを変更するとそのVolumeを何で描画するかを選べる。デフォでmeshになっていて、pointsにも変更できる。VolumeにするとVolumeとして描画される。
data:image/s3,"s3://crabby-images/b92ed/b92ed0fd8a538f62c49519da775b64ad21276348" alt=""
data:image/s3,"s3://crabby-images/18c62/18c62694f85dd06d9476ef7a8262e8d2cb10130f" alt=""
data:image/s3,"s3://crabby-images/eb50f/eb50f5494870ddd5e7eaf2fbc8452cae52b4f367" alt=""
Planeでどの面を選ぶかを選択できて、
Offsetを動かすとその面がVolumeの範囲内に動くようになる。
data:image/s3,"s3://crabby-images/71600/716000b5a4005863d9df98ca9b2e351b314404af" alt=""
Volume noise Vector
Volume の値にVectorを持っているようなときに、
Volumeの値にベクトル方向を持った、noiseを与えることができる。
Vector Volume Nameに
Volumeのnameを指定する
data:image/s3,"s3://crabby-images/c46e8/c46e835897f6a28669af309953d5362177cf87d9" alt=""
Operationを変えると、値に対してどういう演算するかを選べる。
Setは上書き
data:image/s3,"s3://crabby-images/2ce6c/2ce6cef273ca4316d7de3ae168e95389761966d5" alt=""
Range Valuesは、このnoiseの範囲を指定できる。Zero Centeredは0中心周りでnoiseを生成する。
data:image/s3,"s3://crabby-images/92be2/92be2efe7f37526d5cf59f32b21eda25d6448731" alt=""
Noise Patternより、Noise Typeを変更すると、Simplex noiseやPerlin noiseとかノイズアルゴリズムを変更することができる。
Element Sizeを変更すると、大きなnoiseの脈を変更することができる。
data:image/s3,"s3://crabby-images/f7662/f7662e8ed2d7a02f19585ca47f486b07522aad2a" alt=""
Fractalからもnoiseパターンのあれこれを変更することができる。
data:image/s3,"s3://crabby-images/cbaef/cbaef5858de6ef085040bd384b5456da8c2e229b" alt=""
Volume noise SDF
SDF Volume 用の Noise node
Volume Trail
node1には Points to Trail, pointを持っているgeometryを選択、これが起点となって作られる。
node2には Velocity Volumes、速度場となりうる、Volumeを選ぶ。
data:image/s3,"s3://crabby-images/9aeba/9aeba532f62d7afa18887db52921c6ab5fa62fc5" alt=""
data:image/s3,"s3://crabby-images/b0dd9/b0dd9422fb9581ba1c4cb8873e77f32a9d91fffe" alt=""
Rampで描画の色を変更することができる。
Custom Rampを選べば自分でrampの内容を変更することができる。
data:image/s3,"s3://crabby-images/4789c/4789c55063c7d28cea4b5d2be35682cb913e015b" alt=""
data:image/s3,"s3://crabby-images/fb980/fb980eee700f6ecb1501daee570455d848948f8e" alt=""
Selectツールからいらない部分とかを選択してbackspaceなどで消すと、
blast nodeが出来上がって、描画から消える。
data:image/s3,"s3://crabby-images/e8b00/e8b0069817918ec7541726390a8fa7b4db7fadbf" alt=""
data:image/s3,"s3://crabby-images/fe7a1/fe7a18e46251a8862ae255c7a7037a67a1e7c22c" alt=""
data:image/s3,"s3://crabby-images/b434b/b434bf2eb935db7571de899f929e4c5d41a834ff" alt=""
VDB from Polygon
polygonからVDBを作ることができる。
boxなどからVolumeを作るように作ることができるが、内部のアルゴリズムと構造が違う。
Volumeの場合は対象を覆うようにVolumeを作るが、VDBでは最小のvoxelで埋めるように作る。
そのため、データ量が少なくて済むから軽い。
data:image/s3,"s3://crabby-images/674c4/674c45e009144879715f10c82c6c7021c97d1a80" alt=""
data:image/s3,"s3://crabby-images/0a4cb/0a4cbc99b9a29cb4da018f5df0c82c14928dfc38" alt=""
Voxel Sizeで VDBとしてのVolumeのvoxel sizeを指定できる。
data:image/s3,"s3://crabby-images/f1cc3/f1cc3a731f316ce9e2a39b4e9b3e32d6dd87fbeb" alt=""
Distance VDBにチェックが入っていると、これはSDF(Signed Distance Field)として生成される。
SDFはvoxelの各値をもとのオブジェクトの表面からの距離を格納するようになる。voxelの内側(inside)はネガティブバリューとして保存される。
※衝突判定とかに使いやすい。
data:image/s3,"s3://crabby-images/bd61c/bd61c9fc4c343f75e0282db14224ae070f989858" alt=""
Volume Sliceを使うと状況が分かりやすい。
Convert VDB
VDBを逆にpolygonに戻したりできる。
data:image/s3,"s3://crabby-images/30221/302216568c0e59ed8c4d03aa4648d358df0be07b" alt=""
Converte toはVolume / VDB, Polygons Polygon soupで選べる
data:image/s3,"s3://crabby-images/baf43/baf43460ebc71540a2137a1f15a90182a8b4c508" alt=""
data:image/s3,"s3://crabby-images/d1670/d1670fafb25d3a0a5ee5a992634fbd796ea19086" alt=""
Adaptivityを挙げると
直線部は、そのまま少ないpolygon数で処理される。
data:image/s3,"s3://crabby-images/c5705/c5705fd9954ca1310fc2cd49c4baf79ad4c3c84a" alt=""
data:image/s3,"s3://crabby-images/3f600/3f60092ed73ba039e5898bccaa521147e8c6b5ae" alt=""
VDB Smooth SDF
SDFの状態でスムーズにできる。
別なオブジェクト同士をつなげて、接合部が怪しいときのSDF Volumeを作れる。
ブラーっぽい感じで
Filter Voxel Radius で一回の処理のVoxel半径を決めて、
Iterationsで繰り返し度合いを決める
ブラーってきな感じ。
data:image/s3,"s3://crabby-images/a4bab/a4bab6a5f989141733ea3de66f4f4a61f8e5a09e" alt=""
data:image/s3,"s3://crabby-images/d1a6c/d1a6c0f8749374319554459114d4fc71416ed0a8" alt=""
data:image/s3,"s3://crabby-images/e741f/e741fadb75a2b2f4b2dbb18bf6277502ade0749e" alt=""
Blast
Groupとして、Primitiveやpointが選択されているときにBlastを繋ぐと描画からデリートするとことができる。
ショートカットとして、pointやprimitiveを選択した状態で、backspaceなどで消すと、blast nodeがプロシージャル的に追加される。
data:image/s3,"s3://crabby-images/1634e/1634ed357886f428f0a21d679c6fa5d3f912c899" alt=""
Delete Non Selectedを押すと、反転して、group外が消える。
Recompute Normalsにチェック入れると、
Pointなどに、各ポイントの法線が再計算される。
data:image/s3,"s3://crabby-images/3ee8c/3ee8c786145a0462ac5d5c27cc2bd05ce5bbd832" alt=""
data:image/s3,"s3://crabby-images/dafc3/dafc3e812527e27fd28498ab75be9e3f156a7419" alt=""
Convert
node前後で、polygon, Mesh Bezier Curveなどを変換することができる。
From Typeに前提条件とConvert Toに変換後のものを選択する。
data:image/s3,"s3://crabby-images/ad468/ad46891700d9984805c46aae577e2cb5b4c56f84" alt=""
data:image/s3,"s3://crabby-images/ec90c/ec90c8888b573e8169f9f67b1fef3bc145ba9f26" alt=""
data:image/s3,"s3://crabby-images/43ca1/43ca104b09eb8e82748cf39a50af56e88a3bd9f4" alt=""
data:image/s3,"s3://crabby-images/655ba/655badcf751896b34ac9cd5d75c0f1c39315fdec" alt=""
Copy To Points
input1 : copyもととなるgeometry
input2 : copy先となるpointを持ったもの。
input2のpointのある場所に対して、input1がcopyされる。
TouchDesignerでいうinstanceみたいな感じ。
内部ではattributeに反応しているため、copy先のpointを持ったオブジェクトのattributeを変更することでコピー先の位置や大きさを変更することができる。
data:image/s3,"s3://crabby-images/22b2b/22b2bd4455f2fa3fff77af8bce1b7833eb68e582" alt=""
data:image/s3,"s3://crabby-images/3ed04/3ed04064ba3537bbbbaa7499d99676504e5b89a7" alt=""
data:image/s3,"s3://crabby-images/22d13/22d131dcfee0359cb87a73dc696d94eeacfcb760" alt=""
ジオメトリをポイント上にコピーまたはインスタンス化する時、Houdiniは目的のポイントから特定のアトリビュートを探し出して、コピー/インスタンス毎にカスタマイズを施します。例えば、コピー先のポイント上にpscaleアトリビュートを作成することで、各コピーのスケールを変更することができます。インスタンスのPointアトリビュートを参照してください。
別のソースジオメトリを別のポイントにコピーしたい場合、コピーしたいすべてのジオメトリが(1番目の入力の)ソースジオメトリ内にあれば、 Piece Attribute オプションでそれが可能です。
コピーをもっと制御したいのであれば、For-Eachループを使用することで、各コピーを個々に処理することができます。
input2側に以下のattributeを持たせると、各種変更ができる。
data:image/s3,"s3://crabby-images/c92d7/c92d7897f9be0aa1f220332764fae8d40553bd6c" alt=""
https://www.sidefx.com/ja/docs/houdini/copy/instanceattrs.html
data:image/s3,"s3://crabby-images/92495/92495350cd45385eeed68c3b255a3cbe9fac7672" alt=""
copyをしすぎると、やはりpolygonの数とかが増えてメモリを割いてしまうので、
Pack and Instanceを押すと、Copy元のpolygonやpointをコピーするように考えて処理させるのではなくて、geometry全体をcopyして計算させるように処理を始める。
instanceを作って処理させるようになる。
data:image/s3,"s3://crabby-images/820aa/820aa7dbc1f8a18357d7e93e6ec019a68750fe13" alt=""
その際のinfoをみてみるとpolygonから Packed Geosという項目に変わっていることがわかる。
data:image/s3,"s3://crabby-images/3912f/3912f62f8ed8c9eeac29c0f36d12dbb9eb3ad905" alt=""
points from Volume
geometryやSDFなどから作られる体積を充満するようにpointをちりばめることができる。
data:image/s3,"s3://crabby-images/758d8/758d8c6b02b1e231cbba3545720c862d0990f7c9" alt=""
data:image/s3,"s3://crabby-images/1f436/1f4360369a20f4a9afe32310087f55f115adee7a" alt=""
Source TYpe は Auto Detect / Geometry / Fog / Signed Distance Field(SDF)から選べる。
data:image/s3,"s3://crabby-images/f4939/f4939893c6855de7583284d3032fb621f41ad8e6" alt=""
point separatioinはpointの間隔。
isovalueが面に対して外側領域に
min isovalueで内側から面に対して、
領域を決めることができる。
min isovalueを上げると内側が巣抜けの状態にすることもできる。
data:image/s3,"s3://crabby-images/e2017/e2017ab89f571716c480b56c6437ef5dba86a128" alt=""
data:image/s3,"s3://crabby-images/c57da/c57da6384c85d9ce4ff4e0982e5de8ebb55d4120" alt=""
Normal
法線がおかしくなっていて、マテリアルがごちゃごちゃになっているときなどの法線の再計算を行いたいときに使える。
data:image/s3,"s3://crabby-images/0a536/0a536a11fb624239d61867c4b2908a26bc23b9c8" alt=""
Block Begin / End
loop処理させるためのnode
Block beginとblock endの間に挟むことでloop処理がされる。
data:image/s3,"s3://crabby-images/28158/2815894d765864686e2f83747b3b1f6d02d63985" alt=""
Block BeginにはどのBlock Endと対になっているかを示すために、
Block Pathにendのノードを指定してあげる。path or Drag and Dropで勝手にpathを打ち込んでくれる。
data:image/s3,"s3://crabby-images/ecc8e/ecc8efa1f79b939de6ea2067c9050a68067acc61" alt=""
もしくは一番右側のopen floating operator choseを押すと、treeが現れて指定することもできる。
data:image/s3,"s3://crabby-images/9a574/9a5744ef5d32497a73bbf4fad97c72bacad8a8b1" alt=""
対になるとblock nodeに枠が発生する。
data:image/s3,"s3://crabby-images/91ec9/91ec90e91aa7bba1b012eaaff34b7682df20c540" alt=""
Block endの方でloopの細かい設定を決めることができて
iterations が繰り返しの数になる。
for文的な感じで start Valueと incrementを決めることもできる。詳しい使い方は下。
data:image/s3,"s3://crabby-images/8513a/8513a70f4481b2b5baba6b571b8c49a27ee21d03" alt=""
block beginの方で、
methodを選択することでどういうloop処理にするかを選べる。
デフォルトでの Fetch Feedbackはblock endまでいった処理が引き継がれるが、
Fetch Inputにすると、並列に毎度inputを参照しての処理が数回繰り返される。
data:image/s3,"s3://crabby-images/a9451/a945164e3bfa590785aebc5ceccec5b587856745" alt=""
Block endの方の Gather Methodも変更しなくてはいけない。
defaultでは Feedback Each Iteration, それぞれの繰り返しをフィードバックs流方法になっている。
merge Each iterationにすると、繰り返しそれぞれがマージされたoutを得られる。
data:image/s3,"s3://crabby-images/53e7c/53e7cc82ba3d709eae6ad03dde7d944136673a1d" alt=""
incrementを使う方法
block beginを2つ作って、どちらも同じendに設定する
二個目のbeginの方には、Methodを Fetch Metadataに設定する。
data:image/s3,"s3://crabby-images/8c5b5/8c5b5968fc586839b600dc97a4eb6e777012884e" alt=""
そうすると、Detail Attributes : iteration, numiterations , value , ivalueというDetailのattributeがbeginの方に追加されていることがわかる。
data:image/s3,"s3://crabby-images/042ea/042ea13ab1359743afdf3758eefc832e47b09053" alt=""
numiterationsがblock endで設定したiterationsの数となっている。繰り返し数。
iterationが今何回目の繰り返し処理中なのかを示している。
iterationは0スタートで numiterations-1までになっている。
valueは block endで与えた条件の Start Valueとincrementが足された状態となっている。for文的な。
ivalueは Valueを四捨五入した値が入っている。
data:image/s3,"s3://crabby-images/d0bfc/d0bfc8a8afffead5f45ed932060fcfa587d3b1c7" alt=""
Single passをonにしてい、数値を動かすと途中段階のiteration、繰り返しのところを確認することができる。
debug用途に使える。
data:image/s3,"s3://crabby-images/3ab36/3ab366264798c7f2544894222205ad82fe4c2ad6" alt=""
Transformとかの値にエクスプレッション でattributeを参照するように書いてあげれば、一定のアルゴリズムで複製的なこともできる。
data:image/s3,"s3://crabby-images/231c1/231c1eca95de2d57096510e8b142b05ed8491f0f" alt=""
data:image/s3,"s3://crabby-images/e2ebf/e2ebf09c2124c596eaf854138d588be07111eb51" alt=""
Block Begin にてCreate Meta Import Nodeというものを押すと、
自動でFetch Metadataとblockendのパス指定を行ったblock beginを生成することができる。便利。
data:image/s3,"s3://crabby-images/49934/4993477388be29f7b285437096acc44b82189bb8" alt=""
BeginのMethodのExtract Piece or Pointは
Piece or Pointで抽出するということで、PrimitiveやPoint単位においての繰り返し処理をしたいときに使える。
data:image/s3,"s3://crabby-images/e1d9a/e1d9a634bd457a86dbcd120ba083106b7672d037" alt=""
Endの iteration Methodを
デフォルトで Auto Detect from Inputs これは、自動で検出してくれる
ByCountが今まで見てきたやつ。
By Pieces or Pointsにすると、UIが少し変わり
data:image/s3,"s3://crabby-images/62f28/62f284a1a0d3c92e3f70883777be1aa5530e16e1" alt=""
By Pieces or Pointにすると、
Piecce Elementsを point / Primitiveにすればそれぞれ単位での繰り返し処理を行ってくれる。
iteration一回目が1つ目のPrimitive(面)など….etc
data:image/s3,"s3://crabby-images/65cdf/65cdf1543a80f3ecb47adf999bdb52ea554fe8d9" alt=""
Missing Template Geometryというエラーが出る場合は、
Default Block Path / Piece Block Pathを Block Beginに選択してあげるとうまくいく。
data:image/s3,"s3://crabby-images/18e5d/18e5da7fe7a80a4347223beaa6d5cb88e83f74b0" alt=""
data:image/s3,"s3://crabby-images/0e910/0e910be45854ae42aa4a5bb773d8a2a0fb0aafe2" alt=""
data:image/s3,"s3://crabby-images/730b9/730b924587c161ea385e333c5f8c895250e0162f" alt=""
Piece Attributeでattributeを指定すると、そのattributeが同じものを一塊のPirimitive / Pointとして認識して繰り返し処理をするようになる。
data:image/s3,"s3://crabby-images/f7bd7/f7bd7c1c02b69824d3853e1c0856b3cde811da46" alt=""
node検索で、foreachと検索すると、似たようなことをデフォルトで設定してくれているblock begin/endを出してくれるやつがある。便利。
data:image/s3,"s3://crabby-images/7150f/7150f814bb89cbbdc84abc2dc6a57a7b93eaacc3" alt=""
Match Size
オブジェクトの大きさを指定したサイズに自動調整してくれる。
data:image/s3,"s3://crabby-images/7a8e3/7a8e3225bdfd79c6cd33d01a081ee7dd1856c760" alt=""
Matching内の Scale to Fitを押すと、Target Size / Positionに設定したようにmatchしてくれる。
data:image/s3,"s3://crabby-images/83375/83375c1588f4f0468d1037d38b8c12d0fe715562" alt=""
Compile Begin / End
Compileをすると、ある程度のノードの処理群を一度計算済みにすることができる。
コンパイルしたい処理群をcompileのbeginとendで囲んであげることで基本はおk
ただしblock begin/endのような処理をコンパイルする際に具体的なinputここでいうadd2みたいなものが想定されないといけないが、compileの中には含まれないのでinputを定義できてない的なエラーが発生する。
data:image/s3,"s3://crabby-images/ec1f3/ec1f3e4e5dd0857573bced74298888f451743ac4" alt=""
その場合は、block endの中にある default block pathにbeginをせってしてあげるとエラーが止まる。
data:image/s3,"s3://crabby-images/55cf4/55cf436e46eb199c69f120528687ad51718e1689" alt=""
ESCキーで一旦コンパイル処理を停止することができる。
コンパイルノードの中でコンパイルブロックに入っていないノードからの参照がある場合(以下のような)、コンパイル処理がうまくいかない。
data:image/s3,"s3://crabby-images/8175d/8175de5448293cfee2556378c92524bb11fb7e90" alt=""
参照しているノードにおいて parameter windowから 歯車マーク > Add Spare InputでSpare inputという項目を出現させる。
data:image/s3,"s3://crabby-images/2506e/2506e9d17be262298b3c8b58b9cb5dfdc859a5af" alt=""
data:image/s3,"s3://crabby-images/3312f/3312f801aaa362b16fda026264fa23e1a02d68ea" alt=""
ここに参照元のノードpathを指定してあげると
data:image/s3,"s3://crabby-images/7e55f/7e55fda78dbcd316dfe7c992a20556641fef6cdd" alt=""
Compile Blockの一部として認識されて処理されるようになる。
ただこれでもエラーが消えずに、expressionとして参照している場合は、
data:image/s3,"s3://crabby-images/55959/55959a12ad91f7c9e6e3b50f2cc5bb0635f9cdc3" alt=""
ノードパスを-1と指定してあげるとspare inputが指定されて処理がうまくいくようになる。
data:image/s3,"s3://crabby-images/07c63/07c6356da4bf7f4e0444eeae036e6c3f4e9d4386" alt=""
Block endに存在する、 Multithread when Compiledにチェックを入れると、
並列化処理が行える時は、compileで早く処理してくれるようになる。
block beginのmethod が Fetch Feedbackになっているときは意味をなさない。
data:image/s3,"s3://crabby-images/22bd9/22bd94667dda5a5ec4378683923e858ccec1dccd" alt=""
コンパイルブロックは、制限事項がたくさんあります。
その中でもよく困るのが、「名前によるジオメトリの参照の不可」と「ノードの直接入力の不可」です。
「名前によるジオメトリの参照の不可」は例えば、npoints(“/obj/sphere1”)のように、ノードパスを指定しジオメトリ情報を取得するヤツです。
「ノードの直接入力の不可」は例えば、npoints(0)って書いて一番目の入力からジオメトリ情報を取得するヤツです。
これを封じられたら、エクスプレッションでのノードの参照はほぼ不可能と言っても過言ではないかと。
このままでは出来ないことが多すぎるってんで、対策として用意されたのが”Spare Input”だとか、・・・そうでないとか。
Spare Inputを使うことで、無事、他のノードからジオメトリ情報を読み込め、それをエクスプレッションでも利用できるようになったと。
めでたしめでたし。
Connectivity
トポロジーとして繋がっているPrimitive / Pointに対して同じ値のattributeを付与するnode
Connectivity Typeには Point / Primitiveが選べる。
Attributeにはそのこれから与えたいattributeの名前 defaultでclassになっている。
Attributeが integer / stringか選べる。
data:image/s3,"s3://crabby-images/fa1b0/fa1b034e57297f16970957c44be8e64ae1b0081d" alt=""
同じ物体として繋がっていると判定されると,
そのもの同士を区別できるようにclassのattributeが与えられる。
data:image/s3,"s3://crabby-images/7d791/7d791606edea3bdb565e453b9d43f7d8f03eb6b3" alt=""
data:image/s3,"s3://crabby-images/053f5/053f5b9eb09c2bd550e703323cc528174ce3170f" alt=""
VEX / VOP
VOP = VEX Operatorの略
VEX = Vector Expressionの略
VOPの中ではVEX Edit内にて、nodeベースでnodeをカスタマイズすることができる。
イメージとしてはカスタムノードを作れるような機能。
data:image/s3,"s3://crabby-images/d70d7/d70d74d7ce1ce9d72d68d110525675c3fcf0f211" alt=""
これらは内部て的にVEXというコードで動いている。
data:image/s3,"s3://crabby-images/9039c/9039c18a4be2dfbc84344f8de33677aeb6fb019d" alt=""
VOP内で繋いだノードたちはVEXで記述することと同じことを意味して相互に影響しあっている。
data:image/s3,"s3://crabby-images/c4672/c46724383a3ba2e019d4b57668c138956bf5ae60" alt=""
Attribute VOP
attributeをnodeベースで処理して、計算することができる。
一番左のinputにSphereなどのGeometry系を繋ぐ
data:image/s3,"s3://crabby-images/34063/340632f8170d75ba1fe8fd93eb919fe5596e1297" alt=""
attribute VOPをダブルクリックすると内部構造に入ることができる。
tabキーを押すとVEXに対応したノードが色々追加されている。
data:image/s3,"s3://crabby-images/d41da/d41da77eb70587b8fc20c6b8e19fae68f2f614d9" alt=""
geometryvopglobalという名前でinputされたもののattributeを持っているものが先頭にできる。
data:image/s3,"s3://crabby-images/e85b0/e85b02ad43c17a33c869c58f78b6814c22bbe201" alt=""
geometryvopoutputにつなげることでそのattributeに反映させることができる。
Pに繋げば例えば、移動されるし、Cdに三次元配列を入れれば色を変更することができる。
data:image/s3,"s3://crabby-images/a80ea/a80ea7e0f6ca6d53d8fac8fb831f26a005dc2da8" alt=""
data:image/s3,"s3://crabby-images/11c01/11c0187f6cc5e1a6d8871f5bc48b61e622f7f096" alt=""
Attribute VOPのRun OverがPointsになっていれば、Point単位のattribute、Premitive単位のattributeなど切り替えることができる。
data:image/s3,"s3://crabby-images/4b2b3/4b2b382652bc5b53118bbcb198102231b377edd4" alt=""
data:image/s3,"s3://crabby-images/b9530/b953098f7c540816b1a5917f21c66d350792d92a" alt=""
Constant
定数生成
data:image/s3,"s3://crabby-images/3d8da/3d8daf45aea303e9879c5ec2aca7b3cddf3339d3" alt=""
Constant Typeは色々選べる。
data:image/s3,"s3://crabby-images/5f7e0/5f7e04fe0b1019da35b91e8241d08a36fe6e080a" alt=""
add
inputに挿したやつの合計を出力
data:image/s3,"s3://crabby-images/6fd1d/6fd1d75c15777e46eff9ef835e38ef3a373cfeea" alt=""
Turbulent Noise
Noise関数を構成するパラメーターを設定できる。
data:image/s3,"s3://crabby-images/440ce/440ceb3ac1a0a12ca58f16e5376e77a07d27bec7" alt=""
data:image/s3,"s3://crabby-images/c68b0/c68b01d3801228a95bc2dda3782bd6efbbb8078e" alt=""
Signatureからは1D Noise、3D Noiseから選べる。
data:image/s3,"s3://crabby-images/b4f13/b4f13b089a29e7ad03b2f1fea951ed741961d78b" alt=""
Noise typeは以下から選べる
data:image/s3,"s3://crabby-images/8ca14/8ca14612fb08b7dec29844ea64dc49b3757bb5c8" alt=""
Point単位の Pをturbulent Noiseのposに入れるとpoint単位にNoise関数のpositionに反映されて、出力される
data:image/s3,"s3://crabby-images/8356c/8356cb2e772fd8e1592894a88b15aea947be27ed" alt=""
data:image/s3,"s3://crabby-images/2b3c5/2b3c50b37eb2822f9d98a03156d6cdf70476e0a4" alt=""
Displace Along Normal
法線方向に沿って、displaceしてくれる。
data:image/s3,"s3://crabby-images/c3c0e/c3c0ef5001c92ddac7875cc03208b0169fe9d9f6" alt=""
Pを入れると、Pの法線方向にディスプレイしてくれる。
dispPは動かされたpositionを返してくれる。
Displacement Amountを動かすとdisplaceされていく。
data:image/s3,"s3://crabby-images/6cb1a/6cb1aac4373c1104654be94527062d622845a714" alt=""
NoiseなどをScaleなどに入れてdispPをPに入れると
data:image/s3,"s3://crabby-images/dab26/dab261cb74e4d783c2a814236d5b9a09388809a0" alt=""
data:image/s3,"s3://crabby-images/52af4/52af4b3527a046b17d29314d00c691621311516d" alt=""
Modulo
モジュロ演算(%)ができる。
input2がパラメーターのdivisorにあたる。
data:image/s3,"s3://crabby-images/4215c/4215ce3aec03f1688703b2e15ed2c35b3b2531b3" alt=""
data:image/s3,"s3://crabby-images/0fc7f/0fc7fcb40672beec13310ea036fad465fd7bd9bd" alt=""
Signatureで型を選べる。
data:image/s3,"s3://crabby-images/d678b/d678b01b5209b252bf1bfd7358d36811a5d7c249" alt=""
Noiseからきた値をmoduloして、displaceのscaleとかに入れると繰り返しが起きて、ノコギリ系になる。
data:image/s3,"s3://crabby-images/99e16/99e164fa0ec3d60bff09adab2baa251afc04c93e" alt=""
data:image/s3,"s3://crabby-images/3d2a2/3d2a2bd2bfd5874258914bac0704ea7438359198" alt=""
divide
単純に割り算。
Parameter
Parameter系列を追加すると、それを内包しているVOPのparameterに出現してそっちで調整することができる。
data:image/s3,"s3://crabby-images/235f4/235f478a5b622e043603c071c932eb0ba5611ac0" alt=""
data:image/s3,"s3://crabby-images/b8d1a/b8d1a3b5a1664f00bdb1e96f3139ab1a79d80fa1" alt=""
VOP内のparameterにparmとして追加される。
data:image/s3,"s3://crabby-images/57cfa/57cfa8ccba6d673979105c984b034a2bb23922f5" alt=""
デフォルトでnameがparmになっているが、任意の名前に帰ることで親VOPのところに出現するparameterの名前を変更することができる。
ここは内部的なVEXの中の変数名としても使われるため、一部の文字制限のルールを守らないといけない。スペースを開けてはいけないなど。
data:image/s3,"s3://crabby-images/53be7/53be7c891e9ca55dd7bcab15675ab0bdf38bb1dc" alt=""
data:image/s3,"s3://crabby-images/42bdc/42bdce8393434ab49c59bd0d4c5c9056c54ddd54" alt=""
data:image/s3,"s3://crabby-images/8f1b6/8f1b6866183bd8316cdd9b9b2bb635dddb13979e" alt=""
LabelにはVEXの中では変数名として使われずにVOPのparameterの名前だけのインターフェースの名前として使われる。
data:image/s3,"s3://crabby-images/aa0bf/aa0bf1e630af148bdf341baf11588e944907f257" alt=""
そのため、ある程度好きな名前をつけれる。
data:image/s3,"s3://crabby-images/30e9b/30e9be11560980def4ba57341006019bc955265a" alt=""
Promote Paramter
parameterをたくさん手動で作ってもいいが、各ノードにある右側の歯車マークより
data:image/s3,"s3://crabby-images/a8ae5/a8ae53ef1073ec8af260492293d9c6a48b0951d8" alt=""
Promote Parmaterを押すと、
data:image/s3,"s3://crabby-images/63169/63169ee7f9633fe34c6eac61fe1d1a54376b8af5" alt=""
nodeのinputにぴょこってUIがでる。
data:image/s3,"s3://crabby-images/cd1a2/cd1a283c6dc18d2d6ad76edc35e0552f54cad57f" alt=""
ダブルクリックすると、parmeter nodeが出現する。
つまり、勝手にparameter nodeを作ってくれる便利機能
data:image/s3,"s3://crabby-images/4b023/4b0238989f1dd2ad4db9c0f627a84e570f2236af" alt=""
Ramp parameter
inputに0~1の値を受けて、remapする。
data:image/s3,"s3://crabby-images/d58a0/d58a0a60fcfb6ed99c697f8139e5fe0ba0dadd13" alt=""
data:image/s3,"s3://crabby-images/3eb56/3eb563e0bacb1ee445e25ca38c57205ecab87c0f" alt=""
Ramp Typeyり、RGB Color Ramp or Spline Ramp(float)が選べる。
data:image/s3,"s3://crabby-images/08c44/08c44d196118cbefd7d1ec499cc54c4c41a7e3e4" alt=""
Spline Ramp(float)を選ぶとkeyframe interpolationみたいに
Interplationから選ぶとeasingつけれる
data:image/s3,"s3://crabby-images/aa993/aa993c9a270e302b1da12ae126843ac99552ff0c" alt=""
ramp parameter nodeを内包しているVOP nodeのparameterにrampが出現するようになってそこから調整するようになる。
data:image/s3,"s3://crabby-images/9a5e0/9a5e005515a7597df312767a71da3872458dbe0d" alt=""
float
Reference
HOUDINI ヘルプ19.0.657