mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
Use the existence of initial latents to decide whether we are doing image-to-image in the FLUX denoising node. Previously we were using the denoising_start value, but in some cases with an inpaintin mask you may want to run image-to-image from densoising_start=0.
This commit is contained in:
parent
75d0558241
commit
480c62320c
@ -131,10 +131,14 @@ class FluxTextToImageInvocation(BaseInvocation, WithMetadata, WithBoard):
|
|||||||
)
|
)
|
||||||
|
|
||||||
# Prepare input latent image.
|
# Prepare input latent image.
|
||||||
if self.denoising_start > 1e-5:
|
if init_latents is not None:
|
||||||
# If denoising_start > 0, we are doing image-to-image.
|
# If init_latents is provided, we are doing image-to-image.
|
||||||
if init_latents is None:
|
|
||||||
raise ValueError("latents must be provided if denoising_start > 0.")
|
if is_schnell:
|
||||||
|
context.logger.warning(
|
||||||
|
"Running image-to-image with a FLUX schnell model. This is not recommended. The results are likely "
|
||||||
|
"to be poor. Consider using a FLUX dev model instead."
|
||||||
|
)
|
||||||
|
|
||||||
# Clip the timesteps schedule based on denoising_start.
|
# Clip the timesteps schedule based on denoising_start.
|
||||||
# TODO(ryand): Should we apply denoising_start in timestep-space rather than timestep-index-space?
|
# TODO(ryand): Should we apply denoising_start in timestep-space rather than timestep-index-space?
|
||||||
@ -145,7 +149,10 @@ class FluxTextToImageInvocation(BaseInvocation, WithMetadata, WithBoard):
|
|||||||
t_0 = timesteps[0]
|
t_0 = timesteps[0]
|
||||||
x = t_0 * noise + (1.0 - t_0) * init_latents
|
x = t_0 * noise + (1.0 - t_0) * init_latents
|
||||||
else:
|
else:
|
||||||
# We are not doing image-to-image, so start from noise.
|
# init_latents are not provided, so we are not doing image-to-image (i.e. we are starting from pure noise).
|
||||||
|
if self.denoising_start > 1e-5:
|
||||||
|
raise ValueError("denoising_start should be 0 when initial latents are not provided.")
|
||||||
|
|
||||||
x = noise
|
x = noise
|
||||||
|
|
||||||
inpaint_mask = self._prep_inpaint_mask(context, x)
|
inpaint_mask = self._prep_inpaint_mask(context, x)
|
||||||
|
Loading…
Reference in New Issue
Block a user