mirror of
https://github.com/lucidrains/DALLE2-pytorch.git
synced 2025-12-19 09:44:19 +01:00
fix a potential issue in the low resolution conditioner, when downsampling and then upsampling using resize right, thanks to @marunine
This commit is contained in:
@@ -44,6 +44,7 @@ This library would not have gotten to this working state without the help of
|
|||||||
- <a href="https://github.com/krish240574">Kumar</a> for working on the initial diffusion training script
|
- <a href="https://github.com/krish240574">Kumar</a> for working on the initial diffusion training script
|
||||||
- <a href="https://github.com/rom1504">Romain</a> for the pull request reviews and project management
|
- <a href="https://github.com/rom1504">Romain</a> for the pull request reviews and project management
|
||||||
- <a href="https://github.com/Ciaohe">He Cao</a> and <a href="https://github.com/xiankgx">xiankgx</a> for the Q&A and for identifying of critical bugs
|
- <a href="https://github.com/Ciaohe">He Cao</a> and <a href="https://github.com/xiankgx">xiankgx</a> for the Q&A and for identifying of critical bugs
|
||||||
|
- <a href="https://github.com/marunine">Marunine</a> for identifying issues with resizing of the low resolution conditioner, when training the upsampler, in addition to various other bug fixes
|
||||||
- <a href="https://github.com/crowsonkb">Katherine</a> for her advice
|
- <a href="https://github.com/crowsonkb">Katherine</a> for her advice
|
||||||
- <a href="https://stability.ai/">Stability AI</a> for the generous sponsorship
|
- <a href="https://stability.ai/">Stability AI</a> for the generous sponsorship
|
||||||
- <a href="https://huggingface.co">🤗 Huggingface</a> and in particular <a href="https://github.com/sgugger">Sylvain</a> for the <a href="https://github.com/huggingface/accelerate">Accelerate</a> library
|
- <a href="https://huggingface.co">🤗 Huggingface</a> and in particular <a href="https://github.com/sgugger">Sylvain</a> for the <a href="https://github.com/huggingface/accelerate">Accelerate</a> library
|
||||||
|
|||||||
@@ -125,14 +125,19 @@ def log(t, eps = 1e-12):
|
|||||||
def l2norm(t):
|
def l2norm(t):
|
||||||
return F.normalize(t, dim = -1)
|
return F.normalize(t, dim = -1)
|
||||||
|
|
||||||
def resize_image_to(image, target_image_size):
|
def resize_image_to(image, target_image_size, clamp_range = None):
|
||||||
orig_image_size = image.shape[-1]
|
orig_image_size = image.shape[-1]
|
||||||
|
|
||||||
if orig_image_size == target_image_size:
|
if orig_image_size == target_image_size:
|
||||||
return image
|
return image
|
||||||
|
|
||||||
scale_factors = target_image_size / orig_image_size
|
scale_factors = target_image_size / orig_image_size
|
||||||
return resize(image, scale_factors = scale_factors)
|
out = resize(image, scale_factors = scale_factors)
|
||||||
|
|
||||||
|
if exists(clamp_range):
|
||||||
|
out = out.clamp(*clamp_range)
|
||||||
|
|
||||||
|
return out
|
||||||
|
|
||||||
# image normalization functions
|
# image normalization functions
|
||||||
# ddpms expect images to be in the range of -1 to 1
|
# ddpms expect images to be in the range of -1 to 1
|
||||||
@@ -1778,9 +1783,12 @@ class LowresConditioner(nn.Module):
|
|||||||
downsample_first = True,
|
downsample_first = True,
|
||||||
blur_sigma = 0.6,
|
blur_sigma = 0.6,
|
||||||
blur_kernel_size = 3,
|
blur_kernel_size = 3,
|
||||||
|
input_image_range = None
|
||||||
):
|
):
|
||||||
super().__init__()
|
super().__init__()
|
||||||
self.downsample_first = downsample_first
|
self.downsample_first = downsample_first
|
||||||
|
self.input_image_range = input_image_range
|
||||||
|
|
||||||
self.blur_sigma = blur_sigma
|
self.blur_sigma = blur_sigma
|
||||||
self.blur_kernel_size = blur_kernel_size
|
self.blur_kernel_size = blur_kernel_size
|
||||||
|
|
||||||
@@ -1794,7 +1802,7 @@ class LowresConditioner(nn.Module):
|
|||||||
blur_kernel_size = None
|
blur_kernel_size = None
|
||||||
):
|
):
|
||||||
if self.training and self.downsample_first and exists(downsample_image_size):
|
if self.training and self.downsample_first and exists(downsample_image_size):
|
||||||
cond_fmap = resize_image_to(cond_fmap, downsample_image_size)
|
cond_fmap = resize_image_to(cond_fmap, downsample_image_size, clamp_range = self.input_image_range)
|
||||||
|
|
||||||
if self.training:
|
if self.training:
|
||||||
# when training, blur the low resolution conditional image
|
# when training, blur the low resolution conditional image
|
||||||
@@ -1814,7 +1822,7 @@ class LowresConditioner(nn.Module):
|
|||||||
|
|
||||||
cond_fmap = gaussian_blur2d(cond_fmap, cast_tuple(blur_kernel_size, 2), cast_tuple(blur_sigma, 2))
|
cond_fmap = gaussian_blur2d(cond_fmap, cast_tuple(blur_kernel_size, 2), cast_tuple(blur_sigma, 2))
|
||||||
|
|
||||||
cond_fmap = resize_image_to(cond_fmap, target_image_size)
|
cond_fmap = resize_image_to(cond_fmap, target_image_size, clamp_range = self.input_image_range)
|
||||||
|
|
||||||
return cond_fmap
|
return cond_fmap
|
||||||
|
|
||||||
@@ -1968,6 +1976,10 @@ class Decoder(nn.Module):
|
|||||||
|
|
||||||
self.predict_x_start = cast_tuple(predict_x_start, len(unets)) if not predict_x_start_for_latent_diffusion else tuple(map(lambda t: isinstance(t, VQGanVAE), self.vaes))
|
self.predict_x_start = cast_tuple(predict_x_start, len(unets)) if not predict_x_start_for_latent_diffusion else tuple(map(lambda t: isinstance(t, VQGanVAE), self.vaes))
|
||||||
|
|
||||||
|
# input image range
|
||||||
|
|
||||||
|
self.input_image_range = (-1. if not auto_normalize_img else 0., 1.)
|
||||||
|
|
||||||
# cascading ddpm related stuff
|
# cascading ddpm related stuff
|
||||||
|
|
||||||
lowres_conditions = tuple(map(lambda t: t.lowres_cond, self.unets))
|
lowres_conditions = tuple(map(lambda t: t.lowres_cond, self.unets))
|
||||||
@@ -1977,6 +1989,7 @@ class Decoder(nn.Module):
|
|||||||
downsample_first = lowres_downsample_first,
|
downsample_first = lowres_downsample_first,
|
||||||
blur_sigma = blur_sigma,
|
blur_sigma = blur_sigma,
|
||||||
blur_kernel_size = blur_kernel_size,
|
blur_kernel_size = blur_kernel_size,
|
||||||
|
input_image_range = self.input_image_range
|
||||||
)
|
)
|
||||||
|
|
||||||
# classifier free guidance
|
# classifier free guidance
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
__version__ = '0.16.15'
|
__version__ = '0.16.16'
|
||||||
|
|||||||
Reference in New Issue
Block a user