Compare commits

...

3 Commits

Author SHA1 Message Date
Eric
20a700a9f1
Merge 1a864435f6 into 4209edf48d 2025-01-07 20:12:59 +08:00
Eric
1a864435f6
Update nodes_differential_diffusion.py 2024-11-21 23:43:17 -05:00
ThereforeGames
ce31337813 Update nodes_differential_diffusion.py 2024-11-21 21:02:49 -05:00

View File

@ -5,19 +5,27 @@ import torch
class DifferentialDiffusion(): class DifferentialDiffusion():
@classmethod @classmethod
def INPUT_TYPES(s): def INPUT_TYPES(s):
return {"required": {"model": ("MODEL", ), return {
}} "required": {
"model": ("MODEL", ),
"strength": ("FLOAT", {
"default": 1.0,
"min": 0.0,
"max": 1.0
}),
}
}
RETURN_TYPES = ("MODEL",) RETURN_TYPES = ("MODEL",)
FUNCTION = "apply" FUNCTION = "apply"
CATEGORY = "_for_testing" CATEGORY = "_for_testing"
INIT = False INIT = False
def apply(self, model): def apply(self, model, strength=1.0):
model = model.clone() model = model.clone()
model.set_model_denoise_mask_function(self.forward) model.set_model_denoise_mask_function(lambda *args, **kwargs: self.forward(*args, **kwargs, strength=strength))
return (model, ) return (model, )
def forward(self, sigma: torch.Tensor, denoise_mask: torch.Tensor, extra_options: dict): def forward(self, sigma: torch.Tensor, denoise_mask: torch.Tensor, extra_options: dict, strength: float):
model = extra_options["model"] model = extra_options["model"]
step_sigmas = extra_options["sigmas"] step_sigmas = extra_options["sigmas"]
sigma_to = model.inner_model.model_sampling.sigma_min sigma_to = model.inner_model.model_sampling.sigma_min
@ -31,7 +39,15 @@ class DifferentialDiffusion():
threshold = (current_ts - ts_to) / (ts_from - ts_to) threshold = (current_ts - ts_to) / (ts_from - ts_to)
return (denoise_mask >= threshold).to(denoise_mask.dtype) # Generate the binary mask based on the threshold
binary_mask = (denoise_mask >= threshold).to(denoise_mask.dtype)
# Blend binary mask with the original denoise_mask using strength
if strength and strength < 1:
blended_mask = strength * binary_mask + (1 - strength) * denoise_mask
return blended_mask
else:
return binary_mask
NODE_CLASS_MAPPINGS = { NODE_CLASS_MAPPINGS = {