Kohya-ss-sd-scripts/docs/sdxl_train_network.md

20 KiB
Raw Permalink Blame History

How to Use the SDXL LoRA Training Script sdxl_train_network.py / SDXL LoRA学習スクリプト sdxl_train_network.py の使い方

This document explains the basic procedure for training a LoRA (Low-Rank Adaptation) model for SDXL (Stable Diffusion XL) using sdxl_train_network.py included in the sd-scripts repository.

日本語 このドキュメントでは、`sd-scripts` リポジトリに含まれる `sdxl_train_network.py` を使用して、SDXL (Stable Diffusion XL) モデルに対する LoRA (Low-Rank Adaptation) モデルを学習する基本的な手順について解説します。

1. Introduction / はじめに

sdxl_train_network.py is a script for training additional networks such as LoRA for SDXL models. The basic usage is common with train_network.py (see How to Use the LoRA Training Script train_network.py), but SDXL model-specific settings are required.

This guide focuses on SDXL LoRA training, explaining the main differences from train_network.py and SDXL-specific configuration items.

Prerequisites:

日本語 `sdxl_train_network.py` は、SDXL モデルに対して LoRA などの追加ネットワークを学習させるためのスクリプトです。基本的な使い方は `train_network.py` ([LoRA学習スクリプト `train_network.py` の使い方](train_network.md) 参照) と共通ですが、SDXL モデル特有の設定が必要となります。

このガイドでは、SDXL LoRA 学習に焦点を当て、train_network.py との主な違いや SDXL 特有の設定項目を中心に説明します。

前提条件:

2. Preparation / 準備

Before starting training, you need the following files:

  1. Training Script: sdxl_train_network.py
  2. Dataset Definition File (.toml): A TOML format file describing the training dataset configuration.

About the Dataset Definition File

The basic format of the dataset definition file (.toml) is the same as for train_network.py. Please refer to the Dataset Configuration Guide and How to Use the LoRA Training Script train_network.py.

For SDXL, it is common to use high-resolution datasets and the aspect ratio bucketing feature (enable_bucket = true).

In this example, we'll use a file named my_sdxl_dataset_config.toml.

日本語 学習を開始する前に、以下のファイルが必要です。
  1. 学習スクリプト: sdxl_train_network.py
  2. データセット定義ファイル (.toml): 学習データセットの設定を記述した TOML 形式のファイル。

データセット定義ファイルについて

データセット定義ファイル (.toml) の基本的な書き方は train_network.py と共通です。データセット設定ガイド および LoRA学習スクリプト train_network.py の使い方 を参照してください。

SDXL では、高解像度のデータセットや、アスペクト比バケツ機能 (enable_bucket = true) の利用が一般的です。

ここでは、例として my_sdxl_dataset_config.toml という名前のファイルを使用することにします。

3. Running the Training / 学習の実行

Training starts by running sdxl_train_network.py from the terminal.

Here's a basic command line execution example for SDXL LoRA training:

accelerate launch --num_cpu_threads_per_process 1 sdxl_train_network.py 
 --pretrained_model_name_or_path="<SDXL base model path>" 
 --dataset_config="my_sdxl_dataset_config.toml" 
 --output_dir="<output directory for training results>" 
 --output_name="my_sdxl_lora" 
 --save_model_as=safetensors 
 --network_module=networks.lora 
 --network_dim=32 
 --network_alpha=16 
 --learning_rate=1e-4 
 --unet_lr=1e-4 
 --text_encoder_lr1=1e-5 
 --text_encoder_lr2=1e-5 
 --optimizer_type="AdamW8bit" 
 --lr_scheduler="constant" 
 --max_train_epochs=10 
 --save_every_n_epochs=1 
 --mixed_precision="bf16" 
 --gradient_checkpointing 
 --cache_text_encoder_outputs 
 --cache_latents

Comparing with the execution example of train_network.py, the following points are different:

  • The script to execute is sdxl_train_network.py.
  • You specify an SDXL base model for --pretrained_model_name_or_path.
  • --text_encoder_lr is split into --text_encoder_lr1 and --text_encoder_lr2 (since SDXL has two Text Encoders).
  • --mixed_precision is recommended to be bf16 or fp16.
  • --cache_text_encoder_outputs and --cache_latents are recommended to reduce VRAM usage.

Next, we'll explain the main command line arguments that differ from train_network.py. For common arguments, please refer to How to Use the LoRA Training Script train_network.py.

日本語 学習は、ターミナルから `sdxl_train_network.py` を実行することで開始します。

以下に、SDXL LoRA 学習における基本的なコマンドライン実行例を示します。

accelerate launch --num_cpu_threads_per_process 1 sdxl_train_network.py 
 --pretrained_model_name_or_path="<SDXLベースモデルのパス>" 
 --dataset_config="my_sdxl_dataset_config.toml" 
 --output_dir="<学習結果の出力先ディレクトリ>" 
 --output_name="my_sdxl_lora" 
 --save_model_as=safetensors 
 --network_module=networks.lora 
 --network_dim=32 
 --network_alpha=16 
 --learning_rate=1e-4 
 --unet_lr=1e-4 
 --text_encoder_lr1=1e-5 
 --text_encoder_lr2=1e-5 
 --optimizer_type="AdamW8bit" 
 --lr_scheduler="constant" 
 --max_train_epochs=10 
 --save_every_n_epochs=1 
 --mixed_precision="bf16" 
 --gradient_checkpointing 
 --cache_text_encoder_outputs 
 --cache_latents

train_network.py の実行例と比較すると、以下の点が異なります。

  • 実行するスクリプトが sdxl_train_network.py になります。
  • --pretrained_model_name_or_path には SDXL のベースモデルを指定します。
  • --text_encoder_lr--text_encoder_lr1--text_encoder_lr2 に分かれていますSDXL は2つの Text Encoder を持つため)。
  • --mixed_precisionbf16 または fp16 が推奨されます。
  • --cache_text_encoder_outputs--cache_latents は VRAM 使用量を削減するために推奨されます。

次に、train_network.py との差分となる主要なコマンドライン引数について解説します。共通の引数については、LoRA学習スクリプト train_network.py の使い方 を参照してください。

3.1. Main Command Line Arguments (Differences) / 主要なコマンドライン引数(差分)

  • --pretrained_model_name_or_path="<model path>" [Required]
    • Specifies the SDXL model to be used as the base for training. You can specify a Hugging Face Hub model ID (e.g., "stabilityai/stable-diffusion-xl-base-1.0"), a local Diffusers format model directory, or a path to a .safetensors file.
  • --v2, --v_parameterization
    • These arguments are for SD1.x/2.x. When using sdxl_train_network.py, since an SDXL model is assumed, these typically do not need to be specified.
  • --dataset_config="<config file path>"
    • This is common with train_network.py.
    • For SDXL, it is common to use high-resolution data and the bucketing feature (specify enable_bucket = true in the .toml file).
  • These are common with train_network.py.

LoRA Parameters / LoRA パラメータ

  • These are common with train_network.py.

Training Parameters / 学習パラメータ

  • --learning_rate=1e-4
    • Overall learning rate. This becomes the default value if unet_lr, text_encoder_lr1, and text_encoder_lr2 are not specified.
  • --unet_lr=1e-4
    • Learning rate for LoRA modules in the U-Net part. If not specified, the value of --learning_rate is used.
  • --text_encoder_lr1=1e-5
    • Learning rate for LoRA modules in Text Encoder 1 (OpenCLIP ViT-G/14). If not specified, the value of --learning_rate is used. A smaller value than U-Net is recommended.
  • --text_encoder_lr2=1e-5
    • Learning rate for LoRA modules in Text Encoder 2 (CLIP ViT-L/14). If not specified, the value of --learning_rate is used. A smaller value than U-Net is recommended.
  • --optimizer_type="AdamW8bit"
    • Common with train_network.py.
  • --lr_scheduler="constant"
    • Common with train_network.py.
  • --lr_warmup_steps
    • Common with train_network.py.
  • --max_train_steps, --max_train_epochs
    • Common with train_network.py.
  • --mixed_precision="bf16"
    • Mixed precision training setting. For SDXL, bf16 or fp16 is recommended. Choose the one supported by your GPU. This reduces VRAM usage and improves training speed.
  • --gradient_accumulation_steps=1
    • Common with train_network.py.
  • --gradient_checkpointing
    • Common with train_network.py. Recommended to enable for SDXL due to its high memory consumption.
  • --cache_latents
    • Caches VAE outputs in memory (or on disk when --cache_latents_to_disk is specified). By skipping VAE computation, this reduces VRAM usage and speeds up training. Image augmentations (--color_aug, --flip_aug, --random_crop, etc.) are disabled. This option is recommended for SDXL training.
  • --cache_latents_to_disk
    • Used with --cache_latents, caches to disk. When loading the dataset for the first time, VAE outputs are cached to disk. This is recommended when you have a large number of training images, as it allows you to skip VAE computation on subsequent training runs.
  • --cache_text_encoder_outputs
    • Caches Text Encoder outputs in memory (or on disk when --cache_text_encoder_outputs_to_disk is specified). By skipping Text Encoder computation, this reduces VRAM usage and speeds up training. Caption augmentations (--shuffle_caption, --caption_dropout_rate, etc.) are disabled.
    • Note: When using this option, LoRA modules for Text Encoder cannot be trained (--network_train_unet_only must be specified).
  • --cache_text_encoder_outputs_to_disk
    • Used with --cache_text_encoder_outputs, caches to disk.
  • --no_half_vae
    • Runs VAE in float32 even when using mixed precision (fp16/bf16). Since SDXL's VAE can be unstable in float16, enable this when using fp16.
  • --clip_skip
    • Not normally used for SDXL. No need to specify.
  • --fused_backward_pass
    • Fuses gradient computation and optimizer steps to reduce VRAM usage. Available for SDXL. (Currently only supports the Adafactor optimizer)

Others / その他

  • --seed, --logging_dir, --log_prefix, etc. are common with train_network.py.
日本語 #### モデル関連
  • --pretrained_model_name_or_path="<モデルのパス>" [必須]
    • 学習のベースとなる SDXL モデルを指定します。Hugging Face Hub のモデル ID (例: "stabilityai/stable-diffusion-xl-base-1.0") や、ローカルの Diffusers 形式モデルのディレクトリ、.safetensors ファイルのパスを指定できます。
  • --v2, --v_parameterization
    • これらの引数は SD1.x/2.x 用です。sdxl_train_network.py を使用する場合、SDXL モデルであることが前提となるため、通常は指定する必要はありません

データセット関連

  • --dataset_config="<設定ファイルのパス>"
    • train_network.py と共通です。
    • SDXL では高解像度データやバケツ機能 (.tomlenable_bucket = true を指定) の利用が一般的です。

出力・保存関連

  • train_network.py と共通です。

LoRA パラメータ

  • train_network.py と共通です。

学習パラメータ

  • --learning_rate=1e-4
    • 全体の学習率。unet_lr, text_encoder_lr1, text_encoder_lr2 が指定されない場合のデフォルト値となります。
  • --unet_lr=1e-4
    • U-Net 部分の LoRA モジュールに対する学習率。指定しない場合は --learning_rate の値が使用されます。
  • --text_encoder_lr1=1e-5
    • Text Encoder 1 (OpenCLIP ViT-G/14) の LoRA モジュールに対する学習率。指定しない場合は --learning_rate の値が使用されます。U-Net より小さめの値が推奨されます。
  • --text_encoder_lr2=1e-5
    • Text Encoder 2 (CLIP ViT-L/14) の LoRA モジュールに対する学習率。指定しない場合は --learning_rate の値が使用されます。U-Net より小さめの値が推奨されます。
  • --optimizer_type="AdamW8bit"
    • train_network.py と共通です。
  • --lr_scheduler="constant"
    • train_network.py と共通です。
  • --lr_warmup_steps
    • train_network.py と共通です。
  • --max_train_steps, --max_train_epochs
    • train_network.py と共通です。
  • --mixed_precision="bf16"
    • 混合精度学習の設定。SDXL では bf16 または fp16 の使用が推奨されます。GPU が対応している方を選択してください。VRAM 使用量を削減し、学習速度を向上させます。
  • --gradient_accumulation_steps=1
    • train_network.py と共通です。
  • --gradient_checkpointing
    • train_network.py と共通です。SDXL はメモリ消費が大きいため、有効にすることが推奨されます。
  • --cache_latents
    • VAE の出力をメモリ(または --cache_latents_to_disk 指定時はディスクにキャッシュします。VAE の計算を省略できるため、VRAM 使用量を削減し、学習を高速化できます。画像に対する Augmentation (--color_aug, --flip_aug, --random_crop 等) が無効になります。SDXL 学習では推奨されるオプションです。
  • --cache_latents_to_disk
    • --cache_latents と併用し、キャッシュ先をディスクにします。データセットを最初に読み込む際に、VAE の出力をディスクにキャッシュします。二回目以降の学習で VAE の計算を省略できるため、学習データの枚数が多い場合に推奨されます。
  • --cache_text_encoder_outputs
    • Text Encoder の出力をメモリ(または --cache_text_encoder_outputs_to_disk 指定時はディスクにキャッシュします。Text Encoder の計算を省略できるため、VRAM 使用量を削減し、学習を高速化できます。キャプションに対する Augmentation (--shuffle_caption, --caption_dropout_rate 等) が無効になります。
    • 注意: このオプションを使用する場合、Text Encoder の LoRA モジュールは学習できません (--network_train_unet_only の指定が必須です)。
  • --cache_text_encoder_outputs_to_disk
    • --cache_text_encoder_outputs と併用し、キャッシュ先をディスクにします。
  • --no_half_vae
    • 混合精度 (fp16/bf16) 使用時でも VAE を float32 で動作させます。SDXL の VAE は float16 で不安定になることがあるため、fp16 指定時には有効にしてください。
  • --clip_skip
    • SDXL では通常使用しません。指定は不要です。
  • --fused_backward_pass
    • 勾配計算とオプティマイザのステップを融合し、VRAM使用量を削減します。SDXLで利用可能です。現在 Adafactor オプティマイザのみ対応)

その他

  • --seed, --logging_dir, --log_prefix などは train_network.py と共通です。

3.2. Starting the Training / 学習の開始

After setting the necessary arguments, execute the command to start training. The training progress will be displayed on the console. The basic flow is the same as with train_network.py.

日本語 必要な引数を設定し、コマンドを実行すると学習が開始されます。学習の進行状況はコンソールに出力されます。基本的な流れは `train_network.py` と同じです。

4. Using the Trained Model / 学習済みモデルの利用

When training is complete, a LoRA model file (.safetensors, etc.) with the name specified by output_name will be saved in the directory specified by output_dir.

This file can be used with GUI tools that support SDXL, such as AUTOMATIC1111/stable-diffusion-webui and ComfyUI.

日本語 学習が完了すると、`output_dir` で指定したディレクトリに、`output_name` で指定した名前の LoRA モデルファイル (`.safetensors` など) が保存されます。

このファイルは、AUTOMATIC1111/stable-diffusion-webui 、ComfyUI などの SDXL に対応した GUI ツールで利用できます。

5. Supplement: Main Differences from train_network.py / 補足: train_network.py との主な違い

  • Target Model: sdxl_train_network.py is exclusively for SDXL models.
  • Text Encoder: Since SDXL has two Text Encoders, there are differences in learning rate specifications (--text_encoder_lr1, --text_encoder_lr2), etc.
  • Caching Features: --cache_text_encoder_outputs is particularly effective for SDXL and is recommended.
  • Recommended Settings: Due to high VRAM usage, mixed precision (bf16 or fp16), gradient_checkpointing, and caching features (--cache_latents, --cache_text_encoder_outputs) are recommended. When using fp16, it is recommended to run the VAE in float32 with --no_half_vae.

For other detailed options, please refer to the script's help (python sdxl_train_network.py --help) and other documents in the repository.

日本語 * **対象モデル:** `sdxl_train_network.py` は SDXL モデル専用です。 * **Text Encoder:** SDXL は 2 つの Text Encoder を持つため、学習率の指定 (`--text_encoder_lr1`, `--text_encoder_lr2`) などが異なります。 * **キャッシュ機能:** `--cache_text_encoder_outputs` は SDXL で特に効果が高く、推奨されます。 * **推奨設定:** VRAM 使用量が大きいため、`bf16` または `fp16` の混合精度、`gradient_checkpointing`、キャッシュ機能 (`--cache_latents`, `--cache_text_encoder_outputs`) の利用が推奨されます。`fp16` 指定時は、VAE は `--no_half_vae` で `float32` 動作を推奨します。

その他の詳細なオプションについては、スクリプトのヘルプ (python sdxl_train_network.py --help) やリポジトリ内の他のドキュメントを参照してください。