Add a way to control controlnet strength.

This commit is contained in:
comfyanonymous 2023-02-16 18:08:01 -05:00
parent 56498d505a
commit 6135a21ee8
2 changed files with 13 additions and 4 deletions

View File

@ -331,6 +331,7 @@ class ControlNet:
self.control_model = control_model self.control_model = control_model
self.cond_hint_original = None self.cond_hint_original = None
self.cond_hint = None self.cond_hint = None
self.strength = 1.0
def get_control(self, x_noisy, t, cond_txt): def get_control(self, x_noisy, t, cond_txt):
if self.cond_hint is None or x_noisy.shape[2] * 8 != self.cond_hint.shape[2] or x_noisy.shape[3] * 8 != self.cond_hint.shape[3]: if self.cond_hint is None or x_noisy.shape[2] * 8 != self.cond_hint.shape[2] or x_noisy.shape[3] * 8 != self.cond_hint.shape[3]:
@ -340,10 +341,13 @@ class ControlNet:
self.cond_hint = utils.common_upscale(self.cond_hint_original, x_noisy.shape[3] * 8, x_noisy.shape[2] * 8, 'nearest-exact', "center").to(x_noisy.device) self.cond_hint = utils.common_upscale(self.cond_hint_original, x_noisy.shape[3] * 8, x_noisy.shape[2] * 8, 'nearest-exact', "center").to(x_noisy.device)
print("set cond_hint", self.cond_hint.shape) print("set cond_hint", self.cond_hint.shape)
control = self.control_model(x=x_noisy, hint=self.cond_hint, timesteps=t, context=cond_txt) control = self.control_model(x=x_noisy, hint=self.cond_hint, timesteps=t, context=cond_txt)
for x in control:
x *= self.strength
return control return control
def set_cond_hint(self, cond_hint): def set_cond_hint(self, cond_hint, strength=1.0):
self.cond_hint_original = cond_hint self.cond_hint_original = cond_hint
self.strength = strength
return self return self
def cleanup(self): def cleanup(self):
@ -354,6 +358,7 @@ class ControlNet:
def copy(self): def copy(self):
c = ControlNet(self.control_model) c = ControlNet(self.control_model)
c.cond_hint_original = self.cond_hint_original c.cond_hint_original = self.cond_hint_original
c.strength = self.strength
return c return c
def load_controlnet(ckpt_path): def load_controlnet(ckpt_path):

View File

@ -234,19 +234,23 @@ class ControlNetLoader:
class ControlNetApply: class ControlNetApply:
@classmethod @classmethod
def INPUT_TYPES(s): def INPUT_TYPES(s):
return {"required": {"conditioning": ("CONDITIONING", ), "control_net": ("CONTROL_NET", ), "image": ("IMAGE", )}} return {"required": {"conditioning": ("CONDITIONING", ),
"control_net": ("CONTROL_NET", ),
"image": ("IMAGE", ),
"strength": ("FLOAT", {"default": 1.0, "min": 0.0, "max": 10.0, "step": 0.01})
}}
RETURN_TYPES = ("CONDITIONING",) RETURN_TYPES = ("CONDITIONING",)
FUNCTION = "apply_controlnet" FUNCTION = "apply_controlnet"
CATEGORY = "conditioning" CATEGORY = "conditioning"
def apply_controlnet(self, conditioning, control_net, image): def apply_controlnet(self, conditioning, control_net, image, strength):
c = [] c = []
control_hint = image.movedim(-1,1) control_hint = image.movedim(-1,1)
print(control_hint.shape) print(control_hint.shape)
for t in conditioning: for t in conditioning:
n = [t[0], t[1].copy()] n = [t[0], t[1].copy()]
n[1]['control'] = control_net.copy().set_cond_hint(control_hint) n[1]['control'] = control_net.copy().set_cond_hint(control_hint, strength)
c.append(n) c.append(n)
return (c, ) return (c, )