「Google ColabでComfyUIの導入方法が分からない…」と困っていませんか?
Google Colabを使用するときはコードを記載する必要があり
どうやって記載するとComfyUIを導入できるのか分からないですよね。
この記事では
Google ColabでComfyUIを導入するためのコードを記載しているので
コピペするだけで導入することができます。
是非記事を参考にしてComfyUIを利用してみてください。
ComfyUIを導入する方法
data:image/s3,"s3://crabby-images/fb1f3/fb1f322b84ccbbe1e449c16dd16debb111e758f2" alt=""
Google Colabにアクセスしてください。
「ファイル」をクリックしてから
「ノートブックを新規作成」をクリックしてください。
data:image/s3,"s3://crabby-images/1960f/1960f951916fdaa7a457a91dd1927415dbfd2576" alt=""
「編集」をクリックしてから
「ノートブックの設定」をクリックしてください。
data:image/s3,"s3://crabby-images/a8550/a855062b4b88934c6587e7ff77d2b41533e25ee4" alt=""
「ハードウェア アクセラレータ」の項目で
「T4 GPU」を選択してから
「保存」をクリックしてください。
data:image/s3,"s3://crabby-images/71531/71531e4f4fa08df20bfc2a29fc2ace6107f863f3" alt=""
この例では、コード内に「ComfyUI」と「Checkpointモデル」と「VAE」を導入するコードを追加します。
data:image/s3,"s3://crabby-images/e4a2c/e4a2c07b4daaeca072632107d27a2ec9dbb66d36" alt=""
今回の例では、CivitAIのサイトから「AnyLoRA」のCheckpointモデルを導入します。
data:image/s3,"s3://crabby-images/8e00e/8e00ee36b73987c1801661c7ec2270aec41beff3" alt=""
「VAE」は、「LittleStepMix」のCheckpointモデルサイト内に付属されている「kl-f8anime2」を導入します。
data:image/s3,"s3://crabby-images/86fe1/86fe1661a52d382065fd7efe0489d7ab133dfdda" alt=""
以下のコードでは、「ComfyUI」「AnyLoRA」「kl-f8anime2」を導入するコードが記載されているので、コード内にコピペしてから実行ボタンをクリックしてください。
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)
#AnyLora
!aria2c --console-log-level=error -c -x 16 -s 16 -k 1M https://civitai.com/api/download/models/95489 -d /content/ComfyUI/models/checkpoints -o AnyLora.safetensors
#kl-f8-anime2
!aria2c --console-log-level=error -c -x 16 -s 16 -k 1M https://huggingface.co/sazyou-roukaku/LittleStepMix/resolve/main/VAE/sr_SDv2vae_kl-f8anime2.safetensors -d /content/ComfyUI/models/vae -o sr_SDv2vae_kl-f8anime2.safetensors
!python main.py --dont-print-server
data:image/s3,"s3://crabby-images/d4ca1/d4ca145b2fb5a8bfb5f9876be8a018a3e23ffd57" alt=""
別のCheckpointモデルを導入したい方は、例として以下のように修正してください。
導入するCheckpointモデルのダウンロードURLを、以下にある(ダウンロードURL)の部分を削除してからペーストしてください。
赤字になっている「AnyLora」の部分ではモデルの名前になっているので、削除してから導入するモデルの名前に変更してください。
!aria2c –console-log-level=error -c -x 16 -s 16 -k 1M (ダウンロードURL) -d /content/ComfyUI/models/checkpoints -o AnyLora.safetensors
コードを実行してから数十分後くらいに
以下の画像のようにURLが表示されるのでクリックすることで「ComfyUI」を使用することができます。
data:image/s3,"s3://crabby-images/53dae/53dae25d0c55c6ac0ea716ec20612fd7757564fd" alt=""
ComfyUIの使い方
data:image/s3,"s3://crabby-images/76ebf/76ebfd2f429ea174f21921955b2584d1ea027cae" alt=""
ComfyUIを起動したら、以下のzipファイルをダウンロードして解凍してください。
「AnyLora_workflow.json」形式のファイルを
ComfyUI内の何もない場所にドラッグ&ドロップしてください。
data:image/s3,"s3://crabby-images/95fa0/95fa0c7e0833007553d3fedd18557339a1968ccc" alt=""
「Load Checkpoint」項目内にある「ckpt_name」をクリックしてから
「AnyLora」が設定されているか確認してください。
別のCheckpointモデルを導入した方は、そのモデルに変更してください。
data:image/s3,"s3://crabby-images/1f83b/1f83b37f6e6de5561b5a21698319647c816570af" alt=""
「Queue Prompt」をクリックすることで画像生成することが出来ます。
data:image/s3,"s3://crabby-images/274cf/274cf3da0cf6834fb4c1037f6a682f9e1d8fcad6" alt=""
画像生成した作品内で、右クリックしてから「Save Image」をクリックすると、画像を保存することが出来ます。
data:image/s3,"s3://crabby-images/544b2/544b27dfb70297554bc870eca6611d60e83d898a" alt=""
「See History」をクリックしてください。
data:image/s3,"s3://crabby-images/91706/917069c57ca56a979270fe7c18aa643350de8409" alt=""
「History」項目では、「Load」をクリックすることで
過去に画像生成した時のパラメータ情報に戻すので、過去に画像生成した作品を確認したり
パラメータ情報を再度利用したりすることが出来ます。
data:image/s3,"s3://crabby-images/4a83f/4a83fcd069463982f04e72683e43a9776db58c59" alt=""
「CLIP Text Encode(Prompt)」項目では、「CONDITIONING」から「positive」にコードが繋がっていた場合は、プロンプトの入力場所になっています。
プロンプト内には、画像生成したい内容を入力してください。
data:image/s3,"s3://crabby-images/88841/8884184ed94ad607b16ff76a3441ede0f4b46185" alt=""
その下にある「CLIP Text Encode(Prompt)」項目では
「CONDITIONING」から「negative」にコードが繋がっているので
画像生成したくない内容を入力してください。
data:image/s3,"s3://crabby-images/19589/19589203eb5c320f951594eb82f4d1b039520c93" alt=""
「Empty Latent Image」項目では、画像サイズを設定することが出来ます。
「batch_size」では、一度に連続生成する枚数を変更することが出来ます。
data:image/s3,"s3://crabby-images/1f844/1f844374bf86e61d5f18e793f64f4c8468828551" alt=""
以下の画像のように、「batch_size」では3枚の設定にすると、1枚ずつ分割して3枚画像生成されます。
data:image/s3,"s3://crabby-images/080e3/080e3c8827e70372f5420a20ef2a96729fb63532" alt=""
1度に連続生成する枚数を変更することが出来るもう1つの方法として
「Extra options」にチェックを入れてから
「Batch count」の数値を変更する方法があります。
data:image/s3,"s3://crabby-images/b8166/b8166bdcc5b56d88854a9469a09fd0969dd8c1b5" alt=""
「Batch count」を「3」にして生成した場合は
1枚画像生成されたらそのまますぐに別の画像生成が始まります。
data:image/s3,"s3://crabby-images/fc345/fc34501e6aec7699292558e6ac173ef1fea603ab" alt=""
「KSampler」では、「steps」を変更したり「sampler_name」でサンプラーを変更したり出来ます。
data:image/s3,"s3://crabby-images/5de9e/5de9e87026e51fec72eb96336fe090ea01bd4389" alt=""
「Save Intermediate Image」では
「Hires Fix」前に「Empty Latent Image」項目で設定した画像サイズで生成しています。
data:image/s3,"s3://crabby-images/9c07b/9c07bb6470b359da9efcbbd6afe1c13584bfe094" alt=""
「Hires Fix」では、高画質化・高解像にさせることが出来ます。
data:image/s3,"s3://crabby-images/2f63a/2f63acbfa0f7802473dd8dc8c24dd12e744e22cb" alt=""
「Load VAE」では、導入したVAEを設定する項目になっています。
この例では、コード内で導入していた「kl-f8anime2」が設定されています。
data:image/s3,"s3://crabby-images/5f67d/5f67d1a6c429a137b7d1b0fba5e341abb9ac12cf" alt=""
「LoRA」モデルや「Embedding」などを設定したい場合は
以下のリンクにあるComfyUIのExamplesを参考にして導入するといいでしょう。
例として、LoRAの設定方法を参考にしたい場合は「Lora」をクリックしてください。
data:image/s3,"s3://crabby-images/261a3/261a32fb10e184fb6bec330945d5290566ebf49b" alt=""
「Lora Examples」内のページに画像が表示されているので
画像をComfyUI内にドラッグ&ドロップすると設定することが出来ます。
data:image/s3,"s3://crabby-images/3f42b/3f42b70c5731e964e32b78d4607a4935b67c251a" alt=""
まとめ
data:image/s3,"s3://crabby-images/3a818/3a81893c5aaf5fad8783d67a64debbda4c41a92b" alt=""
Google ColabでComfyUIの導入方法について解説しました。
ComfyUIでは、Stable Diffusion Web UIよりも少し複雑な構造なので上級者向けかなと感じます。
Stable Diffusion Web UIよりも早く画像生成できるので
上手く使いこなせるようになるとこちらの方がいいと思います。
是非参考にしてComfyUIを導入してみてください。