Home
Softono
b

bghira

Professional software vendor delivering innovative solutions on the Softono platform. Specialized in both open-source and proprietary software development.

Total Products
1

Software by bghira

SimpleTuner
Open Source

SimpleTuner

# SimpleTuner πŸ’Ή > ℹ️ No data is sent to any third parties except through opt-in flag `report_to`, `push_to_hub`, or webhooks which must be manually configured. **SimpleTuner** is geared towards simplicity, with a focus on making the code easily understood. This codebase serves as a shared academic exercise, and contributions are welcome. If you'd like to join our community, we can be found [on Discord](https://discord.gg/JGkSwEbjRb) via Terminus Research Group. If you have any questions, please feel free to reach out to us there. <img width="1944" height="1657" alt="image" src="https://github.com/user-attachments/assets/af3a24ec-7347-4ddf-8edf-99818a246de1" /> ## Table of Contents - [Design Philosophy](#design-philosophy) - [Tutorial](#tutorial) - [Features](#features) - [Core Training Features](#core-training-features) - [Model Architecture Support](#model-architecture-support) - [Advanced Training Techniques](#advanced-training-techniques) - [Model-Specific Features](#model-specific-features) - [Quickstart Guides](#quickstart-guides) - [Hardware Requirements](#hardware-requirements) - [Toolkit](#toolkit) - [Setup](#setup) - [Troubleshooting](#troubleshooting) ## Design Philosophy - **Simplicity**: Aiming to have good default settings for most use cases, so less tinkering is required. - **Versatility**: Designed to handle a wide range of image quantities - from small datasets to extensive collections. - **Cutting-Edge Features**: Only incorporates features that have proven efficacy, avoiding the addition of untested options. ## Tutorial Please fully explore this README before embarking on the [new web UI tutorial](/documentation/webui/TUTORIAL.md) or [the class command-line tutorial](/documentation/TUTORIAL.md), as this document contains vital information that you might need to know first. For a manually configured quick start without reading the full documentation or using any web interfaces, you can use the [Quick Start](/documentation/QUICKSTART.md) guide. For memory-constrained systems, see the [DeepSpeed document](/documentation/DEEPSPEED.md) which explains how to use πŸ€—Accelerate to configure Microsoft's DeepSpeed for optimiser state offload. For DTensor-based sharding and context parallelism, read the [FSDP2 guide](/documentation/FSDP2.md) which covers the new FullyShardedDataParallel v2 workflow inside SimpleTuner. For multi-node distributed training, [this guide](/documentation/DISTRIBUTED.md) will help tweak the configurations from the INSTALL and Quickstart guides to be suitable for multi-node training, and optimising for image datasets numbering in the billions of samples. --- ## Features SimpleTuner provides comprehensive training support across multiple diffusion model architectures with consistent feature availability: ### Core Training Features - **User-friendly web UI** - Manage your entire training lifecycle through a sleek dashboard - **Multi-modal training** - Unified pipeline for **Image, Video, and Audio** generative models - **Multi-GPU training** - Distributed training across multiple GPUs with automatic optimization - **Advanced caching** - Image, video, audio, and caption embeddings cached to disk for faster training - **CaptionFlow integration** - Generate dataset captions from local GPUs through the Web UI job queue using [bghira/CaptionFlow](https://github.com/bghira/CaptionFlow); see the [CaptionFlow integration guide](/documentation/CAPTIONFLOW.md) - **Aspect bucketing** - Support for varied image/video sizes and aspect ratios - **Concept sliders** - Slider-friendly targeting for LoRA/LyCORIS/full (via LyCORIS `full`) with positive/negative/neutral sampling and per-prompt strength; see [Slider LoRA guide](/documentation/SLIDER_LORA.md) - **Memory optimization** - Most models trainable on 24G GPU, many on 16G with optimizations - **DeepSpeed & FSDP2 integration** - Train large models on smaller GPUs with optim/grad/parameter sharding, context parallel attention, gradient checkpointing, and optimizer state offload - **S3 training** - Train directly from cloud storage (Cloudflare R2, Wasabi S3) - **EMA support** - Exponential moving average weights for improved stability and quality - **Custom experiment trackers** - Drop an `accelerate.GeneralTracker` into `simpletuner/custom-trackers` and use `--report_to=custom-tracker --custom_tracker=<name>` ### Multi-User & Enterprise Features SimpleTuner includes a complete multi-user training platform with enterprise-grade featuresβ€”**free and open source, forever**. - **Worker Orchestration** - Register distributed GPU workers that auto-connect to a central panel and receive job dispatch via SSE; supports ephemeral (cloud-launched) and persistent (always-on) workers; see [Worker Orchestration Guide](/documentation/experimental/server/WORKERS.md) - **SSO Integration** - Authenticate with LDAP/Active Directory or OIDC providers (Okta, Azure AD, Keycloak, Google); see [External Auth Guide](/documentation/experimental/server/EXTERNAL_AUTH.md) - **Role-Based Access Control** - Four default roles (Viewer, Researcher, Lead, Admin) with 17+ granular permissions; define resource rules with glob patterns to restrict configs, hardware, or providers per team - **Organizations & Teams** - Hierarchical multi-tenant structure with ceiling-based quotas; org limits enforce absolute maximums, team limits operate within org bounds - **Quotas & Spending Limits** - Enforce cost ceilings (daily/monthly), job concurrency limits, and submission rate limits at org, team, or user scope; actions include block, warn, or require approval - **Job Queue with Priorities** - Five priority levels (Low β†’ Critical) with fair-share scheduling across teams, starvation prevention for long-waiting jobs, and admin priority overrides - **Approval Workflows** - Configurable rules trigger approval for jobs exceeding cost thresholds, first-time users, or specific hardware requests; approve via UI, API, or email reply - **Email Notifications** - SMTP/IMAP integration for job status, approval requests, quota warnings, and completion alerts - **API Keys & Scoped Permissions** - Generate API keys with expiration and limited scope for CI/CD pipelines - **Audit Logging** - Track all user actions with chain verification for compliance; see [Audit Guide](/documentation/experimental/server/AUDIT.md) For deployment details, see the [Enterprise Guide](/documentation/experimental/server/ENTERPRISE.md). ### Model Architecture Support | Model | Parameters | PEFT LoRA | Lycoris | Full-Rank | ControlNet | Quantization | Flow Matching | Text Encoders | |-------|------------|-----------|---------|-----------|------------|--------------|---------------|---------------| | **Stable Diffusion XL** | 3.5B | βœ“ | βœ“ | βœ“ | βœ“ | int8/nf4 | βœ— | CLIP-L/G | | **Stable Diffusion 3** | 2B-8B | βœ“ | βœ“ | βœ“* | βœ“ | int8/fp8/nf4 | βœ“ | CLIP-L/G + T5-XXL | | **Flux.1** | 12B | βœ“ | βœ“ | βœ“* | βœ“ | int8/fp8/nf4 | βœ“ | CLIP-L + T5-XXL | | **Flux.2** | 32B | βœ“ | βœ“ | βœ“* | βœ— | int8/fp8/nf4 | βœ“ | Mistral-3 Small | | **Ideogram 4** | 9B | βœ“ | βœ“ | βœ“* | βœ— | fp8/nf4 | βœ“ | Qwen3-VL | | **ACE-Step** | 3.5B | βœ“ | βœ“ | βœ“* | βœ— | int8 | βœ“ | UMT5 | | **HeartMuLa** | 3B | βœ“ | βœ“ | βœ“* | βœ— | int8 | βœ— | None | | **Chroma 1** | 8.9B | βœ“ | βœ“ | βœ“* | βœ— | int8/fp8/nf4 | βœ“ | T5-XXL | | **Auraflow** | 6.8B | βœ“ | βœ“ | βœ“* | βœ“ | int8/fp8/nf4 | βœ“ | UMT5-XXL | | **PixArt Sigma** | 0.6B-0.9B | βœ— | βœ“ | βœ“ | βœ“ | int8 | βœ— | T5-XXL | | **Sana** | 0.6B-4.8B | βœ— | βœ“ | βœ“ | βœ— | int8 | βœ“ | Gemma2-2B | | **Lumina2** | 2B | βœ“ | βœ“ | βœ“ | βœ— | int8 | βœ“ | Gemma2 | | **Kwai Kolors** | 5B | βœ“ | βœ“ | βœ“ | βœ— | βœ— | βœ— | ChatGLM-6B | | **LTX Video** | 5B | βœ“ | βœ“ | βœ“ | βœ— | int8/fp8 | βœ“ | T5-XXL | | **LTX Video 2** | 19B | βœ“ | βœ“ | βœ“* | βœ— | int8/fp8 | βœ“ | Gemma3 | | **Wan Video** | 1.3B-14B | βœ“ | βœ“ | βœ“* | βœ— | int8 | βœ“ | UMT5 | | **HiDream** | 17B (8.5B MoE) | βœ“ | βœ“ | βœ“* | βœ“ | int8/fp8/nf4 | βœ“ | CLIP-L + T5-XXL + Llama | | **Cosmos2** | 2B-14B | βœ— | βœ“ | βœ“ | βœ— | int8 | βœ“ | T5-XXL | | **OmniGen** | 3.8B | βœ“ | βœ“ | βœ“ | βœ— | int8/fp8 | βœ“ | T5-XXL | | **Qwen Image** | 20B | βœ“ | βœ“ | βœ“* | βœ— | int8/nf4 (req.) | βœ“ | T5-XXL | | **SD 1.x/2.x (Legacy)** | 0.9B | βœ“ | βœ“ | βœ“ | βœ“ | int8/nf4 | βœ— | CLIP-L | *βœ“ = Supported, βœ— = Not supported, * = Requires DeepSpeed for full-rank training* ### Advanced Training Techniques - **TREAD** - Token-wise dropout for transformer models, including Kontext training - **Masked loss training** - Superior convergence with segmentation/depth guidance - **Prior regularization** - Enhanced training stability for character consistency - **Gradient checkpointing** - Configurable intervals for memory/speed optimization - **Loss functions** - L2, Huber, Smooth L1 with scheduling support - **SNR weighting** - Min-SNR gamma weighting for improved training dynamics - **Group offloading** - Diffusers v0.33+ module-group CPU/disk staging with optional CUDA streams - **Validation adapter sweeps** - Temporarily attach LoRA adapters (single or JSON presets) during validation to measure adapter-only or comparison renders without touching the training loop - **External validation hooks** - Swap the built-in validation pipeline or post-upload steps for your own scripts, so you can run checks on another GPU or forward artifacts to any cloud provider of your choice ([details](/documentation/OPTIONS.md#validation_method)) - **AnyFlow distillation** - FlowMap interval conditioning for flow-matching models with online teacher targets ([guide](/documentation/experimental/ANYFLOW.md)) - **CREPA regularization** - Cross-frame representation alignment for video DiTs ([guide](/documentation/experimental/VIDEO_CREPA.md)) - **LoRA I/O formats** - Load/save PEFT LoRAs in standard Diffusers layout or ComfyUI-style `diffusion_model.*` keys (Flux/Flux2/Lumina2/Z-Image auto-detect ComfyUI inputs) ### Model-Specific Features - **Flux Kontext** - Edit conditioning and image-to-image training for Flux models - **PixArt two-stage** - eDiff training pipeline support for PixArt Sigma - **Flow matching models** - Advanced scheduling with beta/uniform distributions - **HiDream MoE** - Mixture of Experts gate loss augmentation - **T5 masked training** - Enhanced fine details for Flux and compatible models - **QKV fusion** - Memory and speed optimizations (Flux, Lumina2) - **TREAD integration** - Selective token routing for most models - **Wan 2.x I2V** - High/low stage presets plus a 2.1 time-embedding fallback (see Wan quickstart) - **Classifier-free guidance** - Optional CFG reintroduction for distilled models ### Quickstart Guides Detailed quickstart guides are available for all supported models: - **[TwinFlow Few-Step (RCGM) Guide](/documentation/distillation/TWINFLOW.md)** - Enable RCGM auxiliary loss for few-step/one-step generation (flow models or diffusion via diff2flow) - **[Flux.1 Guide](/documentation/quickstart/FLUX.md)** - Includes Kontext editing support and QKV fusion - **[Flux.2 Guide](/documentation/quickstart/FLUX2.md)** - **NEW!** Latest enormous Flux model with Mistral-3 text encoder - **[Z-Image Guide](/documentation/quickstart/ZIMAGE.md)** - Base/Turbo LoRA with assistant adapter + TREAD acceleration - **[Ideogram 4 Guide](/documentation/quickstart/IDEOGRAM4.md)** - **NEW!** FP8-first LoRA training with structured JSON captions - **[ACE-Step Guide](/documentation/quickstart/ACE_STEP.md)** - **NEW!** Audio generation model training (text-to-music) - **[HeartMuLa Guide](/documentation/quickstart/HEARTMULA.md)** - **NEW!** Autoregressive audio generation model training (text-to-audio) - **[Chroma Guide](/documentation/quickstart/CHROMA.md)** - Lodestone's flow-matching transformer with Chroma-specific schedules - **[Stable Diffusion 3 Guide](/documentation/quickstart/SD3.md)** - Full and LoRA training with ControlNet - **[Stable Diffusion XL Guide](/documentation/quickstart/SDXL.md)** - Complete SDXL training pipeline - **[Auraflow Guide](/documentation/quickstart/AURAFLOW.md)** - Flow-matching model training - **[PixArt Sigma Guide](/documentation/quickstart/SIGMA.md)** - DiT model with two-stage support - **[Sana Guide](/documentation/quickstart/SANA.md)** - Lightweight flow-matching model - **[Lumina2 Guide](/documentation/quickstart/LUMINA2.md)** - 2B parameter flow-matching model - **[Kwai Kolors Guide](/documentation/quickstart/KOLORS.md)** - SDXL-based with ChatGLM encoder - **[LongCat-Video Guide](/documentation/quickstart/LONGCAT_VIDEO.md)** - Flow-matching text-to-video and image-to-video with Qwen-2.5-VL - **[LongCat-Video Edit Guide](/documentation/quickstart/LONGCAT_VIDEO_EDIT.md)** - Conditioning-first flavour (image-to-video) - **[LongCat-Image Guide](/documentation/quickstart/LONGCAT_IMAGE.md)** - 6B bilingual flow-matching model with Qwen-2.5-VL encoder - **[LongCat-Image Edit Guide](/documentation/quickstart/LONGCAT_EDIT.md)** - Image editing flavour requiring reference latents - **[LTX Video Guide](/documentation/quickstart/LTXVIDEO.md)** - Video diffusion training - **[Hunyuan Video 1.5 Guide](/documentation/quickstart/HUNYUANVIDEO.md)** - 8.3B flow-matching T2V/I2V with SR stages - **[Wan Video Guide](/documentation/quickstart/WAN.md)** - Video flow-matching with TREAD support - **[HiDream Guide](/documentation/quickstart/HIDREAM.md)** - MoE model with advanced features - **[Cosmos2 Guide](/documentation/quickstart/COSMOS2IMAGE.md)** - Multi-modal image generation - **[OmniGen Guide](/documentation/quickstart/OMNIGEN.md)** - Unified image generation model - **[Qwen Image Guide](/documentation/quickstart/QWEN_IMAGE.md)** - 20B parameter large-scale training - **[Stable Cascade Stage C Guide](/quickstart/STABLE_CASCADE_C.md)** - Prior LoRAs with combined prior+decoder validation - **[Kandinsky 5.0 Image Guide](/documentation/quickstart/KANDINSKY5_IMAGE.md)** - Image generation with Qwen2.5-VL + Flux VAE - **[Kandinsky 5.0 Video Guide](/documentation/quickstart/KANDINSKY5_VIDEO.md)** - Video generation with HunyuanVideo VAE --- ## Hardware Requirements ### General Requirements - **NVIDIA**: RTX 3080+ recommended (tested up to H200) - **AMD**: 7900 XTX 24GB and MI300X verified (higher memory usage vs NVIDIA) - **Apple**: M3 Max+ with 24GB+ unified memory for LoRA training ### Memory Guidelines by Model Size - **Large models (12B+)**: A100-80G for full-rank, 24G+ for LoRA/Lycoris - **Medium models (2B-8B)**: 16G+ for LoRA, 40G+ for full-rank training - **Small models (<2B)**: 12G+ sufficient for most training types **Note**: Quantization (int8/fp8/nf4) significantly reduces memory requirements. See individual [quickstart guides](#quickstart-guides) for model-specific requirements. ## Setup SimpleTuner can be installed via pip for most users: ```bash # Base installation (CPU-only PyTorch) pip install simpletuner # CUDA users (NVIDIA GPUs) pip install 'simpletuner[cuda]' # CUDA 13 / Blackwell users (NVIDIA B-series GPUs) pip install 'simpletuner[cuda13]' --extra-index-url https://download.pytorch.org/whl/cu130 # ROCm users (AMD GPUs) pip install 'simpletuner[rocm]' --extra-index-url https://download.pytorch.org/whl/rocm7.1 # Apple Silicon users (M1/M2/M3/M4 Macs) pip install 'simpletuner[apple]' ``` For manual installation or development setup, see the [installation documentation](/documentation/INSTALL.md). ## Troubleshooting Enable debug logs for a more detailed insight by adding `export SIMPLETUNER_LOG_LEVEL=DEBUG` to your environment (`config/config.env`) file. For performance analysis of the training loop, setting `SIMPLETUNER_TRAINING_LOOP_LOG_LEVEL=DEBUG` will have timestamps that highlight any issues in your configuration. For a comprehensive list of options available, consult [this documentation](/documentation/OPTIONS.md).

AI & Machine Learning ML Frameworks
2.9K Github Stars