今回はGoogleのクラウドコンピューティングサービス、Google ColabratoryでStable DiffusionのWeb UIであるAUTOMATIC1111を使って画像生成する方法を解説します。
自宅にゲーミングPCなど、高性能なグラフィックボードを搭載したPCを持っていない方でも利用することができます。
2023年4月現在、Google Colabratoryの無料版ではStable Diffusionが使用できなくなりました。無料版で使用した場合、アカウント停止などの措置が取られる可能性がありますのでご注意ください。
(有料版のGoogle Colaboratory Proでは引き続き使用できるようです)
前回のローカル環境同様、Pythonのプログラミングを一切必要とせず画像を生成することができますので、ぜひ活用してみてください。
ローカル環境でAUTOMATIC1111を使用する方法については、以下の記事で解説しています。
data:image/s3,"s3://crabby-images/93893/9389308a47c671bd9837212aee9c62ab95e3caaf" alt=""
また、当ブログ内のStable Diffusionに関する記事を以下のページでまとめていますので、あわせてご覧ください。
data:image/s3,"s3://crabby-images/8013d/8013dd22e4ff320b9efdcdfa2a1d52989792db2a" alt=""
Stable Diffusionとは
Stable Diffusion(ステーブル・ディフュージョン)は2022年8月に無償公開された描画AIです。ユーザーがテキストでキーワードを指定することで、それに応じた画像が自動生成される仕組みとなっています。
NVIDIAのGPUを搭載していれば、ユーザ自身でStable Diffusionをインストールし、ローカル環境で実行することも可能です。
(出典:wikipedia)
data:image/s3,"s3://crabby-images/e9f2c/e9f2cf3b30b44529c60055255d08a4c0ac01e892" alt=""
AUTOMATIC1111
GitHubのAUTOMATIC1111公式リポジトリで、Google Colabで使用するためのcolabノートが公開されています。
AUTOMATIC1111の公式リポジトリは以下となります。
ページにアクセスするとGoogle Colabの項目にリストがあります。
今回は「maintained by Akaibu」を使って構築する方法を解説します。
data:image/s3,"s3://crabby-images/4f6f3/4f6f33f9ec69a628a85915bcd174e73855f3d2a2" alt=""
リンクをクリックして、「StableDiffusionUI-Voldemort V1.3.ipynb」ファイルのコピーを自分のGoogle Driveに保存しておいてください。
data:image/s3,"s3://crabby-images/24996/24996bfceb80b2887b08ce0e07e368e708015a0e" alt=""
data:image/s3,"s3://crabby-images/24996/24996bfceb80b2887b08ce0e07e368e708015a0e" alt=""
学習済みモデルの入手
続いてStable Diffusionで使用するモデルを入手します。
今回はVすき焼きさんが公開されているSukiyakiMixV1を例に解説します。
以下のHugging Faceのページへアクセスします。
data:image/s3,"s3://crabby-images/eebda/eebda10fd44407c2735248b0894841daae0c3daa" alt=""
「Files and versions」のタブをクリックします。
data:image/s3,"s3://crabby-images/bf78e/bf78eca01047f34246afb0aa2a3c65cc73f66a20" alt=""
ファイルの一覧に表示されている「.ckpt」と「.safetensors」という拡張子のファイルがモデルファイルです。
AUTOMATIC1111ではどちらの拡張子も読み込むことができます。
fp16とfp32はモデルサイズが変わりますので、Colabなどストレージとメモリに制約がある環境ではfp16がおすすめです。今回はfp16を選択しました。
data:image/s3,"s3://crabby-images/ac8e7/ac8e7846186c9438cbead631d8de57b4db44301a" alt=""
ファイル名をクリックすると、ダウンロードリンクが表示されますので、クリックしてダウンロードしてください。
data:image/s3,"s3://crabby-images/c4f41/c4f41e47ec0074552c62af8ae2d54311050327dc" alt=""
以上でモデルの入手は完了です。
私が使用しているおすすめのモデルについても以下の記事で紹介していますので、あわせてご覧ください。
data:image/s3,"s3://crabby-images/99dac/99dac05e6eed43007a97568f73c671d08556c18d" alt=""
data:image/s3,"s3://crabby-images/67203/672034b63f43ac05c1f9735333f1524ba9e9c98f" alt=""
学習済みモデルのアップロード
続いて先ほど入手したモデルをGoogle Driveにアップロードします。
今回はマイドライブ/StableDiffusion/modelというディレクトリを作成しました。
data:image/s3,"s3://crabby-images/66de3/66de388fb8b8a097d5d126046b7344e8d0936064" alt=""
作成したディレクトリに移動したら、先ほどダウンロードしたモデルファイルをGoogle Driveのウィンドウにドラッグアンドドロップします。
data:image/s3,"s3://crabby-images/11d99/11d99659cc5d68c7d43e6bfbc699ec65b1de975e" alt=""
しばらく待つとアップロードが完了し、ファイル名が表示されます。
data:image/s3,"s3://crabby-images/5382d/5382df6d2b51f7da6f8f974c584959f559bac66c" alt=""
これでモデルのアップロードは完了です。
data:image/s3,"s3://crabby-images/24996/24996bfceb80b2887b08ce0e07e368e708015a0e" alt=""
Google ColabでPythonファイルを編集する
先ほどGitHubからコピーしたJupyterNotebook用Pythonファイル「StableDiffusionUI-Voldemort V1.3.ipynb」をGoogle Colabで開きます。
Google Driveへの接続
開いたら一番上のセルの中央あたりの枠線にマウスを乗せると「+コード」が表示されるため、それをクリックします。
data:image/s3,"s3://crabby-images/003c5/003c596c4b57a02ba04b3bfa84d7a0988f65b003" alt=""
セルが表示されたら以下のコードを入力してください。
from google.colab import drive
drive.mount('/content/drive')
これで、Google Driveに接続するコードが実装されました。
data:image/s3,"s3://crabby-images/0b540/0b54056cb9bef354d963905d8bfe984f6d2d9292" alt=""
data:image/s3,"s3://crabby-images/67203/672034b63f43ac05c1f9735333f1524ba9e9c98f" alt=""
モデルダウンロード処理の削除
続いて不要なコードをコメントアウトします。
「SD1.5」と書かれたセルの赤枠の部分は、使用するモデルをダウンロードする処理ですが、今回はGoogle Driveから読み込むため不要です。
data:image/s3,"s3://crabby-images/f5855/f5855b6a4ae1c77b25b6ab9b3e9709f9005abf94" alt=""
下から3行のコードを以下のようにコメントアウトしてください。
!git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui
%cd stable-diffusion-webui
#@title SD1.5
# get a token from https://huggingface.co/settings/tokens
#user_token = "" #@param {type:"string"}
#user_header = f"\"Authorization: Bearer {user_token}\""
#!wget --header={user_header} https://huggingface.co/runwayml/stable-diffusion-v1-5/resolve/main/v1-5-pruned.ckpt -O /content/stable-diffusion-webui/model.ckpt
編集後は以下のようになりました。
data:image/s3,"s3://crabby-images/9c01a/9c01abb24e85dfe2268170a1091d99250185e8b9" alt=""
data:image/s3,"s3://crabby-images/dcf33/dcf3356d92366d1716eace47b8ec5e6620f6a26c" alt=""
Google Driveからモデルをコピーする
先ほどGoogle Driveにアップロードしたモデルを、アプリ起動前に読み込む処理を追加します。
SD1.5のセルの下枠の部分にマウスを移動し、「+コード」をクリックします。
data:image/s3,"s3://crabby-images/2cb7a/2cb7ae42db0e63ed57c0e083dc5f84a7dadbbd90" alt=""
追加したセルに以下のコードを追加指定ください。
cpコマンドの引数の1つ目にGoogle Driveのコピーしたいモデルのパスを指定します。2目の引数にはコピー先のディレクトリを指定します。(AUTMATIC1111側でモデルを配置する場所が決まっているので、下のパスをそのままコピーしてください)
モデルを複数使いたい場合は、cpコマンドを複数行追加してください。
!cp /content/drive/MyDrive/StableDiffusion/model/SukiyakiMix-v1.0-fp16.ckpt /content/stable-diffusion-webui/models/Stable-diffusion/
以下のように追加したら完了です。
data:image/s3,"s3://crabby-images/23072/23072c1749542585c9f4b638530af6f3660b6881" alt=""
スクリプトを実行する
最後に作成したスクリプトを実行します。
以下の①~④のすべてのセルの実行ボタン(▶)をクリックして上から順番に実行してください。
data:image/s3,"s3://crabby-images/c996c/c996c9ad787fd186af64714a96d6a8a0d7c8e05b" alt=""
アプリケーションが起動すると以下のようにリンクが表示されます。
「Running on public URL:」と書かれている方をクリックしてUIを起動してください。
data:image/s3,"s3://crabby-images/81565/815659d5cd0e418e39a891a95738b96ff6980456" alt=""
起動に成功すると、以下のようなログイン画面が表示されます。
初期設定では、「ユーザー名:me」、「パスワード:qwerty」となっていますので、入力してログインしてください。
data:image/s3,"s3://crabby-images/9ed47/9ed47d7e35191a2d37137f17bd505e366d1dff5b" alt=""
以下の画面が表示されたら準備完了です。
data:image/s3,"s3://crabby-images/2d214/2d214c70552e059ea3504e8c8fb012a0a496c427" alt=""
data:image/s3,"s3://crabby-images/67203/672034b63f43ac05c1f9735333f1524ba9e9c98f" alt=""
VAE(Auto-Encoder)を変更する
VAE(Variational Autoencoder、変分自己符号化器)は、データの次元圧縮や生成、および特徴抽出に利用される深層学習の手法の一つです。
イラストを生成する際、各モデルごとに推奨されているVAEに変更することで、イラストのクオリティを大幅に向上させることができます。(モデル配布サイトの解説に記載されています)
VAEを変更したい場合は、設定方法を以下の記事で解説しています。
data:image/s3,"s3://crabby-images/92a3d/92a3d5b78d18e8391ed293db14f677ee44bde925" alt=""
Settingsの変更内容を次回から自動で読み込む方法については、以下の記事で解説しています。
data:image/s3,"s3://crabby-images/bcda9/bcda9a692795535da885fc9e8ec12646e5ced010" alt=""
data:image/s3,"s3://crabby-images/dcf33/dcf3356d92366d1716eace47b8ec5e6620f6a26c" alt=""
画像を生成する
AUTOMATIC1111の画面の解説と使い方については以下の記事で解説しています。
(ローカル環境での説明ですが、AUTOMATIC1111の機能自体は同じです)
data:image/s3,"s3://crabby-images/93893/9389308a47c671bd9837212aee9c62ab95e3caaf" alt=""
また、GPT-3を使ってプロンプトを自動生成する方法を以下の記事で解説していますので、あわせてご覧ください。
data:image/s3,"s3://crabby-images/e9f2c/e9f2cf3b30b44529c60055255d08a4c0ac01e892" alt=""
構図やキャラクターのポーズを指定して生成する
これまで解説してきた手順で、プロンプトから画像を生成できるようになりました。しかし、プロンプトだけでは、どのようなポーズのキャラクターが出力されるかはガチャ的な要素であり、かなり試行回数を踏まなければ理想的なイラストは出力できません。
そこで、AUTOMATIC1111の拡張機能でControlNetというツールを使用することで、イラストの構図やキャラクターのポーズを指定して生成できるようになります。
ControlNetを使った生成方法は以下のページで解説しています。
data:image/s3,"s3://crabby-images/91d02/91d02c0feaf84b671d2eed64e12a2328443947b9" alt=""
AUTOMATIC1111の拡張機能として使用できるOpenPose Editorがリリースされ、AUTOMATIC1111のUI内でポーズデータの作成から画像生成までを一貫して実行できるようになりました。
data:image/s3,"s3://crabby-images/59d15/59d15a3786ec0912056486cf70594308241679e2" alt=""
data:image/s3,"s3://crabby-images/67203/672034b63f43ac05c1f9735333f1524ba9e9c98f" alt=""
Stable Diffusionのテクニックを効率よく学ぶには?
data:image/s3,"s3://crabby-images/24832/248321bd1e157cfd3dfb0d0691e0e4d55edfeb5f" alt=""
Stable Diffusionを使ってみたいけど、ネットで調べた情報を試してもうまくいかない…
data:image/s3,"s3://crabby-images/62dcd/62dcdf2cd1ba9818d39cdaa4b172aef5677eae36" alt=""
data:image/s3,"s3://crabby-images/62dcd/62dcdf2cd1ba9818d39cdaa4b172aef5677eae36" alt=""
data:image/s3,"s3://crabby-images/62dcd/62dcdf2cd1ba9818d39cdaa4b172aef5677eae36" alt=""
そんな時は、操作方法の説明が動画で見られるUdemyがおすすめだよ!
動画学習プラットフォームUdemyでは、画像生成AIで高品質なイラストを生成する方法や、AIの内部で使われているアルゴリズムについて学べる講座が用意されています。
Udemyは講座単体で購入できるため安価で(セール時1500円くらいから購入できます)、PCが無くてもスマホでいつでもどこでも手軽に学習できます。
Stable Diffusionに特化して学ぶ
Stable Diffusionに特化し、クラウドコンピューティングサービスPaperspaceでの環境構築方法から、モデルのマージ方法、ControlNetを使った構図のコントロールなど、中級者以上のレベルを目指したい方に最適な講座です。
data:image/s3,"s3://crabby-images/04747/04747d25c9941a56a307354c4eee75c6f365435c" alt="icon"
data:image/s3,"s3://crabby-images/04747/04747d25c9941a56a307354c4eee75c6f365435c" alt="icon"
画像生成AIの仕組みを学ぶ
画像生成AIの仕組みについて学びたい方には、以下の講座がおすすめです。
画像生成AIで使用される変分オートエンコーダやGANのアーキテクチャを理解することで、よりクオリティの高いイラストを生成することができます。
data:image/s3,"s3://crabby-images/c4e95/c4e95bfa1478910ca485e363bb9c5ec4b2ea0dae" alt="icon"
data:image/s3,"s3://crabby-images/c4e95/c4e95bfa1478910ca485e363bb9c5ec4b2ea0dae" alt="icon"
まとめ
今回はGoogle ColabでAUTOMATIC1111を使用する方法について解説しました。ストレージやメモリの制約もありますが、Colabで環境構築しておけば24時間外出さっきからでもAUTOMATIC1111で画像生成をすることができます。
無料プランでも利用できますので、ぜひ活用してみてください。
また、以下の記事で効率的にPythonのプログラミングスキルを学べるプログラミングスクールの選び方について解説しています。最近ではほとんどのスクールがオンラインで授業を受けられるようになり、仕事をしながらでも自宅で自分のペースで学習できるようになりました。
スキルアップや副業にぜひ活用してみてください。
data:image/s3,"s3://crabby-images/2c47c/2c47c2de1c3a1b71c25b13c013e7a704c33cc607" alt=""
data:image/s3,"s3://crabby-images/2c47c/2c47c2de1c3a1b71c25b13c013e7a704c33cc607" alt=""
スクールではなく、自分でPythonを習得したい方には、いつでもどこでも学べる動画学習プラットフォームのUdemyがおすすめです。
講座単位で購入できるため、スクールに比べ非常に安価(セール時1200円程度~)に学ぶことができます。私も受講しているおすすめの講座を以下の記事でまとめていますので、ぜひ参考にしてみてください。
data:image/s3,"s3://crabby-images/ce377/ce3773e0a287b204737603bf1fe760dfa7b25917" alt=""
data:image/s3,"s3://crabby-images/ce377/ce3773e0a287b204737603bf1fe760dfa7b25917" alt=""
それでは、また次の記事でお会いしましょう。
data:image/s3,"s3://crabby-images/24996/24996bfceb80b2887b08ce0e07e368e708015a0e" alt=""
data:image/s3,"s3://crabby-images/24996/24996bfceb80b2887b08ce0e07e368e708015a0e" alt=""
data:image/s3,"s3://crabby-images/24996/24996bfceb80b2887b08ce0e07e368e708015a0e" alt=""
data:image/s3,"s3://crabby-images/24996/24996bfceb80b2887b08ce0e07e368e708015a0e" alt=""
data:image/s3,"s3://crabby-images/24996/24996bfceb80b2887b08ce0e07e368e708015a0e" alt=""
data:image/s3,"s3://crabby-images/24996/24996bfceb80b2887b08ce0e07e368e708015a0e" alt=""
コメント