top of page

SD黄色本 アップデート情報AUTOMATIC1111 起動の不具合解消 第3刷に対応した hotfixを実施しました


ree

2024年3月の発売以来、多くの方にご購読いただいた「画像生成AI Stable Diffusionスタートガイド」(通称 #SD黄色本 )に掲載されていた Google Colabのスクリプトに不具合が発生しておりましたが、修正されました。


読者の方からのご指摘がございました。ありがとうございます。


「画像生成AI Stable Diffusion スタートガイド」を読みながら勉強しているのですが、"セクション2-2 google colabでの環境構築" でつまづいています。46ページ目の④モデルのダウンロードでエラーになります。Google Colab は pro にて有償利用しています。CUも充分残っています。以下にエラー最後の部分を記しておきます。

(エラーメッセージについては文末に記載いたします)


修正作業の背景

AUTOMATIC1111/Stable-Diffusion-WebUIの本家がバージョン1.10.0以降メンテナンスされない中、コミュニティにおいてTheLastBen氏によるメンテナンスが続いています。また新しいモデルとしてFlux.1がサポートされており、WebUIもバージョン1.10.1になっていますが、一方で、protobufと関連ライブラリのバージョン維持が複雑になっています。


作業が長引いた背景として、2024年7月29日のAICUによる長期サポート(LTS)化メンテナンスがありましたが、根が深い問題であり、一旦LTSをロールバックして12月28日にhotfixとして早急な解決をいたしました。



現在は、AUTOMATIC1111 が動作しています。



ree


ree

version: v1.10.1

python: 3.10.12

torch: 2.5.1+cu121

xformers: 0.0.27.post2

gradio: 3.41.2

checkpoint: 1449e5b0b9 (AnimagineXL3.0)

※書籍の説明にあわせてAnimagineXL3.0がデフォルトになっています。


以下が初版初出からの主要なアップデートとなります。


現在のhotfixは原作のTheLastBenさんの 2024年11月21日版 Commit a12b351をベースにしており、AUTOMATIC1111-v1.10.1というバージョンが動いています。過去のLTS化はいったん外した状態になっています。今後、xformers: 0.0.27.post2のGoogle Colabでのサポート状況を確認しつつ、さらなる恒久化・安定化・LTS化を実施していきたいと考えています。



書籍の方は第3刷においてこれまでの修正が反映されています。

出版社のサポートサイトもご参照いただけますと幸いです。



新しい年も、「SD黄色本」をよろしくお願いいたします。


著者:AICU media、白井 暁彦


付録:レポートされておりましたエラーを以下に掲載します


Traceback (most recent call last):

File "/usr/local/lib/python3.10/dist-packages/transformers/utils/import_utils.py", line 1146, in _get_module

return importlib.import_module("." + module_name, self.name)

File "/usr/lib/python3.10/importlib/init.py", line 126, in import_module

return _bootstrap._gcd_import(name[level:], package, level)

File "", line 1050, in _gcd_import

File "", line 1027, in _find_and_load

File "", line 1006, in _find_and_load_unlocked

File "", line 688, in _load_unlocked

File "", line 883, in exec_module

File "", line 241, in _call_with_frames_removed

File "/usr/local/lib/python3.10/dist-packages/transformers/modeling_utils.py", line 83, in

from accelerate import version as accelerate_version

File "/usr/local/lib/python3.10/dist-packages/accelerate/init.py", line 7, in

from .accelerator import Accelerator

File "/usr/local/lib/python3.10/dist-packages/accelerate/accelerator.py", line 33, in

from .tracking import LOGGER_TYPE_TO_CLASS, GeneralTracker, filter_trackers

File "/usr/local/lib/python3.10/dist-packages/accelerate/tracking.py", line 29, in

from torch.utils import tensorboard

File "/usr/local/lib/python3.10/dist-packages/torch/utils/tensorboard/init.py", line 12, in

from .writer import FileWriter, SummaryWriter # noqa: F401

File "/usr/local/lib/python3.10/dist-packages/torch/utils/tensorboard/writer.py", line 13, in

from tensorboard.compat.proto import event_pb2

File "/usr/local/lib/python3.10/dist-packages/tensorboard/compat/proto/event_pb2.py", line 17, in

from tensorboard.compat.proto import summary_pb2 as tensorboard_dot_compat_dot_proto_dot_summary__pb2

File "/usr/local/lib/python3.10/dist-packages/tensorboard/compat/proto/summary_pb2.py", line 17, in

from tensorboard.compat.proto import tensor_pb2 as tensorboard_dot_compat_dot_proto_dot_tensor__pb2

File "/usr/local/lib/python3.10/dist-packages/tensorboard/compat/proto/tensor_pb2.py", line 16, in

from tensorboard.compat.proto import resource_handle_pb2 as tensorboard_dot_compat_dot_proto_dot_resource__handle__pb2

File "/usr/local/lib/python3.10/dist-packages/tensorboard/compat/proto/resource_handle_pb2.py", line 16, in

from tensorboard.compat.proto import tensor_shape_pb2 as tensorboard_dot_compat_dot_proto_dot_tensor__shape__pb2

File "/usr/local/lib/python3.10/dist-packages/tensorboard/compat/proto/tensor_shape_pb2.py", line 36, in

_descriptor.FieldDescriptor(

File "/usr/local/lib/python3.10/dist-packages/google/protobuf/descriptor.py", line 553, in new

_message.Message._CheckCalledFromGeneratedFile()

TypeError: Descriptors cannot be created directly.

If this call came from a _pb2.py file, your generated code is out of date and must be regenerated with protoc >= 3.19.0.

If you cannot immediately regenerate your protos, some other possible workarounds are:Downgrade the protobuf package to 3.20.x or lower.

Set PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION=python (but this will use pure-Python parsing and will be much slower).




The above exception was the direct cause of the following exception:


Traceback (most recent call last):

File "/content/gdrive/MyDrive/sd/stable-diffusion-webui/webui.py", line 13, in

initialize.imports()

File "/content/gdrive/MyDrive/sd/stable-diffusion-webui/modules/initialize.py", line 17, in imports

import pytorch_lightning # noqa: F401

File "/usr/local/lib/python3.10/dist-packages/pytorch_lightning/init.py", line 34, in

from pytorch_lightning.callbacks import Callback # noqa: E402

File "/usr/local/lib/python3.10/dist-packages/pytorch_lightning/callbacks/init.py", line 14, in

from pytorch_lightning.callbacks.callback import Callback

File "/usr/local/lib/python3.10/dist-packages/pytorch_lightning/callbacks/callback.py", line 25, in

from pytorch_lightning.utilities.types import STEP_OUTPUT

File "/usr/local/lib/python3.10/dist-packages/pytorch_lightning/utilities/types.py", line 28, in

from torchmetrics import Metric

File "/usr/local/lib/python3.10/dist-packages/torchmetrics/init.py", line 14, in

from torchmetrics import functional # noqa: E402

File "/usr/local/lib/python3.10/dist-packages/torchmetrics/functional/init.py", line 77, in

from torchmetrics.functional.text.bleu import bleu_score

File "/usr/local/lib/python3.10/dist-packages/torchmetrics/functional/text/init.py", line 30, in

from torchmetrics.functional.text.bert import bert_score # noqa: F401

File "/usr/local/lib/python3.10/dist-packages/torchmetrics/functional/text/bert.py", line 24, in

from torchmetrics.functional.text.helper_embedding_metric import (

File "/usr/local/lib/python3.10/dist-packages/torchmetrics/functional/text/helper_embedding_metric.py", line 26, in

from transformers import AutoModelForMaskedLM, AutoTokenizer, PreTrainedModel, PreTrainedTokenizerBase

File "", line 1075, in _handle_fromlist

File "/usr/local/lib/python3.10/dist-packages/transformers/utils/import_utils.py", line 1136, in getattr

module = self._get_module(self._class_to_module[name])

File "/usr/local/lib/python3.10/dist-packages/transformers/utils/import_utils.py", line 1148, in _get_module

raise RuntimeError(

RuntimeError: Failed to import transformers.modeling_utils because of the following error (look up to see its traceback):

Descriptors cannot be created directly.

If this call came from a _pb2.py file, your generated code is out of date and must be regenerated with protoc >= 3.19.0.

If you cannot immediately regenerate your protos, some other possible workarounds are:Downgrade the protobuf package to 3.20.x or lower.

Set PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION=python (but this will use pure-Python parsing and will be much slower).




Originally published at note.com/aicu on Dec 31, 2024.

コメント


bottom of page