mirror of
https://github.com/lllyasviel/stable-diffusion-webui-forge.git
synced 2026-03-13 17:09:49 +00:00
link k-diffusion to backend
This commit is contained in:
@@ -38,6 +38,41 @@ class VDenoiser(nn.Module):
|
||||
return self.inner_model(input * c_in, self.sigma_to_t(sigma), **kwargs) * c_out + input * c_skip
|
||||
|
||||
|
||||
class ForgeScheduleLinker(nn.Module):
|
||||
def __init__(self, predictor):
|
||||
super().__init__()
|
||||
self.predictor = predictor
|
||||
|
||||
@property
|
||||
def sigmas(self):
|
||||
return self.predictor.sigmas
|
||||
|
||||
@property
|
||||
def log_sigmas(self):
|
||||
return self.predictor.sigmas.log()
|
||||
|
||||
@property
|
||||
def sigma_min(self):
|
||||
return self.predictor.sigma_min()
|
||||
|
||||
@property
|
||||
def sigma_max(self):
|
||||
return self.predictor.sigma_max()
|
||||
|
||||
def get_sigmas(self, n=None):
|
||||
if n is None:
|
||||
return sampling.append_zero(self.sigmas.flip(0))
|
||||
t_max = len(self.sigmas) - 1
|
||||
t = torch.linspace(t_max, 0, n, device=self.sigmas.device)
|
||||
return sampling.append_zero(self.t_to_sigma(t))
|
||||
|
||||
def sigma_to_t(self, sigma, quantize=None):
|
||||
return self.predictor.timestep(sigma)
|
||||
|
||||
def t_to_sigma(self, t):
|
||||
return self.predictor.sigma(t)
|
||||
|
||||
|
||||
class DiscreteSchedule(nn.Module):
|
||||
"""A mapping between continuous noise levels (sigmas) and a list of discrete noise
|
||||
levels."""
|
||||
|
||||
Reference in New Issue
Block a user