「Stable Cascadeを使って画像生成したいけど、どうやって導入できるのか全く分からない」
と困っていませんか?
Stable Cascadeを使う1つの方法として
ComfyUIを使って導入するやり方があります。
コピペするだけで簡単にStable Cascadeを導入できるサンプルコードを用意しているので
是非参考にして画像生成してみてください!
この記事では、Google Colabを使ってComfyUIでStable Cascadeの導入方法から画像生成する方法までを解説します。
4つのファイルのダウンロードURLを取得する
data:image/s3,"s3://crabby-images/1f5d1/1f5d1bdf2f372ae88fd01dd75baf60c42e60096b" alt=""
Stable Cascadeでは、次の4つのファイルのダウンロードURLを取得する必要があります。
①stage_a.safetensors
②stage_b_bf16.safetensors
③stage_c_bf16.safetensors
④model.safetensors
上記4つのファイルは、全て「Hugging Face」にあるStabilityAIのアカウントからダウンロードURLを取得することができます。
以下のリンクからダウンロードURLを取得することができます。
アクセスしたら「stage_a.safetensors」「stage_b_bf16.safetensors」「stage_c_bf16.safetensors」の3つのファイルがあるので、それぞれダウンロードURLを取得します。
data:image/s3,"s3://crabby-images/f90ea/f90ea03b2c2c948183a53e7f3f205e1b87cfc1aa" alt=""
ダウンロードURLを取得するには、「ダウンロード」アイコンを右クリックしてください。
Google Chromeを使っている方は、「リンクのアドレスをコピー」をクリックすることで取得できます。
ダウンロードURLはGoogle Colabのコード内で導入するときに必要になりますが
後でコピペで使えるコードを教えるので、コピーする作業は別に行わなくても結構です。
data:image/s3,"s3://crabby-images/19b4e/19b4e3b34abe8bdaa8e69a10c1efdd9f04143bc0" alt=""
もう1つのファイルもダウンロードURLを取得する必要があります。
「text_encoder」をクリックしてください。
data:image/s3,"s3://crabby-images/7e001/7e00122e755f29de2831798d1fc914ac15a6bc5a" alt=""
「model.safetensors」があるのでダウンロードURLを取得してください。
data:image/s3,"s3://crabby-images/7a0c9/7a0c98829b1ed82712567f297d5b5dd0a601f20d" alt=""
Stable Cascadeのコードを導入する
data:image/s3,"s3://crabby-images/05206/05206282c5bd504b4ccd829ba31a5a61900fd24f" alt=""
Google Colabにアクセスしてから
「ノートブックの設定」で「T4 GPU」を選択してから
「ハイメモリ」のトグルをオンに設定してください。
「ハイメモリ」をオンにしないと、生成中に自動で終了してしまい画像生成できない場合があります。
data:image/s3,"s3://crabby-images/b25a5/b25a537ea5e8bebb39309b23516a116ab282df50" alt=""
Google Colabのコード内に以下のコードをコピペしてください。
import os
!apt -y update -qq
!apt -y install -qq aria2
!pip install -q torch==1.13.1+cu116 torchvision==0.14.1+cu116 torchaudio==0.13.1 torchtext==0.14.1 torchdata==0.5.1 --extra-index-url https://download.pytorch.org/whl/cu116 -U
!pip install -q xformers==0.0.16 triton==2.0.0 -U
!pip install -q mediapipe==0.9.1.0 addict yapf fvcore omegaconf
!git clone https://github.com/comfyanonymous/ComfyUI
%cd /content/ComfyUI
!pip install -q -r requirements.txt
!git reset --hard
!git clone https://github.com/ltdrdata/ComfyUI-Manager /content/ComfyUI/custom_nodes/ComfyUI-Manager
!wget https://github.com/cloudflare/cloudflared/releases/latest/download/cloudflared-linux-amd64 -O /content/cloudflared-linux-amd64 && chmod 777 /content/cloudflared-linux-amd64
import atexit, requests, subprocess, time, re, os
from random import randint
from threading import Timer
from queue import Queue
def cloudflared(port, metrics_port, output_queue):
atexit.register(lambda p: p.terminate(), subprocess.Popen(['/content/cloudflared-linux-amd64', 'tunnel', '--url', f'http://127.0.0.1:{port}', '--metrics', f'127.0.0.1:{metrics_port}'], stdout=subprocess.DEVNULL, stderr=subprocess.STDOUT))
attempts, tunnel_url = 0, None
while attempts < 10 and not tunnel_url:
attempts += 1
time.sleep(3)
try:
tunnel_url = re.search("(?P<url>https?:\/\/[^\s]+.trycloudflare.com)", requests.get(f'http://127.0.0.1:{metrics_port}/metrics').text).group("url")
except:
pass
if not tunnel_url:
raise Exception("Can't connect to Cloudflare Edge")
output_queue.put(tunnel_url)
output_queue, metrics_port = Queue(), randint(8100, 9000)
thread = Timer(2, cloudflared, args=(8188, metrics_port, output_queue))
thread.start()
thread.join()
tunnel_url = output_queue.get()
os.environ['webui_url'] = tunnel_url
print(tunnel_url)
#stage_a
!aria2c --console-log-level=error -c -x 16 -s 16 -k 1M https://huggingface.co/stabilityai/stable-cascade/resolve/main/stage_a.safetensors?download=true -d /content/ComfyUI/models/vae -o stage_a.safetensors
#stage_b_bf16
!aria2c --console-log-level=error -c -x 16 -s 16 -k 1M https://huggingface.co/stabilityai/stable-cascade/resolve/main/stage_b_bf16.safetensors?download=true -d /content/ComfyUI/models/unet -o stage_b_bf16.safetensors
#stage_c_bf16
!aria2c --console-log-level=error -c -x 16 -s 16 -k 1M https://huggingface.co/stabilityai/stable-cascade/resolve/main/stage_c_bf16.safetensors?download=true -d /content/ComfyUI/models/unet -o stage_c_bf16.safetensors
#model.safetensors
!aria2c --console-log-level=error -c -x 16 -s 16 -k 1M https://huggingface.co/stabilityai/stable-cascade/resolve/main/text_encoder/model.safetensors?download=true -d /content/ComfyUI/models/clip -o model.safetensors
!python main.py --dont-print-server
コードをコピペしたら実行ボタンをクリックしてください。
data:image/s3,"s3://crabby-images/3c341/3c34112d3ae6a57df82b64ee77b41b79cba4a14e" alt=""
コードの下付近に「trycloudflare.com」のURLが表示されるので、クリックしてComfyUIを起動してください。
data:image/s3,"s3://crabby-images/9bffd/9bffd3fa05d8529103604cc0af3e9196a7a220a7" alt=""
Stable Cascadeを使って画像生成する
data:image/s3,"s3://crabby-images/599bc/599bc9ca61a6ee840b19167c92023f02fbeb7e0e" alt=""
ComfyUIを起動したら、次はStable Cascadeを使って画像生成するためのworkflow(jsonファイル)をダウンロードします。
workflowは、CivitAIにある以下のリンクからダウンロードすることが出来るのでアクセスしてください。
「Download」をクリックしてjsonファイルをダウンロードしてください。
data:image/s3,"s3://crabby-images/85796/857961e7eb2181a037a6c1a8ba68da6cc6062715" alt=""
ComfyUIに、ダウンロードしたjsonファイルを
何もないところにドラッグ&ドロップしてください。
すると、1つの部分だけ赤く表示されてエラーが出ます。
これはノードが足りていないと表示されるエラーとなっています。
このままではまだ画像生成できませんから、エラーになっている赤い部分のノードを追加します。
data:image/s3,"s3://crabby-images/8ae71/8ae7190221e8953010fc54f732e28c8950e7c0a2" alt=""
右側にある「Manager」をクリックしてください。
data:image/s3,"s3://crabby-images/15079/150798932b80fe663a7906ca81f28149a7e86c09" alt=""
「Install Missin Custom Nodes」をクリックしてください。
data:image/s3,"s3://crabby-images/ab14a/ab14a331694b77d4027495bb2dcd2c7a4d5e9113" alt=""
足りていないノードが表示されるので
左側にあるチェックをつけてから
右側にある「Install」をクリックしてください。
data:image/s3,"s3://crabby-images/710a7/710a75864e8843f90ab68c28eeb82a6b1200b563" alt=""
「RESTART」をクリックすると、インストールしたノードを適用することができます。
data:image/s3,"s3://crabby-images/ad6fc/ad6fcc3a433fea731d04a39051582e8798eb2b64" alt=""
念の為に右側にある「Refresh」もクリックしてComfyUIを更新してください。
それでも反映されない場合はページを再読み込みしてください。
data:image/s3,"s3://crabby-images/cf7d5/cf7d5d21ad0f57e1a3d563f547a12eefb97ce209" alt=""
これで赤く表示されていた場所に自動でノードが設定されるようになり、エラーがなくなります。
反映されるまで1分くらいかかる場合があります。
data:image/s3,"s3://crabby-images/79184/79184ecb1443ca7c1da5eb22ce5a712345b97518" alt=""
以下の手順に沿って設定してください。
①「UNETLoader(Model B)」の項目内で、「stage_b_bf16.safetensors」を選択する
②「UNETLoader(Model C)」の項目内で、「stage_c_bf16.safetensors」を選択する
③「Load CLIP」の項目内で、「model.safetensors」を選択する
data:image/s3,"s3://crabby-images/78c6c/78c6c80f9c7cc4bd17ec8d07f04a397f34ca7843" alt=""
「Load VAE(Model A)」の項目内で、「stage_a.safetensors」を選択してください。
data:image/s3,"s3://crabby-images/feb07/feb07ab5377f0b8048cb147f35794cea3d4e70df" alt=""
上部にある「CLIP Text Encode(Prompt)」内ではプロンプトになっているので、画像生成したい内容を入力してください。
下部にある「CLIP Text Encode(Prompt)」内ではネガティブプロンプトになっているので、画像生成したくない内容を入力してください。
この例では、プロンプト内にアニメ風の女性で画像生成するように入力しています。
masterpiece , best quality , woman , smile , anime , detailed
data:image/s3,"s3://crabby-images/db18e/db18e0dd64495bc676d77c0d4864a85b9f41e6d5" alt=""
「Queue Prompt」をクリックすることで、Stable Cascadeを使用した画像生成をすることができます。
以下の画像のように、クオリティが高いアニメ風の女性で画像生成することができます。
是非参考にしてStable Cascadeを使用してみてください。
data:image/s3,"s3://crabby-images/0da33/0da3340a5d47fc31f3bf4a98456f255c425e7a6f" alt=""
まとめ
data:image/s3,"s3://crabby-images/aae5a/aae5a92ff20606a7a657efffdfd762e3040070e5" alt=""
ComfyUIでStable Cascadeを使用する方法について解説しました。
・Stable Cascadeを使用するための4つのファイルのダウンロードURLを取得する
・Google Colab内にStable Cascadeを導入するコードを入力する
・ComfyUIでStable Cascadeを使用するためのworkflowをCIVITAIからダウンロードして導入する
是非参考にしてStable Cascadeで画像生成してみてください。