プロンプトの領域指定を行うカスタムノードです。ComfyUIにはlatent coupleベースの領域指定法が存在しますが、こちらはUNet内のAttention層で領域分けします。
- custom_nodesにくろーん
- latent coupleと同様のノードを作る。(参考)
- loaderからattention coupleのノードをロードしてMODELとCONDITIONINGを繋げる
- 画像を作る
比較用として、modeをLatentにすると、latent coupleになります。といってもこのノードで何かするわけではなく入力をそのまま出力するモードになるだけです。
実験段階でたぶん色々問題があります。
- モデルのモジュールを無理やり書き換えるので他の機能になんらかの影響を与える可能性があります。
- Pytorch 2.0以上が必要です。
- モデルをぢーぷこぴいしてるのでVRAM使用量とかがあがったりするのかも(分からん)。
- サンプラーによっては想定しない動作が起こる可能性があります。(uncondとcondの順番が全部同じなのか分からない・・・)
- どのプロンプトにも指定されていない領域があるとエラーが起こります。
- LoRAの領域指定は実装していないし見当もつきません。
- SDXLにおけるpooled outputは分割せずに1番目のプロンプトがそのまま入力されます。(そもそもSDXLでテストしてないけど)
Latent coupleはプロンプトの数だけUNetの計算が必要になります。Attention coupleは計算量が比較的小さいCross Attention層のみ複数回計算が必要になり、計算時間は単純な生成とほとんど変わりません。またUNet内部で領域分けすることでより自然な分割が期待できますが、UNet内は画像を縮小してしまう層があるため、細かい分割がしづらいという欠点もあるようです。