From 5f5f535dc0b954d2e346b61b05e235cc96506dc8 Mon Sep 17 00:00:00 2001 From: Brandon Rising Date: Fri, 23 Aug 2024 13:28:05 -0400 Subject: [PATCH] Load and unload clip/t5 encoders and run inference separately in text encoding --- invokeai/app/invocations/flux_text_encoder.py | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/invokeai/app/invocations/flux_text_encoder.py b/invokeai/app/invocations/flux_text_encoder.py index ae3456be06..80e13c2270 100644 --- a/invokeai/app/invocations/flux_text_encoder.py +++ b/invokeai/app/invocations/flux_text_encoder.py @@ -59,23 +59,28 @@ class FluxTextEncoderInvocation(BaseInvocation): t5_tokenizer_info = context.models.load(self.t5_encoder.tokenizer) t5_text_encoder_info = context.models.load(self.t5_encoder.text_encoder) + prompt = [self.prompt] + with ( - clip_text_encoder_info as clip_text_encoder, t5_text_encoder_info as t5_text_encoder, - clip_tokenizer_info as clip_tokenizer, t5_tokenizer_info as t5_tokenizer, ): - assert isinstance(clip_text_encoder, CLIPTextModel) assert isinstance(t5_text_encoder, T5EncoderModel) - assert isinstance(clip_tokenizer, CLIPTokenizer) assert isinstance(t5_tokenizer, T5Tokenizer) - clip_encoder = HFEncoder(clip_text_encoder, clip_tokenizer, True, 77) t5_encoder = HFEncoder(t5_text_encoder, t5_tokenizer, False, self.t5_max_seq_len) - prompt = [self.prompt] prompt_embeds = t5_encoder(prompt) + with ( + clip_text_encoder_info as clip_text_encoder, + clip_tokenizer_info as clip_tokenizer, + ): + assert isinstance(clip_text_encoder, CLIPTextModel) + assert isinstance(clip_tokenizer, CLIPTokenizer) + + clip_encoder = HFEncoder(clip_text_encoder, clip_tokenizer, True, 77) + pooled_prompt_embeds = clip_encoder(prompt) assert isinstance(prompt_embeds, torch.Tensor)