2021-12-21 02:23:41 +00:00
|
|
|
# adopted from
|
|
|
|
# https://github.com/openai/improved-diffusion/blob/main/improved_diffusion/gaussian_diffusion.py
|
|
|
|
# and
|
|
|
|
# https://github.com/lucidrains/denoising-diffusion-pytorch/blob/7706bdfc6f527f58d33f84b7b522e61e6e3164b3/denoising_diffusion_pytorch/denoising_diffusion_pytorch.py
|
|
|
|
# and
|
|
|
|
# https://github.com/openai/guided-diffusion/blob/0ba878e517b276c45d1195eb29f6f5f72659a05b/guided_diffusion/nn.py
|
|
|
|
#
|
|
|
|
# thanks!
|
|
|
|
|
|
|
|
|
|
|
|
import os
|
|
|
|
import math
|
|
|
|
import torch
|
|
|
|
import torch.nn as nn
|
|
|
|
import numpy as np
|
|
|
|
from einops import repeat
|
|
|
|
|
|
|
|
from ldm.util import instantiate_from_config
|
|
|
|
|
|
|
|
|
2022-08-26 07:15:42 +00:00
|
|
|
def make_beta_schedule(
|
|
|
|
schedule, n_timestep, linear_start=1e-4, linear_end=2e-2, cosine_s=8e-3
|
|
|
|
):
|
|
|
|
if schedule == 'linear':
|
2021-12-21 02:23:41 +00:00
|
|
|
betas = (
|
2022-08-26 07:15:42 +00:00
|
|
|
torch.linspace(
|
|
|
|
linear_start**0.5,
|
|
|
|
linear_end**0.5,
|
|
|
|
n_timestep,
|
|
|
|
dtype=torch.float64,
|
|
|
|
)
|
|
|
|
** 2
|
2021-12-21 02:23:41 +00:00
|
|
|
)
|
|
|
|
|
2022-08-26 07:15:42 +00:00
|
|
|
elif schedule == 'cosine':
|
2021-12-21 02:23:41 +00:00
|
|
|
timesteps = (
|
2022-08-26 07:15:42 +00:00
|
|
|
torch.arange(n_timestep + 1, dtype=torch.float64) / n_timestep
|
|
|
|
+ cosine_s
|
2021-12-21 02:23:41 +00:00
|
|
|
)
|
|
|
|
alphas = timesteps / (1 + cosine_s) * np.pi / 2
|
|
|
|
alphas = torch.cos(alphas).pow(2)
|
|
|
|
alphas = alphas / alphas[0]
|
|
|
|
betas = 1 - alphas[1:] / alphas[:-1]
|
|
|
|
betas = np.clip(betas, a_min=0, a_max=0.999)
|
|
|
|
|
2022-08-26 07:15:42 +00:00
|
|
|
elif schedule == 'sqrt_linear':
|
|
|
|
betas = torch.linspace(
|
|
|
|
linear_start, linear_end, n_timestep, dtype=torch.float64
|
|
|
|
)
|
|
|
|
elif schedule == 'sqrt':
|
|
|
|
betas = (
|
|
|
|
torch.linspace(
|
|
|
|
linear_start, linear_end, n_timestep, dtype=torch.float64
|
|
|
|
)
|
|
|
|
** 0.5
|
|
|
|
)
|
2021-12-21 02:23:41 +00:00
|
|
|
else:
|
|
|
|
raise ValueError(f"schedule '{schedule}' unknown.")
|
|
|
|
return betas.numpy()
|
|
|
|
|
|
|
|
|
2022-08-26 07:15:42 +00:00
|
|
|
def make_ddim_timesteps(
|
|
|
|
ddim_discr_method, num_ddim_timesteps, num_ddpm_timesteps, verbose=True
|
|
|
|
):
|
2021-12-21 02:23:41 +00:00
|
|
|
if ddim_discr_method == 'uniform':
|
|
|
|
c = num_ddpm_timesteps // num_ddim_timesteps
|
|
|
|
ddim_timesteps = np.asarray(list(range(0, num_ddpm_timesteps, c)))
|
|
|
|
elif ddim_discr_method == 'quad':
|
2022-08-26 07:15:42 +00:00
|
|
|
ddim_timesteps = (
|
|
|
|
(
|
|
|
|
np.linspace(
|
|
|
|
0, np.sqrt(num_ddpm_timesteps * 0.8), num_ddim_timesteps
|
|
|
|
)
|
|
|
|
)
|
|
|
|
** 2
|
|
|
|
).astype(int)
|
2021-12-21 02:23:41 +00:00
|
|
|
else:
|
2022-08-26 07:15:42 +00:00
|
|
|
raise NotImplementedError(
|
|
|
|
f'There is no ddim discretization method called "{ddim_discr_method}"'
|
|
|
|
)
|
2021-12-21 02:23:41 +00:00
|
|
|
|
|
|
|
# assert ddim_timesteps.shape[0] == num_ddim_timesteps
|
|
|
|
# add one to get the final alpha values right (the ones from first scale to data during sampling)
|
Squashed commit of the following:
commit 1c649e4663f37b51b42a561548c7e03d7efb209e
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Mon Sep 12 13:29:16 2022 -0400
fix torchvision dependency version #511
commit 4d197f699e1e8c3b0e7c1b71c30261a49370ee8d
Merge: a3e07fb 190ba78
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Mon Sep 12 07:29:19 2022 -0400
Merge branch 'development' of github.com:lstein/stable-diffusion into development
commit a3e07fb84ad51eab2aa586edaa011bbd4e01b395
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Mon Sep 12 07:28:58 2022 -0400
fix grid crash
commit 9fa1f31bf2f80785492927959c58e4b0825fb2e4
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Mon Sep 12 07:07:05 2022 -0400
fix opencv and realesrgan dependencies in mac install
commit 190ba78960c0c45bd1c51626e303b8c78a17b0c1
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Mon Sep 12 01:50:58 2022 -0400
Update requirements-mac.txt
Fixed dangling dash on last line.
commit 25d9ccc5091cc6452d8597453dcfe6c79327aa3a
Author: Any-Winter-4079 <50542132+Any-Winter-4079@users.noreply.github.com>
Date: Mon Sep 12 03:17:29 2022 +0200
Update model.py
commit 9cdf3aca7d2a7a6e85ec0a2732eb8e5a2dd60329
Author: Any-Winter-4079 <50542132+Any-Winter-4079@users.noreply.github.com>
Date: Mon Sep 12 02:52:36 2022 +0200
Update attention.py
Performance improvements to generate larger images in M1 #431
Update attention.py
Added dtype=r1.dtype to softmax
commit 49a96b90d846bcff17582273cacad596eff30658
Author: Mihai <299015+mh-dm@users.noreply.github.com>
Date: Sat Sep 10 16:58:07 2022 +0300
~7% speedup (1.57 to 1.69it/s) from switch to += in ldm.modules.attention. (#482)
Tested on 8GB eGPU nvidia setup so YMMV.
512x512 output, max VRAM stays same.
commit aba94b85e88cde654dd03bdec493a6d3b232f931
Author: Niek van der Maas <mail@niekvandermaas.nl>
Date: Fri Sep 9 15:01:37 2022 +0200
Fix macOS `pyenv` instructions, add code block highlight (#441)
Fix: `anaconda3-latest` does not work, specify the correct virtualenv, add missing init.
commit aac5102cf3850781a635cacc3150dd6bb4f486a8
Author: Henry van Megen <h.vanmegen@gmail.com>
Date: Thu Sep 8 05:16:35 2022 +0200
Disabled debug output (#436)
Co-authored-by: Henry van Megen <hvanmegen@gmail.com>
commit 0ab5a3646424467b459ea878d49cfc23f4a5ea35
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 17:19:46 2022 -0400
fix missing lines in outputs
commit 5e433728b550de9f56a2f124c8b325b3a5f2bd2f
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 16:20:14 2022 -0400
upped max_steps in v1-finetune.yaml and fixed TI docs to address #493
commit 7708f4fb98510dff504041231261c039a2c718de
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 16:03:37 2022 -0400
slight efficiency gain by using += in attention.py
commit b86a1deb00892f2b5f260659377d27790ef14016
Author: blessedcoolant <54517381+blessedcoolant@users.noreply.github.com>
Date: Mon Sep 12 07:47:12 2022 +1200
Remove print statement styling (#504)
Co-authored-by: Lincoln Stein <lincoln.stein@gmail.com>
commit 4951e66103878e5d5c8943a710ebce9320888252
Author: chromaticist <mhostick@gmail.com>
Date: Sun Sep 11 12:44:26 2022 -0700
Adding support for .bin files from huggingface concepts (#498)
* Adding support for .bin files from huggingface concepts
* Updating documentation to include huggingface .bin info
commit 79b445b0ca43b3592a829909dc4507cb1ecbe9e0
Merge: a323070 f7662c1
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 15:39:38 2022 -0400
Merge branch 'development' of github.com:lstein/stable-diffusion into development
commit a323070a4dbb1ce62db94342a2ab8e4adef833d6
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 15:28:57 2022 -0400
update requirements for new location of gfpgan
commit f7662c1808acc1704316d3b84d4baeacf1b24018
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 15:00:24 2022 -0400
update requirements for changed location of gfpgan
commit 93c242c9fbef91d87a6bbf42db2267dbd51e5739
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 14:47:58 2022 -0400
make gfpgan_model_exists flag available to web interface
commit c7c6cd7735b5c32e58349ca998a925cbaed7b376
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 14:43:07 2022 -0400
Update UPSCALE.md
New instructions needed to accommodate fact that the ESRGAN and GFPGAN packages are now installed by environment.yaml.
commit 77ca83e1031639f1e15cb7451e53dd8e37d1e971
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 14:31:56 2022 -0400
Update CLI.md
Final documentation tweak.
commit 0ea145d1884ce2316452124fd51a879506e2988d
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 14:29:26 2022 -0400
Update CLI.md
More doc fixes.
commit 162285ae86a2ab0bb26749387186c82b6bbf851d
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 14:28:45 2022 -0400
Update CLI.md
Minor documentation fix
commit 37c921dfe2aa25342934a101bf83eea4c0f5cfb7
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 14:26:41 2022 -0400
documentation enhancements
commit 4f72cb44ad0429874c9ba507d325267e295a040c
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 13:05:38 2022 -0400
moved the notebook files into their own directory
commit 878ef2e9e095ab08d00532f8a19556b8949b2dbb
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 12:58:06 2022 -0400
documentation tweaks
commit 4923118610ecaced2a670d108aef81c220d3507a
Merge: 16f6a67 defafc0
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 12:51:25 2022 -0400
Merge branch 'development' of github.com:lstein/stable-diffusion into development
commit defafc0e8e0e69b39fd13db12036e1d01e7a19f1
Author: Dominic Letz <dominic@diode.io>
Date: Sun Sep 11 18:51:01 2022 +0200
Enable upscaling on m1 (#474)
commit 16f6a6731d80fcc04dcdb693d74fc5c21e753c10
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 12:47:26 2022 -0400
install GFPGAN inside SD repository in order to fix 'dark cast' issue #169
commit 0881d429f2ddcd288aa673b2b5e9435a8a44371a
Author: blessedcoolant <54517381+blessedcoolant@users.noreply.github.com>
Date: Mon Sep 12 03:52:43 2022 +1200
Docs Update (#466)
Authored-by: @blessedcoolant
Co-authored-by: Lincoln Stein <lincoln.stein@gmail.com>
commit 9a29d442b437d650bd42516bbb24ebbcd0d6cd74
Author: Gérald LONLAS <gerald@lonlas.com>
Date: Sun Sep 11 23:23:18 2022 +0800
Revert "Add 3x Upscale option on the Web UI (#442)" (#488)
This reverts commit f8a540881c79ae657dc05b47bc71f8648e9f9782.
commit d301836fbdfce0a3f12b19ae6415e7ae14f53ed2
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 10:52:19 2022 -0400
can select prior output for init_img using -1, -2, etc
commit 70aa674e9e10d03eb462249764695ef1d4e1e28c
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 10:34:06 2022 -0400
merge PR #495 - keep using float16 in ldm.modules.attention
commit 8748370f44e28b104fbaa23b4e2e54e64102d799
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 10:22:32 2022 -0400
negative -S indexing recovers correct previous seed; closes issue #476
commit 839e30e4b8ca6554017fbab671bdf85fadf9a6ea
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 11 10:02:44 2022 -0400
improve CUDA VRAM monitoring
extra check that device==cuda before getting VRAM stats
commit bfb278127923fbd461c4549a4b7f2f2c1dd34b8c
Author: tildebyte <337875+tildebyte@users.noreply.github.com>
Date: Sat Sep 10 10:15:56 2022 -0400
fix(readme): add note about updating env via conda (#475)
commit 5c439888626145f94db1fdb00f5787ad27b64602
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 10 10:02:43 2022 -0400
reduce VRAM memory usage by half during model loading
* This moves the call to half() before model.to(device) to avoid GPU
copy of full model. Improves speed and reduces memory usage dramatically
* This fix contributed by @mh-dm (Mihai)
commit 99122708ca3342e00063c687f149c950cfd87200
Merge: 817c4a2 ecc6b75
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 10 09:54:34 2022 -0400
Merge branch 'development' of github.com:lstein/stable-diffusion into development
commit 817c4a26de0d01b109550e6db9d4c3ece9f37c1b
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 10 09:53:27 2022 -0400
remove -F option from normalized prompt; closes #483
commit ecc6b75a3ede6d1d2850d69e998c92c342efdf2d
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 10 09:53:27 2022 -0400
remove -F option from normalized prompt
commit 723d07444205a9c3da96926630c1dc705db3f130
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Fri Sep 9 18:49:51 2022 -0400
Allow ctrl c when using --from_file (#472)
* added ansi escapes to highlight key parts of CLI session
* adjust exception handling so that ^C will abort when reading prompts from a file
commit 75f633cda887d7bfcca3ef529d25c52461e11d99
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Fri Sep 9 12:03:45 2022 -0400
re-add new logo
commit 10db192cc4be66b3cebbdaa48a1806807578b56f
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Fri Sep 9 09:26:10 2022 -0400
changes to dogettx optimizations to run on m1
* Author @any-winter-4079
* Author @dogettx
Thanks to many individuals who contributed time and hardware to
benchmarking and debugging these changes.
commit c85ae00b33d619ab5448246ecda6c8e40d66fa3e
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Thu Sep 8 23:57:45 2022 -0400
fix bug which caused seed to get "stuck" on previous image even when UI specified -1
commit 1b5aae3ef3218b3f07b9ec48ce72589c0ad33746
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Thu Sep 8 22:36:47 2022 -0400
add icon to dream web server
commit 6abf739315ef83202ff5ad2144888f79f480d88d
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Thu Sep 8 22:25:09 2022 -0400
add favicon to web server
commit db825b813805b7428465e42377d756009e09e836
Merge: 33874ba afee7f9
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Thu Sep 8 22:17:37 2022 -0400
Merge branch 'deNULL-development' into development
commit 33874bae8db71dcdb5525826a1ec93b105e841ad
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Thu Sep 8 22:16:29 2022 -0400
Squashed commit of the following:
commit afee7f9cea2a73a3d62ced667e88aa0fe15020e4
Merge: 6531446 171f8db
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Thu Sep 8 22:14:32 2022 -0400
Merge branch 'development' of github.com:deNULL/stable-diffusion into deNULL-development
commit 171f8db742f18532b6fa03cdfbf4be2bbf6cf3ad
Author: Denis Olshin <me@denull.ru>
Date: Thu Sep 8 03:15:20 2022 +0300
saving full prompt to metadata when using web ui
commit d7e67b62f0ea9b7c8394b7c48786f5cf9c6f9e94
Author: Denis Olshin <me@denull.ru>
Date: Thu Sep 8 01:51:47 2022 +0300
better logic for clicking to make variations
commit afee7f9cea2a73a3d62ced667e88aa0fe15020e4
Merge: 6531446 171f8db
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Thu Sep 8 22:14:32 2022 -0400
Merge branch 'development' of github.com:deNULL/stable-diffusion into deNULL-development
commit 653144694fbb928d387c615c013ab0f2f1d5ca7f
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Thu Sep 8 20:41:37 2022 -0400
work around unexplained crash when timesteps=1000 (#440)
* work around unexplained crash when timesteps=1000
* this fix seems to work
commit c33a84cdfdb861a77916cd499e561d4c68ee192a
Author: blessedcoolant <54517381+blessedcoolant@users.noreply.github.com>
Date: Fri Sep 9 12:39:51 2022 +1200
Add New Logo (#454)
* Add instructions on how to install alongside pyenv (#393)
Like probably many others, I have a lot of different virtualenvs, one for each project. Most of them are handled by `pyenv`.
After installing according to these instructions I had issues with ´pyenv`and `miniconda` fighting over the $PATH of my system.
But then I stumbled upon this nice solution on SO: https://stackoverflow.com/a/73139031 , upon which I have based my suggested changes.
It runs perfectly on my M1 setup, with the anaconda setup as a virtual environment handled by pyenv.
Feel free to incorporate these instructions as you see fit.
Thanks a million for all your hard work.
* Disabled debug output (#436)
Co-authored-by: Henry van Megen <hvanmegen@gmail.com>
* Add New Logo
Co-authored-by: Håvard Gulldahl <havard@lurtgjort.no>
Co-authored-by: Henry van Megen <h.vanmegen@gmail.com>
Co-authored-by: Henry van Megen <hvanmegen@gmail.com>
Co-authored-by: Lincoln Stein <lincoln.stein@gmail.com>
commit f8a540881c79ae657dc05b47bc71f8648e9f9782
Author: Gérald LONLAS <gerald@lonlas.com>
Date: Fri Sep 9 01:45:54 2022 +0800
Add 3x Upscale option on the Web UI (#442)
commit 244239e5f656e1f34830b8e8ce99a40decbea324
Author: James Reynolds <magnusviri@users.noreply.github.com>
Date: Thu Sep 8 05:36:33 2022 -0600
macOS CI workflow, dream.py exits with an error, but the workflow com… (#396)
* macOS CI workflow, dream.py exits with an error, but the workflow completes.
* Files for testing
Co-authored-by: James Reynolds <magnsuviri@me.com>
Co-authored-by: Lincoln Stein <lincoln.stein@gmail.com>
commit 711d49ed30a0741558ed06d6be38680e00272774
Author: James Reynolds <magnusviri@users.noreply.github.com>
Date: Thu Sep 8 05:35:08 2022 -0600
Cache model workflow (#394)
* Add workflow that caches the model, step 1 for CI
* Change name of workflow job
Co-authored-by: James Reynolds <magnsuviri@me.com>
Co-authored-by: Lincoln Stein <lincoln.stein@gmail.com>
commit 7996a30e3aea1ae9611bbce6e6efaac60aeb95d4
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Thu Sep 8 07:34:03 2022 -0400
add auto-creation of mask for inpainting (#438)
* now use a single init image for both image and mask
* turn on debugging for now to write out mask and image
* add back -M option as a fallback
commit a69ca31f349ddcf4c94fd009dc896f4e653f7fa4
Author: elliotsayes <elliotsayes@gmail.com>
Date: Thu Sep 8 15:30:06 2022 +1200
.gitignore WebUI temp files (#430)
* Add instructions on how to install alongside pyenv (#393)
Like probably many others, I have a lot of different virtualenvs, one for each project. Most of them are handled by `pyenv`.
After installing according to these instructions I had issues with ´pyenv`and `miniconda` fighting over the $PATH of my system.
But then I stumbled upon this nice solution on SO: https://stackoverflow.com/a/73139031 , upon which I have based my suggested changes.
It runs perfectly on my M1 setup, with the anaconda setup as a virtual environment handled by pyenv.
Feel free to incorporate these instructions as you see fit.
Thanks a million for all your hard work.
* .gitignore WebUI temp files
Co-authored-by: Håvard Gulldahl <havard@lurtgjort.no>
commit 5c6b612a722ff9cde1a5ddf9b29874842f1d5a26
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Wed Sep 7 22:50:55 2022 -0400
fix bug that caused same seed to be redisplayed repeatedly
commit 56f155c5907224b4276adb6ba01bd5c1a3401ee3
Author: Johan Roxendal <johan@roxendal.com>
Date: Thu Sep 8 04:50:06 2022 +0200
added support for parsing run log and displaying images in the frontend init state (#410)
Co-authored-by: Johan Roxendal <johan.roxendal@litteraturbanken.se>
Co-authored-by: Lincoln Stein <lincoln.stein@gmail.com>
commit 41687746be5290a4c3d3437957307666d956ae9d
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Wed Sep 7 20:24:35 2022 -0400
added missing initialization of latent_noise to None
commit 171f8db742f18532b6fa03cdfbf4be2bbf6cf3ad
Author: Denis Olshin <me@denull.ru>
Date: Thu Sep 8 03:15:20 2022 +0300
saving full prompt to metadata when using web ui
commit d7e67b62f0ea9b7c8394b7c48786f5cf9c6f9e94
Author: Denis Olshin <me@denull.ru>
Date: Thu Sep 8 01:51:47 2022 +0300
better logic for clicking to make variations
commit d1d044aa87cf8ba95a7e2e553c7fd993ec81a6d7
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Wed Sep 7 17:56:59 2022 -0400
actual image seed now written into web log rather than -1 (#428)
commit edada042b318028c77ab50dfbaa0b2671cc69e61
Author: Arturo Mendivil <60411196+artmen1516@users.noreply.github.com>
Date: Wed Sep 7 10:42:26 2022 -0700
Improve notebook and add requirements file (#422)
commit 29ab3c20280bfa73b9a89c8bd9dc99dc0ad7b651
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Wed Sep 7 13:28:11 2022 -0400
disable neonpixel optimizations on M1 hardware (#414)
* disable neonpixel optimizations on M1 hardware
* fix typo that was causing random noise images on m1
commit 7670ecc63f3e30e320e2c4197eb7140c6196c168
Author: cody <cnmizell@gmail.com>
Date: Wed Sep 7 12:24:41 2022 -0500
add more keyboard support on the web server (#391)
add ability to submit prompts with the "enter" key
add ability to cancel generations with the "escape" key
commit dd2aedacaf27d8fe750a342c310bc88de5311931
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Wed Sep 7 13:23:53 2022 -0400
report VRAM usage stats during initial model loading (#419)
commit f6284777e6d79bd3d1e85b83aa72d774299a7403
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Tue Sep 6 17:12:39 2022 -0400
Squashed commit of the following:
commit 7d1344282d942a33dcecda4d5144fc154ec82915
Merge: caf4ea3 ebeb556
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Mon Sep 5 10:07:27 2022 -0400
Merge branch 'development' of github.com:WebDev9000/stable-diffusion into WebDev9000-development
commit ebeb556af9c99b491a83c72f83512683a02a82ad
Author: Web Dev 9000 <rirath@gmail.com>
Date: Sun Sep 4 18:05:15 2022 -0700
Fixed unintentionally removed lines
commit ff2c4b9a1b773b95686d5f3e546e1194de054694
Author: Web Dev 9000 <rirath@gmail.com>
Date: Sun Sep 4 17:50:13 2022 -0700
Add ability to recreate variations via image click
commit c012929cdae7c37aa3b3b4fa2e7de465458f732a
Author: Web Dev 9000 <rirath@gmail.com>
Date: Sun Sep 4 14:35:33 2022 -0700
Add files via upload
commit 02a601899214adfe4536ce0ba67694a46319fd51
Author: Web Dev 9000 <rirath@gmail.com>
Date: Sun Sep 4 14:35:07 2022 -0700
Add files via upload
commit eef788981cbed7c68ffd58b4eb22a2df2e59ae0b
Author: Olivier Louvignes <olivier@mg-crea.com>
Date: Tue Sep 6 12:41:08 2022 +0200
feat(txt2img): allow from_file to work with len(lines) < batch_size (#349)
commit 720e5cd6513cd27e6d53feb6475dde20bd39841a
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Mon Sep 5 20:40:10 2022 -0400
Refactoring simplet2i (#387)
* start refactoring -not yet functional
* first phase of refactor done - not sure weighted prompts working
* Second phase of refactoring. Everything mostly working.
* The refactoring has moved all the hard-core inference work into
ldm.dream.generator.*, where there are submodules for txt2img and
img2img. inpaint will go in there as well.
* Some additional refactoring will be done soon, but relatively
minor work.
* fix -save_orig flag to actually work
* add @neonsecret attention.py memory optimization
* remove unneeded imports
* move token logging into conditioning.py
* add placeholder version of inpaint; porting in progress
* fix crash in img2img
* inpainting working; not tested on variations
* fix crashes in img2img
* ported attention.py memory optimization #117 from basujindal branch
* added @torch_no_grad() decorators to img2img, txt2img, inpaint closures
* Final commit prior to PR against development
* fixup crash when generating intermediate images in web UI
* rename ldm.simplet2i to ldm.generate
* add backward-compatibility simplet2i shell with deprecation warning
* add back in mps exception, addresses @vargol comment in #354
* replaced Conditioning class with exported functions
* fix wrong type of with_variations attribute during intialization
* changed "image_iterator()" to "get_make_image()"
* raise NotImplementedError for calling get_make_image() in parent class
* Update ldm/generate.py
better error message
Co-authored-by: Kevin Gibbons <bakkot@gmail.com>
* minor stylistic fixes and assertion checks from code review
* moved get_noise() method into img2img class
* break get_noise() into two methods, one for txt2img and the other for img2img
* inpainting works on non-square images now
* make get_noise() an abstract method in base class
* much improved inpainting
Co-authored-by: Kevin Gibbons <bakkot@gmail.com>
commit 1ad2a8e567b054cfe9df1715aa805218ee185754
Author: thealanle <35761977+thealanle@users.noreply.github.com>
Date: Mon Sep 5 17:35:04 2022 -0700
Fix --outdir function for web (#373)
* Fix --outdir function for web
* Removed unnecessary hardcoded path
commit 52d8bb2836cf05994ee5e2c5cf9c8d190dac0524
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Mon Sep 5 10:31:59 2022 -0400
Squashed commit of the following:
commit 0cd48e932f1326e000c46f4140f98697eb9bdc79
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Mon Sep 5 10:27:43 2022 -0400
resolve conflicts with development
commit d7bc8c12e05535a363ac7c745a3f3abc2773bfcf
Author: Scott McMillin <scott@scottmcmillin.com>
Date: Sun Sep 4 18:52:09 2022 -0500
Add title attribute back to img tag
commit 5397c89184ebfb8260bc2d8c3f23e73e103d24e6
Author: Scott McMillin <scott@scottmcmillin.com>
Date: Sun Sep 4 13:49:46 2022 -0500
Remove temp code
commit 1da080b50972696db2930681a09cb1c14e524758
Author: Scott McMillin <scott@scottmcmillin.com>
Date: Sun Sep 4 13:33:56 2022 -0500
Cleaned up HTML; small style changes; image click opens image; add seed to figcaption beneath image
commit caf4ea3d8982416dcf5a80fe4601ac4fbc126cc0
Author: Adam Rice <adam@askadam.io>
Date: Mon Sep 5 10:05:39 2022 -0400
Add a 'Remove Image' button to clear the file upload field (#382)
* added "remove image" button
* styled a new "remove image" button
* Update index.js
commit 95c088b30342c75ec2ab8c7d7a423ffd11c50099
Author: Kevin Gibbons <bakkot@gmail.com>
Date: Sun Sep 4 19:04:14 2022 -0700
Revert "Add CORS headers to dream server to ease integration with third-party web interfaces" (#371)
This reverts commit 91e826e5f425333674d1e3bec1fa1ac63cfb382d.
commit a20113d5a3985a23b7e19301acb57688e31e975c
Author: Kevin Gibbons <bakkot@gmail.com>
Date: Sun Sep 4 18:59:12 2022 -0700
put no_grad decorator on make_image closures (#375)
commit 0f93dadd6ac5aa0fbeee5d72150def775752a153
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 4 21:39:15 2022 -0400
fix several dangling references to --gfpgan option, which no longer exists
commit f4004f660e5daba721426cfcd3fe95318fd10bc3
Author: tildebyte <337875+tildebyte@users.noreply.github.com>
Date: Sun Sep 4 19:43:04 2022 -0400
TOIL(requirements): Split requirements to per-platform (#355)
* toil(reqs): split requirements to per-platform
Signed-off-by: Ben Alkov <ben.alkov@gmail.com>
* toil(reqs): fix for Win and Lin...
...allow pip to resolve latest torch, numpy
Signed-off-by: Ben Alkov <ben.alkov@gmail.com>
* toil(install): update reqs in Win install notebook
Signed-off-by: Ben Alkov <ben.alkov@gmail.com>
Signed-off-by: Ben Alkov <ben.alkov@gmail.com>
commit 4406fd138dec0e25409aeaa2b716f88dd95b76d1
Merge: 5116c81 fd7a72e
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 4 08:23:53 2022 -0400
Merge branch 'SebastianAigner-main' into development
Add support for full CORS headers for dream server.
commit fd7a72e147393f32fc40d8f5918ea9bf1401e723
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 4 08:23:11 2022 -0400
remove debugging message
commit 3a2be621f36e66b16e60b7f4f9210babfe84c582
Merge: 91e826e 5116c81
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sun Sep 4 08:15:51 2022 -0400
Merge branch 'development' into main
commit 5116c8178c67f550e57f5d16fe931ee1a7cdb0ba
Author: Justin Wong <1584142+wongjustin99@users.noreply.github.com>
Date: Sun Sep 4 07:17:58 2022 -0400
fix save_original flag saving to the same filename (#360)
* Update README.md with new Anaconda install steps (#347)
pip3 version did not work for me and this is the recommended way to install Anaconda now it seems
* fix save_original flag saving to the same filename
Before this, the `--save_orig` flag was not working. The upscaled/GFPGAN would overwrite the original output image.
Co-authored-by: greentext2 <112735219+greentext2@users.noreply.github.com>
commit 91e826e5f425333674d1e3bec1fa1ac63cfb382d
Author: Sebastian Aigner <SebastianAigner@users.noreply.github.com>
Date: Sun Sep 4 10:22:54 2022 +0200
Add CORS headers to dream server to ease integration with third-party web interfaces
commit 6266d9e8d6421ee732338560f825771e461cefb0
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 3 15:45:20 2022 -0400
remove stray debugging message
commit 138956e5162679f6894ce75462907c9eeed83cbb
Author: greentext2 <112735219+greentext2@users.noreply.github.com>
Date: Sat Sep 3 13:38:57 2022 -0500
Update README.md with new Anaconda install steps (#347)
pip3 version did not work for me and this is the recommended way to install Anaconda now it seems
commit 60be735e802a1c3cd2812c5d8e63f9ed467ea9d9
Author: Cora Johnson-Roberson <cora.johnson.roberson@gmail.com>
Date: Sat Sep 3 14:28:34 2022 -0400
Switch to regular pytorch channel and restore Python 3.10 for Macs. (#301)
* Switch to regular pytorch channel and restore Python 3.10 for Macs.
Although pytorch-nightly should in theory be faster, it is currently
causing increased memory usage and slower iterations:
https://github.com/lstein/stable-diffusion/pull/283#issuecomment-1234784885
This changes the environment-mac.yaml file back to the regular pytorch
channel and moves the `transformers` dep into pip for now (since it
cannot be satisfied until tokenizers>=0.11 is built for Python 3.10).
* Specify versions for Pip packages as well.
commit d0d95d3a2a4b7a91c5c4f570d88af43a2c3afe75
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 3 14:10:31 2022 -0400
make initimg appear in web log
commit b90a21500037f07bb1b5d143045253ee6bc67391
Merge: 1eee811 6270e31
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 3 13:47:15 2022 -0400
Merge branch 'prixt-seamless' into development
commit 6270e313b8d87b33cb914f12558e34bc2f0ae357
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 3 13:46:29 2022 -0400
add credit to prixt for seamless circular tiling
commit a01b7bdc40af5376177de30b76dc075b523b3450
Merge: 1eee811 9d88abe
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 3 13:43:04 2022 -0400
add web interface for seamless option
commit 1eee8111b95241f54b49f58605ab343a52325b89
Merge: 64eca42 fb857f0
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 3 12:33:39 2022 -0400
Merge branch 'development' of github.com:lstein/stable-diffusion into development
commit 64eca42610b92cb73a30c405ab9dad28990c15e1
Merge: 9130ad7 21a1f68
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 3 12:33:05 2022 -0400
Merge branch 'main' into development
* brings in small documentation fixes that were
added directly to main during release tweaking.
commit fb857f05ba0eda5cf9bbe0f60b73a73d75562d85
Author: Lincoln Stein <lincoln.stein@gmail.com>
Date: Sat Sep 3 12:07:07 2022 -0400
fix typo in docs
commit 9d88abe2ea1fed6231ffd822956614589a1075b7
Author: prixt <paraxite@naver.com>
Date: Sat Sep 3 22:42:16 2022 +0900
fixed typo
commit a61e49bc974af0fc01c8424d7df9262f63ecf289
Author: prixt <paraxite@naver.com>
Date: Sat Sep 3 22:39:35 2022 +0900
* Removed unnecessary code
* Added description about --seamless
commit 02bee4fdb1534b71c5e609204506efb66699b2bc
Author: prixt <paraxite@naver.com>
Date: Sat Sep 3 16:08:03 2022 +0900
added --seamless tag logging to normalize_prompt
commit d922b53c26f3e9a11ecb920536b9632ec69df5f6
Author: prixt <paraxite@naver.com>
Date: Sat Sep 3 15:13:31 2022 +0900
added seamless tiling mode and commands
2022-09-12 18:31:48 +00:00
|
|
|
# steps_out = ddim_timesteps + 1
|
|
|
|
steps_out = ddim_timesteps
|
|
|
|
|
2021-12-21 02:23:41 +00:00
|
|
|
if verbose:
|
|
|
|
print(f'Selected timesteps for ddim sampler: {steps_out}')
|
|
|
|
return steps_out
|
|
|
|
|
|
|
|
|
2022-08-26 07:15:42 +00:00
|
|
|
def make_ddim_sampling_parameters(
|
|
|
|
alphacums, ddim_timesteps, eta, verbose=True
|
|
|
|
):
|
2021-12-21 02:23:41 +00:00
|
|
|
# select alphas for computing the variance schedule
|
|
|
|
alphas = alphacums[ddim_timesteps]
|
2022-08-26 07:15:42 +00:00
|
|
|
alphas_prev = np.asarray(
|
|
|
|
[alphacums[0]] + alphacums[ddim_timesteps[:-1]].tolist()
|
|
|
|
)
|
2021-12-21 02:23:41 +00:00
|
|
|
|
|
|
|
# according the the formula provided in https://arxiv.org/abs/2010.02502
|
2022-08-26 07:15:42 +00:00
|
|
|
sigmas = eta * np.sqrt(
|
|
|
|
(1 - alphas_prev) / (1 - alphas) * (1 - alphas / alphas_prev)
|
|
|
|
)
|
2021-12-21 02:23:41 +00:00
|
|
|
if verbose:
|
2022-08-26 07:15:42 +00:00
|
|
|
print(
|
|
|
|
f'Selected alphas for ddim sampler: a_t: {alphas}; a_(t-1): {alphas_prev}'
|
|
|
|
)
|
|
|
|
print(
|
|
|
|
f'For the chosen value of eta, which is {eta}, '
|
|
|
|
f'this results in the following sigma_t schedule for ddim sampler {sigmas}'
|
|
|
|
)
|
2021-12-21 02:23:41 +00:00
|
|
|
return sigmas, alphas, alphas_prev
|
|
|
|
|
|
|
|
|
|
|
|
def betas_for_alpha_bar(num_diffusion_timesteps, alpha_bar, max_beta=0.999):
|
|
|
|
"""
|
|
|
|
Create a beta schedule that discretizes the given alpha_t_bar function,
|
|
|
|
which defines the cumulative product of (1-beta) over time from t = [0,1].
|
|
|
|
:param num_diffusion_timesteps: the number of betas to produce.
|
|
|
|
:param alpha_bar: a lambda that takes an argument t from 0 to 1 and
|
|
|
|
produces the cumulative product of (1-beta) up to that
|
|
|
|
part of the diffusion process.
|
|
|
|
:param max_beta: the maximum beta to use; use values lower than 1 to
|
|
|
|
prevent singularities.
|
|
|
|
"""
|
|
|
|
betas = []
|
|
|
|
for i in range(num_diffusion_timesteps):
|
|
|
|
t1 = i / num_diffusion_timesteps
|
|
|
|
t2 = (i + 1) / num_diffusion_timesteps
|
|
|
|
betas.append(min(1 - alpha_bar(t2) / alpha_bar(t1), max_beta))
|
|
|
|
return np.array(betas)
|
|
|
|
|
|
|
|
|
|
|
|
def extract_into_tensor(a, t, x_shape):
|
|
|
|
b, *_ = t.shape
|
|
|
|
out = a.gather(-1, t)
|
|
|
|
return out.reshape(b, *((1,) * (len(x_shape) - 1)))
|
|
|
|
|
|
|
|
|
|
|
|
def checkpoint(func, inputs, params, flag):
|
|
|
|
"""
|
|
|
|
Evaluate a function without caching intermediate activations, allowing for
|
|
|
|
reduced memory at the expense of extra compute in the backward pass.
|
|
|
|
:param func: the function to evaluate.
|
|
|
|
:param inputs: the argument sequence to pass to `func`.
|
|
|
|
:param params: a sequence of parameters `func` depends on but does not
|
|
|
|
explicitly take as arguments.
|
|
|
|
:param flag: if False, disable gradient checkpointing.
|
|
|
|
"""
|
2022-08-26 07:15:42 +00:00
|
|
|
if (
|
|
|
|
False
|
|
|
|
): # disabled checkpointing to allow requires_grad = False for main model
|
2021-12-21 02:23:41 +00:00
|
|
|
args = tuple(inputs) + tuple(params)
|
|
|
|
return CheckpointFunction.apply(func, len(inputs), *args)
|
|
|
|
else:
|
|
|
|
return func(*inputs)
|
|
|
|
|
|
|
|
|
|
|
|
class CheckpointFunction(torch.autograd.Function):
|
|
|
|
@staticmethod
|
|
|
|
def forward(ctx, run_function, length, *args):
|
|
|
|
ctx.run_function = run_function
|
|
|
|
ctx.input_tensors = list(args[:length])
|
|
|
|
ctx.input_params = list(args[length:])
|
|
|
|
|
|
|
|
with torch.no_grad():
|
|
|
|
output_tensors = ctx.run_function(*ctx.input_tensors)
|
|
|
|
return output_tensors
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def backward(ctx, *output_grads):
|
2022-08-26 07:15:42 +00:00
|
|
|
ctx.input_tensors = [
|
|
|
|
x.detach().requires_grad_(True) for x in ctx.input_tensors
|
|
|
|
]
|
2021-12-21 02:23:41 +00:00
|
|
|
with torch.enable_grad():
|
|
|
|
# Fixes a bug where the first op in run_function modifies the
|
|
|
|
# Tensor storage in place, which is not allowed for detach()'d
|
|
|
|
# Tensors.
|
|
|
|
shallow_copies = [x.view_as(x) for x in ctx.input_tensors]
|
|
|
|
output_tensors = ctx.run_function(*shallow_copies)
|
|
|
|
input_grads = torch.autograd.grad(
|
|
|
|
output_tensors,
|
|
|
|
ctx.input_tensors + ctx.input_params,
|
|
|
|
output_grads,
|
|
|
|
allow_unused=True,
|
|
|
|
)
|
|
|
|
del ctx.input_tensors
|
|
|
|
del ctx.input_params
|
|
|
|
del output_tensors
|
|
|
|
return (None, None) + input_grads
|
|
|
|
|
|
|
|
|
|
|
|
def timestep_embedding(timesteps, dim, max_period=10000, repeat_only=False):
|
|
|
|
"""
|
|
|
|
Create sinusoidal timestep embeddings.
|
|
|
|
:param timesteps: a 1-D Tensor of N indices, one per batch element.
|
|
|
|
These may be fractional.
|
|
|
|
:param dim: the dimension of the output.
|
|
|
|
:param max_period: controls the minimum frequency of the embeddings.
|
|
|
|
:return: an [N x dim] Tensor of positional embeddings.
|
|
|
|
"""
|
|
|
|
if not repeat_only:
|
|
|
|
half = dim // 2
|
|
|
|
freqs = torch.exp(
|
2022-08-26 07:15:42 +00:00
|
|
|
-math.log(max_period)
|
|
|
|
* torch.arange(start=0, end=half, dtype=torch.float32)
|
|
|
|
/ half
|
2021-12-21 02:23:41 +00:00
|
|
|
).to(device=timesteps.device)
|
|
|
|
args = timesteps[:, None].float() * freqs[None]
|
|
|
|
embedding = torch.cat([torch.cos(args), torch.sin(args)], dim=-1)
|
|
|
|
if dim % 2:
|
2022-08-26 07:15:42 +00:00
|
|
|
embedding = torch.cat(
|
|
|
|
[embedding, torch.zeros_like(embedding[:, :1])], dim=-1
|
|
|
|
)
|
2021-12-21 02:23:41 +00:00
|
|
|
else:
|
|
|
|
embedding = repeat(timesteps, 'b -> b d', d=dim)
|
|
|
|
return embedding
|
|
|
|
|
|
|
|
|
|
|
|
def zero_module(module):
|
|
|
|
"""
|
|
|
|
Zero out the parameters of a module and return it.
|
|
|
|
"""
|
|
|
|
for p in module.parameters():
|
|
|
|
p.detach().zero_()
|
|
|
|
return module
|
|
|
|
|
|
|
|
|
|
|
|
def scale_module(module, scale):
|
|
|
|
"""
|
|
|
|
Scale the parameters of a module and return it.
|
|
|
|
"""
|
|
|
|
for p in module.parameters():
|
|
|
|
p.detach().mul_(scale)
|
|
|
|
return module
|
|
|
|
|
|
|
|
|
|
|
|
def mean_flat(tensor):
|
|
|
|
"""
|
|
|
|
Take the mean over all non-batch dimensions.
|
|
|
|
"""
|
|
|
|
return tensor.mean(dim=list(range(1, len(tensor.shape))))
|
|
|
|
|
|
|
|
|
|
|
|
def normalization(channels):
|
|
|
|
"""
|
|
|
|
Make a standard normalization layer.
|
|
|
|
:param channels: number of input channels.
|
|
|
|
:return: an nn.Module for normalization.
|
|
|
|
"""
|
|
|
|
return GroupNorm32(32, channels)
|
|
|
|
|
|
|
|
|
|
|
|
# PyTorch 1.7 has SiLU, but we support PyTorch 1.5.
|
|
|
|
class SiLU(nn.Module):
|
|
|
|
def forward(self, x):
|
|
|
|
return x * torch.sigmoid(x)
|
|
|
|
|
|
|
|
|
|
|
|
class GroupNorm32(nn.GroupNorm):
|
|
|
|
def forward(self, x):
|
|
|
|
return super().forward(x.float()).type(x.dtype)
|
|
|
|
|
2022-08-26 07:15:42 +00:00
|
|
|
|
2021-12-21 02:23:41 +00:00
|
|
|
def conv_nd(dims, *args, **kwargs):
|
|
|
|
"""
|
|
|
|
Create a 1D, 2D, or 3D convolution module.
|
|
|
|
"""
|
|
|
|
if dims == 1:
|
|
|
|
return nn.Conv1d(*args, **kwargs)
|
|
|
|
elif dims == 2:
|
|
|
|
return nn.Conv2d(*args, **kwargs)
|
|
|
|
elif dims == 3:
|
|
|
|
return nn.Conv3d(*args, **kwargs)
|
2022-08-26 07:15:42 +00:00
|
|
|
raise ValueError(f'unsupported dimensions: {dims}')
|
2021-12-21 02:23:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
def linear(*args, **kwargs):
|
|
|
|
"""
|
|
|
|
Create a linear module.
|
|
|
|
"""
|
|
|
|
return nn.Linear(*args, **kwargs)
|
|
|
|
|
|
|
|
|
|
|
|
def avg_pool_nd(dims, *args, **kwargs):
|
|
|
|
"""
|
|
|
|
Create a 1D, 2D, or 3D average pooling module.
|
|
|
|
"""
|
|
|
|
if dims == 1:
|
|
|
|
return nn.AvgPool1d(*args, **kwargs)
|
|
|
|
elif dims == 2:
|
|
|
|
return nn.AvgPool2d(*args, **kwargs)
|
|
|
|
elif dims == 3:
|
|
|
|
return nn.AvgPool3d(*args, **kwargs)
|
2022-08-26 07:15:42 +00:00
|
|
|
raise ValueError(f'unsupported dimensions: {dims}')
|
2021-12-21 02:23:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
class HybridConditioner(nn.Module):
|
|
|
|
def __init__(self, c_concat_config, c_crossattn_config):
|
|
|
|
super().__init__()
|
|
|
|
self.concat_conditioner = instantiate_from_config(c_concat_config)
|
2022-08-26 07:15:42 +00:00
|
|
|
self.crossattn_conditioner = instantiate_from_config(
|
|
|
|
c_crossattn_config
|
|
|
|
)
|
2021-12-21 02:23:41 +00:00
|
|
|
|
|
|
|
def forward(self, c_concat, c_crossattn):
|
|
|
|
c_concat = self.concat_conditioner(c_concat)
|
|
|
|
c_crossattn = self.crossattn_conditioner(c_crossattn)
|
|
|
|
return {'c_concat': [c_concat], 'c_crossattn': [c_crossattn]}
|
2021-12-22 14:57:23 +00:00
|
|
|
|
|
|
|
|
|
|
|
def noise_like(shape, device, repeat=False):
|
2022-08-26 07:15:42 +00:00
|
|
|
repeat_noise = lambda: torch.randn((1, *shape[1:]), device=device).repeat(
|
|
|
|
shape[0], *((1,) * (len(shape) - 1))
|
|
|
|
)
|
2021-12-22 14:57:23 +00:00
|
|
|
noise = lambda: torch.randn(shape, device=device)
|
2022-08-26 07:15:42 +00:00
|
|
|
return repeat_noise() if repeat else noise()
|