File size: 2,030 Bytes
c2ced9d |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
from .DiffAE_support_config import *
from .DiffAE_diffusion_diffusion import SpacedDiffusionBeatGans as Sampler
from .DiffAE_model_unet_autoenc import BeatGANsAutoencModel
from torch.cuda import amp
def render_uncondition(conf: TrainConfig,
model: BeatGANsAutoencModel,
x_T,
sampler: Sampler,
latent_sampler: Sampler,
conds_mean=None,
conds_std=None,
clip_latent_noise: bool = False):
device = x_T.device
if conf.train_mode == TrainMode.diffusion:
assert conf.model_type.can_sample()
return sampler.sample(model=model, noise=x_T)
elif conf.train_mode.is_latent_diffusion():
model: BeatGANsAutoencModel
if conf.train_mode == TrainMode.latent_diffusion:
latent_noise = torch.randn(len(x_T), conf.style_ch, device=device)
else:
raise NotImplementedError()
if clip_latent_noise:
latent_noise = latent_noise.clip(-1, 1)
cond = latent_sampler.sample(
model=model.latent_net,
noise=latent_noise,
clip_denoised=conf.latent_clip_sample,
)
if conf.latent_znormalize:
cond = cond * conds_std.to(device) + conds_mean.to(device)
# the diffusion on the model
return sampler.sample(model=model, noise=x_T, cond=cond)
else:
raise NotImplementedError()
def render_condition(
conf: TrainConfig,
model: BeatGANsAutoencModel,
x_T,
sampler: Sampler,
x_start=None,
cond=None,
):
if conf.train_mode == TrainMode.diffusion:
assert conf.model_type.has_autoenc()
# returns {'cond', 'cond2'}
if cond is None:
cond = model.encode(x_start)
return sampler.sample(model=model,
noise=x_T,
model_kwargs={'cond': cond})
else:
raise NotImplementedError()
|