- general:
- new loading screens and artwork
- extra networks: add add/remove tags to prompt (e.g. lora activation keywords)
- extensions: fix couple of compatibility items
- firefox compatibility improvements
- original
- fix hires secondary sampler
this now fully obsoletesfallback_sampler
andforce_latent_sampler
- fix hires secondary sampler
- diffusers:
- implement img2img and inpainting (experimental)
actual support and qualiy depends on model
it works as expected for sd 1.5, but not so much for sd-xl for now - add option to save image before refiner pass
- option to set vae upcast in settings
- enable fp16 vae decode when using optimized vae
this pretty much doubles performance of decode step (delay after generate is done) - sd-xl: loading vae now applies to both base and refiner and saves a bit of vram
- vae: enable loading of pure-safetensors vae files without config
also enable automatic selection to work with diffusers
- implement img2img and inpainting (experimental)
- diffusers: future-proof
requiresdiffusers==0.19.dev
, not yet released, but can be installed manually- sd-xl: denoising_start/denoising_end
- sd-xl: enable dual prompts
dual prompt is used if set regardless if refiner is enabled/loaded
if refiner is loaded & enabled, refiner prompt will also be used for refiner pass- primary prompt goes to OpenAI CLIP-ViT/L-14
- refiner prompt goes to OpenCLIP-ViT/bigG-14
While we're waiting for official SD-XL release, here's another update with some fixes and enhancements...
- global
- image save: option to add invisible image watermark to all your generated images
disabled by default, can be enabled in settings -> image options
watermark information will be shown when loading image such as in process image tab
also additional cli utility/cli/image-watermark.py
to read/write/strip watermarks from images - batch processing: fix metadata saving, also allow to drag&drop images for batch processing
- ui configuration: you can modify all ui default values from settings as usual,
but only values that are non-default will be written toui-config.json
- startup: add cmd flag to skip all
torch
checks - startup: force requirements check on each server start
there are too many misbehaving extensions that change system requirements - internal: safe handling of all config file read/write operations
this allows sdnext to run in fully shared environments and prevents any possible configuration corruptions
- image save: option to add invisible image watermark to all your generated images
- diffusers:
- sd-xl: remove image watermarks autocreated by 0.9 model
- vae: enable loading of external vae, documented in diffusers wiki
and mix&match continues, you can even use sd-xl vae with sd 1.5 models! - samplers: add concept of default sampler to avoid needing to tweak settings for primary or second pass
note that sampler details will be printed in log when running in debug level - samplers: allow overriding of sampler beta values in settings
- refiner: fix refiner applying only to first image in batch
- refiner: allow using direct latents or processed output in refiner
- model: basic support for one more model: UniDiffuser
download using model downloader:thu-ml/unidiffuser-v1
and set resolution to 512x512
Trying to unify settings for both original and diffusers backend without introducing duplicates...
- renamed hires fix to second pass
as that is what it actually is, name hires fix is misleading to start with - actual hires fix and refiner are now options inside second pass section
- obsoleted settings -> sampler -> force_latent_sampler
it is now part of second pass options and it works the same for both original and diffusers backend
which means you can use different scheduler settings for txt2img and hires if you want - sd-xl refiner will run if its loaded and if second pass is enabled
so you can quickly enable/disable refiner by simply enabling/disabling second pass - you can mix&match model and refiner
for example, you can generate image using sd 1.5 and still use sd-xl refiner as second pass - reorganized settings -> samplers to show which section refers to which backend
- added diffusers lmsd sampler
Another big one, but now improvements to both diffusers and original backends as well plus ability to dynamically switch between them!
- swich backend between diffusers and original on-the-fly
- you can still use
--backend <backend>
and now that only means in which mode app will start, but you can change it anytime in ui settings - for example, you can even do things like generate image using sd-xl,
then switch to original backend and perform inpaint using a different model
- you can still use
- diffusers backend:
- separate ui settings for refiner pass with sd-xl
you can specify: prompt, negative prompt, steps, denoise start - fix loading from pure safetensors files
now you can load sd-xl from safetensors file or from huggingface folder format - fix kandinsky model (2.1 working, 2.2 was just released and will be soon)
- separate ui settings for refiner pass with sd-xl
- original backend:
- improvements to vae/unet handling as well as cross-optimization heads
in non-technical terms, this means lower memory usage and higher performance
and you should be able to generate higher resolution images without any other changes
- improvements to vae/unet handling as well as cross-optimization heads
- other:
- major refactoring of the javascript code
includes fixes for text selections and navigation - system info tab now reports on nvidia driver version as well
- minor fixes in extra-networks
- installer handles origin changes for submodules
- major refactoring of the javascript code
big thanks to @huggingface team for great communication, support and fixing all the reported issues asap!
Service release with some fixes and enhancements:
- diffusers:
- option to move base and/or refiner model to cpu to free up vram
- model downloader options to specify model variant / revision / mirror
- now you can download
fp16
variant directly for reduced memory footprint - basic img2img workflow (sketch and inpaint are not supported yet)
note that sd-xl img2img workflows are architecturaly different so it will take longer to implement - updated hints for settings
- extra networks:
- fix corrupt display on refesh when new extra network type found
- additional ui tweaks
- generate thumbnails from previews only if preview resolution is above 1k
- image viewer:
- fixes for non-chromium browsers and mobile users and add option to download image
- option to download image directly from image viewer
- general
- fix startup issue with incorrect config
- installer should always check requirements on upgrades
This is a massive update which has been baking in a dev
branch for a while now
- merge experimental diffusers support
TL;DR: Yes, you can run SD-XL model in SD.Next now
For details, see Wiki page: Diffusers
Note this is still experimental, so please follow Wiki
Additional enhancements and fixes will be provided over the next few days
Thanks to @huggingface team for making this possible and our internal @team for all the early testing
Release also contains number of smaller updates:
- add pan & zoom controls (touch and mouse) to image viewer (lightbox)
- cache extra networks between tabs
this should result in neat 2x speedup on building extra networks - add settings -> extra networks -> do not automatically build extra network pages
speeds up app start if you have a lot of extra networks and you want to build them manually when needed - extra network ui tweaks
Small quality-of-life updates and bugfixes:
- add option to disallow usage of ckpt checkpoints
- change lora and lyco dir without server restart
- additional filename template fields:
uuid
,seq
,image_hash
- image toolbar is now shown only when image is present
- image
Zip
button gone and its not optional setting that applies to standardSave
button - folder
Show
button is present only when working on localhost,
otherwise its replaced withCopy
that places image URLs on clipboard so they can be used in other apps
A bit bigger update this time, but contained to specific areas...
- change in behavior
extensions no longer auto-update on startup
using--upgrade
flag upgrades core app as well as all submodules and extensions - live server log monitoring in ui
configurable via settings -> live preview - new extra networks interface
note: if you're using a 3rd party ui extension for extra networks, it will likely need to be updated to work with new interface- display in front of main ui, inline with main ui or as a sidebar
- lazy load thumbnails
drastically reduces load times for large number of extra networks - auto-create thumbnails from preview images in extra networks in a background thread
significant load time saving on subsequent restarts - support for info files in addition to description files
- support for variable aspect-ratio thumbnails
- new folder view
- extensions sort by trending
- add requirements check for training
- new training tab interface
- redesigned preprocess, train embedding, train hypernetwork
- new models tab interface
- new model convert functionality, thanks @akegarasu
- new model verify functionality
- lot of ipex specific fixes/optimizations, thanks @disty0
This one is less relevant for standard users, but pretty major if you're running an actual server
But even if not, it still includes bunch of cumulative fixes since last release - and going by number of new issues, this is probably the most stable release so far...
(next one is not going to be as stable, but it will be fun :) )
- minor improvements to extra networks ui
- more hints/tooltips integrated into ui
- new decidated api server
- but highly promising for high throughput server
- improve server logging and monitoring with
- server log file rotation
- ring buffer with api endpoint
/sdapi/v1/log
- real-time status and load endpoint
/sdapi/v1/system-info/status
Second stage of a jumbo merge from upstream plus few minor changes...
- simplify token merging
- reorganize some settings
- all updates from upstream: A1111 v1.3.2 [df004be] (latest release)
pretty much nothing major that i haven't released in previous versions, but its still a long list of tiny changes- skipped/did-not-port:
add separate hires prompt: unnecessarily complicated and spread over large number of commits due to many regressions
allow external scripts to add cross-optimization methods: dangerous and i don't see a use case for it so far
load extension info in threads: unnecessary as other optimizations ive already put place perform equally good - broken/reverted:
sub-quadratic optimization changes
- skipped/did-not-port:
Just a day later and one bigger update... Both some new functionality as well as massive merges from upstream
- new cache for models/lora/lyco metadata:
metadata.json
drastically reduces disk access on app startup - allow saving/resetting of ui default values
settings -> ui defaults - ability to run server without loaded model
default is to auto-load model on startup, can be changed in settings -> stable diffusion
if disabled, model will be loaded on first request, e.g. when you click generate
useful when you want to start server to perform other tasks like upscaling which do not rely on model - updated
accelerate
andxformers
- huge nubmer of changes ported from A1111 upstream
this was a massive merge, hopefully this does not cause any regressions
and still a bit more pending...
- updated ui labels and hints to improve clarity and provide some extra info
this is 1st stage of the process, more to come...
if you want to join the effort, see vladmandic#1246 - new localization and hints engine
how hints are displayed can be selected in settings -> ui - reworked installer sequence
as some extensions are loading packages directly from their preload sequence
which was preventing some optimizations to take effect - updated settings tab functionality, thanks @gegell
with real-time monitor for all new and/or updated settings - launcher will now warn if application owned files are modified
you are free to add any user files, but do not modify app files unless you're sure in what you're doing - add more profiling for scripts/extensions so you can see what takes time
this applies both to initial load as well as execution - experimental
sd_model_dict
setting which allows you to load model dictionary
from one model and apply weights from another model specified insd_model_checkpoint
results? who am i to judge :)
Few new features and extra handling for broken extensions
that caused my phone to go crazy with notifications over the weekend...
- added extra networks to xyz grid options
now you can have more fun with all your embeddings and loras :) - new vae decode method to help with larger batch sizes, thanks @bigdog
- new setting -> lora -> use lycoris to handle all lora types
this is still experimental, but the goal is to obsolete old built-in lora module
as it doesn't understand many new loras and built-in lyco module can handle it all - somewhat optimize browser page loading
still slower than i'd want, but gradio is pretty bad at this - profiling of scripts/extensions callbacks
you can now see how much or pre/post processing is done, not just how long generate takes - additional exception handling so bad exception does not crash main app
- additional background removal models
- some work on bfloat16 which nobody really should be using, but why not 🙂
Some quality-of-life improvements while working on larger stuff in the background...
- redesign action box to be uniform accross all themes
- add pause option next to stop/skip
- redesigned progress bar
- add new built-in extension: agent-scheduler
very elegant way to getting full queing capabilies, thank @artventurdev - enable more image formats
note: not all are understood by browser so previews and images may appear as blank
unless you have some browser extensions that can handle them
but they are saved correctly. and cant beat raw quality of 32-bittiff
orpsd
:) - change in behavior:
xformers
will be uninstalled on startup if they are not active
if you do havexformers
selected as your desired cross-optimization method, then they will be used
reason is that a lot of libaries try to blindy import xformers even if they are not selected or not functional
Another bigger one...And more to come in the next few days...
- new live preview mode: taesd
i really like this one, so its enabled as default for new installs - settings search feature
- new sampler: dpm++ 2m sde
- fully common save/zip/delete (new) options in all tabs
which (again) meant rework of process image tab - system info tab: live gpu utilization/memory graphs for nvidia gpus
- updated controlnet interface
- minor style changes
- updated lora, swinir, scunet and ldsr code from upstream
- start of merge from a1111 v1.3
Some quality-of-life improvements...
- updated README
- created CHANGELOG
this will be the source for all info about new things moving forward
and cross-posted to Discussions#99 as well as discord announcements - optimize model loading on startup
this should reduce startup time significantly - set default cross-optimization method for each platform backend
applicable for new installs onlycuda
=> Scaled-Dot-Productrocm
=> Sub-quadraticdirectml
=> Sub-quadraticipex
=> InvokeAI'smps
=> Doggettx'scpu
=> Doggettx's
- optimize logging
- optimize profiling
now includes startup profiling as well ascuda
profiling during generate - minor lightbox improvements
- bugfixes...i don't recall when was a release with at least several of those
other than that - first stage of Diffusers integration is now in master branch
i don't recommend anyone to try it (and dont even think reporting issues for it)
but if anyone wants to contribute, take a look at project page
Major internal work with perhaps not that much user-facing to show for it ;)
- update core repos: stability-ai, taming-transformers, k-diffusion, blip, codeformer
note: to avoid disruptions, this is applicable for new installs only - tested with torch 2.1, cuda 12.1, cudnn 8.9
(production remains on torch2.0.1+cuda11.8+cudnn8.8) - fully extend support of
--data-dir
allows multiple installations to share pretty much everything, not just models
especially useful if you want to run in a stateless container or cloud instance - redo api authentication
now api authentication will use same user/pwd (if specified) for ui and strictly enforce it using httpbasicauth
new authentication is also fully supported in combination with ssl for both sync and async calls
if you want to use api programatically, see examples incli/sdapi.py
- add dark/light theme mode toggle
- redo some
clip-skip
functionality - better matching for vae vs model
- update to
xyz grid
to allow creation of large number of images without creating grid itself - update
gradio
(again) - more prompt parser optimizations
- better error handling when importing image settings which are not compatible with current install
for example, when upscaler or sampler originally used is not available - fixes...amazing how many issues were introduced by porting a1111 v1.20 code without adding almost no new functionality
next one is v1.30 (still in dev) which does bring a lot of new features
This is a massive one due to huge number of changes,
but hopefully it will go ok...
- new prompt parsers
select in UI -> Settings -> Stable Diffusion- Full: my new implementation
- A1111: for backward compatibility
- Compel: as used in ComfyUI and InvokeAI (a.k.a Temporal Weighting)
- Fixed: for really old backward compatibility
- monitor extensions install/startup and
log if they modify any packages/requirements
this is a deep-experimental python hack, but i think its worth it as extensions modifying requirements
is one of most common causes of issues - added
--safe
command line flag mode which skips loading user extensions
please try to use it before opening new issue - reintroduce
--api-only
mode to start server without ui - port all upstream changes from A1111
up to today - commit hash89f9faa
- major work on prompt parsing
this can cause some differences in results compared to what you're used to, but its all about fixes & improvements
- prompt parser was adding commas and spaces as separate words and tokens and/or prefixes
- negative prompt weight using
[word:weight]
was ignored, it was always0.909
- bracket matching was anything but correct. complex nested attention brackets are now working.
- btw, if you run with
--debug
flag, you'll now actually see parsed prompt & schedule
- updated all scripts in
/cli
- add option in settings to force different latent sampler instead of using primary only
- add interrupt/skip capabilities to process images
This is mostly about optimizations...
- improved
torch-directml
support
especially interesting for amd users on windows where torch+rocm is not yet available
dont forget to run using--use-directml
or default is cpu - improved compatibility with nvidia rtx 1xxx/2xxx series gpus
- fully working
torch.compile
with torch 2.0.1
usinginductor
compile takes a while on first run, but does result in 5-10% performance increase - improved memory handling
for highest performance, you can also disable aggressive gc in settings - improved performance
especially after generate as image handling has been moved to separate thread - allow per-extension updates in extension manager
- option to reset configuration in settings
- brand new extension manager
this is pretty much a complete rewrite, so new issues are possible - support for
torch
2.0.1
note that if you are experiencing frequent hangs, this may be a worth a try - updated
gradio
to 3.29.0 - added
--reinstall
flag to force reinstall of all packages - auto-recover & re-attempt when
--upgrade
is requested but fails - check for duplicate extensions
Back online with few updates:
- bugfixes. yup, quite a lot of those
- auto-detect some cpu/gpu capabilities on startup
this should reduce need to tweak and tune settings like no-half, no-half-vae, fp16 vs fp32, etc - configurable order of top level tabs
- configurable order of scripts in txt2img and img2img
for both, see sections in ui-> settings -> user interface
Again, few days later...
- reviewed/ported all commits from A1111 upstream
some a few are not applicable as i already have alternative implementations
and very few i choose not to implement (save/restore last-known-good-config is a bad hack)
otherwise, we're fully up to date (its doesn't show on fork status as code merges were mostly manual due to conflicts)
but...due to sheer size of the updates, this may introduce some temporary issues - redesigned server restart function
now available and working in ui
actually, since server restart is now a true restart and not ui restart, it can be used much more flexibly - faster model load
plus support for slower devices via stream-load function (in ui settings) - better logging
this includes new--debug
flag for more verbose logging when troubleshooting
Been a bit quieter for last few days as changes were quite significant, but finally here we are...
- Updated core libraries: Gradio, Diffusers, Transformers
- Added support for Intel ARC GPUs via Intel OneAPI IPEX (auto-detected)
- Added support for TorchML (set by default when running on non-compatible GPU or on CPU)
- Enhanced support for AMD GPUs with ROCm
- Enhanced support for Apple M1/M2
- Redesigned command params: run
webui --help
for details - Redesigned API and script processing
- Experimental support for multiple Torch compile options
- Improved sampler support
- Google Colab: https://colab.research.google.com/drive/126cDNwHfifCyUpCCQF9IHpEdiXRfHrLN
Maintained by https://github.com/Linaqruf/sd-notebook-collection - Fixes, fixes, fixes...
To take advantage of new out-of-the-box tunings, its recommended to delete your config.json
so new defaults are applied. Its not necessary, but otherwise you may need to play with UI Settings to get the best of Intel ARC, TorchML, ROCm or Apple M1/M2.
a bit shorter list as:
- i've been busy with buxfixing
there are a lot of them, not going to list each here.
but seems like critical issues backlog is quieting down and soon i can focus on new features development. - i've started collaboration with couple of major projects, hopefully this will accelerate future development.
what's new:
- ability to view/add/edit model description shown in extra networks cards
- add option to specify fallback sampler if primary sampler is not compatible with desired operation
- make clip skip a local parameter
- remove obsolete items from UI settings
- set defaults for AMD ROCm
if you have issues, you may want to start with a fresh install so configuration can be created from scratch - set defaults for Apple M1/M2
if you have issues, you may want to start with a fresh install so configuration can be created from scratch
- update process image -> info
- add VAE info to metadata
- update GPU utility search paths for better GPU type detection
- update git flags for wider compatibility
- update environment tuning
- update ti training defaults
- update VAE search paths
- add compatibility opts for some old extensions
- validate script args for always-on scripts
fixes: deforum with controlnet
- identify race condition where generate locks up while fetching preview
- add pulldowns to x/y/z script
- add VAE rollback feature in case of NaNs
- use samples format for live preview
- add token merging
- use Approx NN for live preview
- create default
styles.csv
- fix setup not installing
tensorflow
dependencies - update default git flags to reduce number of warnings
- fix VAE dtype
should fix most issues with NaN or black images - add built-in Gradio themes
- reduce requirements
- more AMD specific work
- initial work on Apple platform support
- additional PR merges
- handle torch cuda crashing in setup
- fix setup race conditions
- fix ui lightbox
- mark tensorflow as optional
- add additional image name templates
- autodetect which system libs should be installed
this is a first pass of autoconfig for nVidia vs AMD environments - fix parse cmd line args from extensions
- only install
xformers
if actually selected as desired cross-attention method - do not attempt to use
xformers
orsdp
if running on cpu - merge tomesd token merging
- merge 23 PRs pending from a1111 backlog (!!)
expect shorter updates for the next few days as i'll be partically ooo
- full CUDA tuning section in UI Settings
- improve exif/pnginfo metadata parsing
it can now handle 3rd party images or images edited in external software - optimized setup performance and logging
- improve compatibility with some 3rd party extensions for example handle extensions that install packages directly from github urls
- fix initial model download if no models found
- fix vae not found issues
- fix multiple git issues
note: if you previously had command line optimizations such as --no-half, those are now ignored and moved to ui settings
- fix live preview
- fix model merge
- fix handling of user-defined temp folders
- fix submit benchmark
- option to override
torch
andxformers
installer - separate benchmark data for system-info extension
- minor css fixes
- created initial merge backlog from pending prs on a1111 repo
see #258 for details
- reconnect ui to active session on browser restart
this is one of most frequently asked for items, finally figured it out
works for text and image generation, but not for process as there is no progress bar reported there to start with - force unload
xformers
when not used
improves compatibility with AMD/M1 platforms - add
styles.csv
to UI settings to allow customizing path - add
--skip-git
to cmd flags for power users that want
to skip all git checks and operations and perform manual updates - add
--disable-queue
to cmd flags that disables Gradio queues (experimental) this forces it to use HTTP instead of WebSockets and can help on unreliable network connections - set scripts & extensions loading priority and allow custom priorities
fixes random extension issues:
ScuNet
upscaler dissapearing,Additional Networks
not showing up on XYZ axis, etc. - improve html loading order
- remove some
asserts
causing runtime errors and replace with user-friendly messages - update README.md
- update TODO.md
- themes are now dynamic and discovered from list of available gradio themes on huggingface
its quite a list of 30+ supported themes so far - added option to see theme preview without the need to apply it or restart server
- integrated image info functionality into process image tab and removed separate image info tab
- more installer improvements
- fix urls
- updated github integration
- make model download as optional if no models found
- support for ui themes! to to settings -> user interface -> "ui theme* includes 12 predefined themes
- ability to restart server from ui
- updated requirements
- removed
styles.csv
from repo, its now fully under user control - removed model-keyword extension as overly aggresive
- rewrite of the fastapi middleware handlers
- install bugfixes, hopefully new installer is now ok
i really want to focus on features and not troubleshooting installer
- update default values
- remove
ui-config.json
from repo, its not fully under user control - updated extensions mangager
- updated locon/lycoris plugin
- enable quick launch by default
- add multidiffusion upscaler extensions
- add model keyword extension
- enable strong linting
- fix circular imports
- fix extensions updated
- fix git update issues
- update github templates
- handle duplicate extensions
- redo exception handler
- fix generate forever
- enable cmdflags compatibility
- change default css font
- fix ti previews on initial start
- enhance tracebacks
- pin transformers version to last known good version
- fix extension loader
This has been pending for a while, but finally uploaded some massive changes
- New launcher
webui.bat
andwebui.sh
:
Platform specific wrapper scripts that startslaunch.py
in Python virtual environment
Note: Server can run without virtual environment, but it is recommended to use it
This is carry-over from original repo
If you're unsure which launcher to use, this is the one you wantlaunch.py
:
Main startup script
Can be used directly to start server in manually activatedvenv
or to run it withoutvenv
installer.py
:
Main installer, used bylaunch.py
webui.py
:
Main server script
- New logger
- New exception handler
- Built-in performance profiler
- New requirements handling
- Move of most of command line flags into UI Settings