From dcebd71381935a2ec5845c3685f48882c9af12d3 Mon Sep 17 00:00:00 2001 From: user1 Date: Wed, 17 May 2023 18:26:34 -0700 Subject: [PATCH] Extended node-based ControlNet support to LatentsToLatentsInvocation. --- invokeai/app/invocations/latent.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/invokeai/app/invocations/latent.py b/invokeai/app/invocations/latent.py index b07a406089..f9c9f2b30f 100644 --- a/invokeai/app/invocations/latent.py +++ b/invokeai/app/invocations/latent.py @@ -334,8 +334,8 @@ class TextToLatentsInvocation(BaseInvocation): noise=noise, num_inference_steps=self.steps, conditioning_data=conditioning_data, - callback=step_callback, control_data=control_data, # list[ControlNetData] + callback=step_callback, ) # https://discuss.huggingface.co/t/memory-usage-by-later-pipeline-stages/23699 @@ -380,6 +380,11 @@ class LatentsToLatentsInvocation(TextToLatentsInvocation): model = self.get_model(context.services.model_manager) conditioning_data = self.get_conditioning_data(context, model) + print("type of control input: ", type(self.control)) + control_data = self.prep_control_data(model=model, context=context, control_input=self.control, + latents_shape=noise.shape, + do_classifier_free_guidance=(self.cfg_scale >= 1.0)) + # TODO: Verify the noise is the right size initial_latents = latent if self.strength < 1.0 else torch.zeros_like( @@ -394,6 +399,7 @@ class LatentsToLatentsInvocation(TextToLatentsInvocation): noise=noise, num_inference_steps=self.steps, conditioning_data=conditioning_data, + control_data=control_data, # list[ControlNetData] callback=step_callback )