agentbot commited on
Commit
16e34a3
·
verified ·
1 Parent(s): e7fdcfc

Initial commit with folder contents

Browse files
Files changed (5) hide show
  1. .gitattributes +0 -5
  2. .gitmodules +4 -0
  3. pyproject.toml +4 -20
  4. src/pipeline.py +75 -958
  5. uv.lock +54 -331
.gitattributes CHANGED
@@ -33,8 +33,3 @@ saved_model/**/* filter=lfs diff=lfs merge=lfs -text
33
  *.zip filter=lfs diff=lfs merge=lfs -text
34
  *.zst filter=lfs diff=lfs merge=lfs -text
35
  *tfevents* filter=lfs diff=lfs merge=lfs -text
36
- cached_pipe/text_encoder filter=lfs diff=lfs merge=lfs -text
37
- cached_pipe/text_encoder_2 filter=lfs diff=lfs merge=lfs -text
38
- cached_pipe/vae.decoder filter=lfs diff=lfs merge=lfs -text
39
- cached_pipe/fast_unet filter=lfs diff=lfs merge=lfs -text
40
- cached_pipe/unet filter=lfs diff=lfs merge=lfs -text
 
33
  *.zip filter=lfs diff=lfs merge=lfs -text
34
  *.zst filter=lfs diff=lfs merge=lfs -text
35
  *tfevents* filter=lfs diff=lfs merge=lfs -text
 
 
 
 
 
.gitmodules ADDED
@@ -0,0 +1,4 @@
 
 
 
 
 
1
+ [submodule "newdream-sdxl-20"]
2
+ path = models/newdream-sdxl-20
3
+ url = https://huggingface.co/stablediffusionapi/newdream-sdxl-20
4
+ branch = main
pyproject.toml CHANGED
@@ -8,30 +8,14 @@ description = "An edge-maxxing model submission for the 4090 newdream contest"
8
  requires-python = ">=3.10,<3.11"
9
  version = "6"
10
  dependencies = [
11
- "diffusers==0.28.2",
12
- "onediff==1.2.0",
13
- "onediffx==1.2.0",
14
- "accelerate==0.31.0",
15
- "numpy==1.26.4",
16
- "xformers==0.0.25.post1",
17
- "triton==2.2.0",
18
  "transformers==4.41.2",
19
  "accelerate==0.31.0",
20
  "omegaconf==2.3.0",
21
- "torch==2.2.2",
22
- "torchvision==0.17.2",
23
- "huggingface-hub==0.25.2",
24
- "edge-maxxing-pipelines @ git+https://github.com/womboai/edge-maxxing#subdirectory=pipelines",
25
- "oneflow",
26
- "setuptools>=75.2.0",
27
- "bitsandbytes>=0.44.1",
28
- "stable-fast",
29
- "tomesd>=0.1.3",
30
  ]
31
 
32
- [tool.uv.sources]
33
- oneflow = { url = "https://github.com/siliconflow/oneflow_releases/releases/download/community_cu118/oneflow-0.9.1.dev20240802%2Bcu118-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl" }
34
- stable-fast = { url = "https://github.com/chengzeyi/stable-fast/releases/download/v1.0.5/stable_fast-1.0.5+torch222cu121-cp310-cp310-manylinux2014_x86_64.whl" }
35
-
36
  [project.scripts]
37
  start_inference = "main:main"
 
8
  requires-python = ">=3.10,<3.11"
9
  version = "6"
10
  dependencies = [
11
+ "diffusers==0.30.2",
 
 
 
 
 
 
12
  "transformers==4.41.2",
13
  "accelerate==0.31.0",
14
  "omegaconf==2.3.0",
15
+ "torch==2.4.1",
16
+ "edge-maxxing-pipelines @ git+https://github.com/womboai/edge-maxxing@8d8ff45863416484b5b4bc547782591bbdfc696a#subdirectory=pipelines",
17
+ "DeepCache",
 
 
 
 
 
 
18
  ]
19
 
 
 
 
 
20
  [project.scripts]
21
  start_inference = "main:main"
src/pipeline.py CHANGED
@@ -1,982 +1,99 @@
1
  import torch
2
- from PIL import Image
 
3
  from pipelines.models import TextToImageRequest
4
  from torch import Generator
5
- import json
6
- from diffusers import StableDiffusionXLPipeline, DDIMScheduler
7
- import inspect
8
- from typing import Any, Callable, Dict, List, Optional, Tuple, Union
9
- from loss import SchedulerWrapper
10
- from onediffx import compile_pipe,load_pipe
11
- # Import necessary components
12
- from transformers import (
13
- CLIPImageProcessor,
14
- CLIPTextModel,
15
- CLIPTextModelWithProjection,
16
- CLIPTokenizer,
17
- CLIPVisionModelWithProjection,
18
- )
19
 
 
 
 
 
 
 
 
20
 
21
- from diffusers.callbacks import MultiPipelineCallbacks, PipelineCallback
22
- from diffusers.image_processor import PipelineImageInput, VaeImageProcessor
23
- from diffusers.loaders import (
24
- FromSingleFileMixin,
25
- IPAdapterMixin,
26
- StableDiffusionXLLoraLoaderMixin,
27
- TextualInversionLoaderMixin,
28
- )
29
- from diffusers.models import AutoencoderKL, ImageProjection, UNet2DConditionModel
30
- from diffusers.models.attention_processor import (
31
- AttnProcessor2_0,
32
- FusedAttnProcessor2_0,
33
- XFormersAttnProcessor,
34
- )
35
- from diffusers.models.lora import adjust_lora_scale_text_encoder
36
- from diffusers.schedulers import KarrasDiffusionSchedulers
37
- from diffusers.utils import (
38
- USE_PEFT_BACKEND,
39
- deprecate,
40
- is_invisible_watermark_available,
41
- is_torch_xla_available,
42
- logging,
43
- replace_example_docstring,
44
- scale_lora_layers,
45
- unscale_lora_layers,
46
- )
47
- from diffusers.utils.torch_utils import randn_tensor
48
- from diffusers.pipelines.pipeline_utils import DiffusionPipeline, StableDiffusionMixin
49
- from diffusers.pipelines.stable_diffusion_xl.pipeline_output import StableDiffusionXLPipelineOutput
50
 
51
- # Import watermark if available
52
- if is_invisible_watermark_available():
53
- from .watermark import StableDiffusionXLWatermarker
54
 
55
- # Check for XLA availability
56
- if is_torch_xla_available():
57
- import torch_xla.core.xla_model as xm
58
- XLA_AVAILABLE = True
59
- else:
60
- XLA_AVAILABLE = False
61
-
62
- logger = logging.get_logger(__name__)
63
-
64
- # Constants
65
- EXAMPLE_DOC_STRING = """
66
- Examples:
67
- ```py
68
- >>> import torch
69
- >>> from diffusers import StableDiffusionXLPipeline
70
-
71
- >>> pipe = StableDiffusionXLPipeline.from_pretrained(
72
- >>> "stabilityai/stable-diffusion-xl-base-1.0",
73
- >>> torch_dtype=torch.float16
74
- >>> )
75
- >>> pipe = pipe.to("cuda")
76
-
77
- >>> prompt = "a photo of an astronaut riding a horse on mars"
78
- >>> image = pipe(prompt).images[0]
79
- ```
80
- """
81
-
82
- # Helper functions
83
- def rescale_noise_cfg(noise_cfg, noise_pred_text, guidance_rescale=0.0):
84
- """Rescale noise configuration."""
85
- std_text = noise_pred_text.std(dim=list(range(1, noise_pred_text.ndim)), keepdim=True)
86
- std_cfg = noise_cfg.std(dim=list(range(1, noise_cfg.ndim)), keepdim=True)
87
- noise_pred_rescaled = noise_cfg * (std_text / std_cfg)
88
- noise_cfg = guidance_rescale * noise_pred_rescaled + (1 - guidance_rescale) * noise_cfg
89
- return noise_cfg
90
-
91
- # Utils functions
92
- import numpy as np
93
- def max_pixel_filter(image: Image) -> Image:
94
- try:
95
- # Convert the image to a numpy array
96
- img_array = np.array(image)
97
- # Find the maximum pixel value in the image
98
- max_val = img_array.max()
99
- # Reduce the maximum value to 1
100
- img_array[img_array == max_val] -= 2
101
- # Convert the numpy array back to an image
102
- filtered_image = Image.fromarray(img_array)
103
- return filtered_image
104
- except:
105
- return image
106
 
107
- # Copied from diffusers.pipelines.stable_diffusion.pipeline_stable_diffusion.retrieve_timesteps
108
- def retrieve_timesteps(
109
- scheduler,
110
- num_inference_steps: Optional[int] = None,
111
- device: Optional[Union[str, torch.device]] = None,
112
- timesteps: Optional[List[int]] = None,
113
- sigmas: Optional[List[float]] = None,
114
- **kwargs,
115
- ):
116
- if timesteps is not None and sigmas is not None:
117
- raise ValueError("Only one of `timesteps` or `sigmas` can be passed. Please choose one to set custom values")
118
- if timesteps is not None:
119
- accepts_timesteps = "timesteps" in set(inspect.signature(scheduler.set_timesteps).parameters.keys())
120
- if not accepts_timesteps:
121
- raise ValueError(
122
- f"The current scheduler class {scheduler.__class__}'s `set_timesteps` does not support custom"
123
- f" timestep schedules. Please check whether you are using the correct scheduler."
124
- )
125
- scheduler.set_timesteps(timesteps=timesteps, device=device, **kwargs)
126
- timesteps = scheduler.timesteps
127
- num_inference_steps = len(timesteps)
128
- elif sigmas is not None:
129
- accept_sigmas = "sigmas" in set(inspect.signature(scheduler.set_timesteps).parameters.keys())
130
- if not accept_sigmas:
131
- raise ValueError(
132
- f"The current scheduler class {scheduler.__class__}'s `set_timesteps` does not support custom"
133
- f" sigmas schedules. Please check whether you are using the correct scheduler."
134
- )
135
- scheduler.set_timesteps(sigmas=sigmas, device=device, **kwargs)
136
- timesteps = scheduler.timesteps
137
- num_inference_steps = len(timesteps)
138
- else:
139
- scheduler.set_timesteps(num_inference_steps, device=device, **kwargs)
140
- timesteps = scheduler.timesteps
141
- return timesteps, num_inference_steps
142
-
143
-
144
- class StableDiffusionXLPipeline_new(
145
- DiffusionPipeline,
146
- StableDiffusionMixin,
147
- FromSingleFileMixin,
148
- StableDiffusionXLLoraLoaderMixin,
149
- TextualInversionLoaderMixin,
150
- IPAdapterMixin,
151
- ):
152
-
153
- model_cpu_offload_seq = "text_encoder->text_encoder_2->image_encoder->unet->vae"
154
- _optional_components = [
155
- "tokenizer",
156
- "tokenizer_2",
157
- "text_encoder",
158
- "text_encoder_2",
159
- "image_encoder",
160
- "feature_extractor",
161
- ]
162
- _callback_tensor_inputs = [
163
- "latents",
164
- "prompt_embeds",
165
- "negative_prompt_embeds",
166
- "add_text_embeds",
167
- "add_time_ids",
168
- "negative_pooled_prompt_embeds",
169
- "negative_add_time_ids",
170
- ]
171
-
172
- def __init__(
173
- self,
174
- vae: AutoencoderKL,
175
- text_encoder: CLIPTextModel,
176
- text_encoder_2: CLIPTextModelWithProjection,
177
- tokenizer: CLIPTokenizer,
178
- tokenizer_2: CLIPTokenizer,
179
- unet: UNet2DConditionModel,
180
- scheduler: KarrasDiffusionSchedulers,
181
- image_encoder: CLIPVisionModelWithProjection = None,
182
- feature_extractor: CLIPImageProcessor = None,
183
- force_zeros_for_empty_prompt: bool = True,
184
- add_watermarker: Optional[bool] = None,
185
- ):
186
- super().__init__()
187
-
188
- self.register_modules(
189
- vae=vae,
190
- text_encoder=text_encoder,
191
- text_encoder_2=text_encoder_2,
192
- tokenizer=tokenizer,
193
- tokenizer_2=tokenizer_2,
194
- unet=unet,
195
- scheduler=scheduler,
196
- image_encoder=image_encoder,
197
- feature_extractor=feature_extractor,
198
- )
199
- self.register_to_config(force_zeros_for_empty_prompt=force_zeros_for_empty_prompt)
200
- self.vae_scale_factor = 2 ** (len(self.vae.config.block_out_channels) - 1)
201
- self.image_processor = VaeImageProcessor(vae_scale_factor=self.vae_scale_factor)
202
-
203
- self.default_sample_size = self.unet.config.sample_size
204
-
205
- add_watermarker = add_watermarker if add_watermarker is not None else is_invisible_watermark_available()
206
-
207
- if add_watermarker:
208
- self.watermark = StableDiffusionXLWatermarker()
209
- else:
210
- self.watermark = None
211
-
212
- def encode_prompt(
213
- self,
214
- prompt: str,
215
- prompt_2: Optional[str] = None,
216
- device: Optional[torch.device] = None,
217
- num_images_per_prompt: int = 1,
218
- do_classifier_free_guidance: bool = True,
219
- negative_prompt: Optional[str] = None,
220
- negative_prompt_2: Optional[str] = None,
221
- prompt_embeds: Optional[torch.Tensor] = None,
222
- negative_prompt_embeds: Optional[torch.Tensor] = None,
223
- pooled_prompt_embeds: Optional[torch.Tensor] = None,
224
- negative_pooled_prompt_embeds: Optional[torch.Tensor] = None,
225
- lora_scale: Optional[float] = None,
226
- clip_skip: Optional[int] = None,
227
- ):
228
- device = device or self._execution_device
229
-
230
- # set lora scale so that monkey patched LoRA
231
- # function of text encoder can correctly access it
232
- if lora_scale is not None and isinstance(self, StableDiffusionXLLoraLoaderMixin):
233
- self._lora_scale = lora_scale
234
-
235
- # dynamically adjust the LoRA scale
236
- if self.text_encoder is not None:
237
- if not USE_PEFT_BACKEND:
238
- adjust_lora_scale_text_encoder(self.text_encoder, lora_scale)
239
- else:
240
- scale_lora_layers(self.text_encoder, lora_scale)
241
-
242
- if self.text_encoder_2 is not None:
243
- if not USE_PEFT_BACKEND:
244
- adjust_lora_scale_text_encoder(self.text_encoder_2, lora_scale)
245
- else:
246
- scale_lora_layers(self.text_encoder_2, lora_scale)
247
-
248
- prompt = [prompt] if isinstance(prompt, str) else prompt
249
-
250
- if prompt is not None:
251
- batch_size = len(prompt)
252
- else:
253
- batch_size = prompt_embeds.shape[0]
254
-
255
- # Define tokenizers and text encoders
256
- tokenizers = [self.tokenizer, self.tokenizer_2] if self.tokenizer is not None else [self.tokenizer_2]
257
- text_encoders = (
258
- [self.text_encoder, self.text_encoder_2] if self.text_encoder is not None else [self.text_encoder_2]
259
- )
260
-
261
- if prompt_embeds is None:
262
- prompt_2 = prompt_2 or prompt
263
- prompt_2 = [prompt_2] if isinstance(prompt_2, str) else prompt_2
264
-
265
- # textual inversion: process multi-vector tokens if necessary
266
- prompt_embeds_list = []
267
- prompts = [prompt, prompt_2]
268
- for prompt, tokenizer, text_encoder in zip(prompts, tokenizers, text_encoders):
269
- if isinstance(self, TextualInversionLoaderMixin):
270
- prompt = self.maybe_convert_prompt(prompt, tokenizer)
271
-
272
- text_inputs = tokenizer(
273
- prompt,
274
- padding="max_length",
275
- max_length=tokenizer.model_max_length,
276
- truncation=True,
277
- return_tensors="pt",
278
- )
279
-
280
- text_input_ids = text_inputs.input_ids
281
- untruncated_ids = tokenizer(prompt, padding="longest", return_tensors="pt").input_ids
282
-
283
- if untruncated_ids.shape[-1] >= text_input_ids.shape[-1] and not torch.equal(
284
- text_input_ids, untruncated_ids
285
- ):
286
- removed_text = tokenizer.batch_decode(untruncated_ids[:, tokenizer.model_max_length - 1 : -1])
287
- logger.warning(
288
- "The following part of your input was truncated because CLIP can only handle sequences up to"
289
- f" {tokenizer.model_max_length} tokens: {removed_text}"
290
- )
291
-
292
- prompt_embeds = text_encoder(text_input_ids.to(device), output_hidden_states=True)
293
-
294
- # We are only ALWAYS interested in the pooled output of the final text encoder
295
- pooled_prompt_embeds = prompt_embeds[0]
296
- if clip_skip is None:
297
- prompt_embeds = prompt_embeds.hidden_states[-2]
298
- else:
299
- # "2" because SDXL always indexes from the penultimate layer.
300
- prompt_embeds = prompt_embeds.hidden_states[-(clip_skip + 2)]
301
-
302
- prompt_embeds_list.append(prompt_embeds)
303
-
304
- prompt_embeds = torch.concat(prompt_embeds_list, dim=-1)
305
-
306
- # get unconditional embeddings for classifier free guidance
307
- zero_out_negative_prompt = negative_prompt is None and self.config.force_zeros_for_empty_prompt
308
- if do_classifier_free_guidance and negative_prompt_embeds is None and zero_out_negative_prompt:
309
- negative_prompt_embeds = torch.zeros_like(prompt_embeds)
310
- negative_pooled_prompt_embeds = torch.zeros_like(pooled_prompt_embeds)
311
- elif do_classifier_free_guidance and negative_prompt_embeds is None:
312
- negative_prompt = negative_prompt or ""
313
- negative_prompt_2 = negative_prompt_2 or negative_prompt
314
-
315
- # normalize str to list
316
- negative_prompt = batch_size * [negative_prompt] if isinstance(negative_prompt, str) else negative_prompt
317
- negative_prompt_2 = (
318
- batch_size * [negative_prompt_2] if isinstance(negative_prompt_2, str) else negative_prompt_2
319
- )
320
-
321
- uncond_tokens: List[str]
322
- if prompt is not None and type(prompt) is not type(negative_prompt):
323
- raise TypeError(
324
- f"`negative_prompt` should be the same type to `prompt`, but got {type(negative_prompt)} !="
325
- f" {type(prompt)}."
326
- )
327
- elif batch_size != len(negative_prompt):
328
- raise ValueError(
329
- f"`negative_prompt`: {negative_prompt} has batch size {len(negative_prompt)}, but `prompt`:"
330
- f" {prompt} has batch size {batch_size}. Please make sure that passed `negative_prompt` matches"
331
- " the batch size of `prompt`."
332
- )
333
- else:
334
- uncond_tokens = [negative_prompt, negative_prompt_2]
335
-
336
- negative_prompt_embeds_list = []
337
- for negative_prompt, tokenizer, text_encoder in zip(uncond_tokens, tokenizers, text_encoders):
338
- if isinstance(self, TextualInversionLoaderMixin):
339
- negative_prompt = self.maybe_convert_prompt(negative_prompt, tokenizer)
340
-
341
- max_length = prompt_embeds.shape[1]
342
- uncond_input = tokenizer(
343
- negative_prompt,
344
- padding="max_length",
345
- max_length=max_length,
346
- truncation=True,
347
- return_tensors="pt",
348
- )
349
-
350
- negative_prompt_embeds = text_encoder(
351
- uncond_input.input_ids.to(device),
352
- output_hidden_states=True,
353
- )
354
- # We are only ALWAYS interested in the pooled output of the final text encoder
355
- negative_pooled_prompt_embeds = negative_prompt_embeds[0]
356
- negative_prompt_embeds = negative_prompt_embeds.hidden_states[-2]
357
-
358
- negative_prompt_embeds_list.append(negative_prompt_embeds)
359
-
360
- negative_prompt_embeds = torch.concat(negative_prompt_embeds_list, dim=-1)
361
-
362
- if self.text_encoder_2 is not None:
363
- prompt_embeds = prompt_embeds.to(dtype=self.text_encoder_2.dtype, device=device)
364
- else:
365
- prompt_embeds = prompt_embeds.to(dtype=self.unet.dtype, device=device)
366
-
367
- bs_embed, seq_len, _ = prompt_embeds.shape
368
- # duplicate text embeddings for each generation per prompt, using mps friendly method
369
- prompt_embeds = prompt_embeds.repeat(1, num_images_per_prompt, 1)
370
- prompt_embeds = prompt_embeds.view(bs_embed * num_images_per_prompt, seq_len, -1)
371
-
372
- if do_classifier_free_guidance:
373
- # duplicate unconditional embeddings for each generation per prompt, using mps friendly method
374
- seq_len = negative_prompt_embeds.shape[1]
375
-
376
- if self.text_encoder_2 is not None:
377
- negative_prompt_embeds = negative_prompt_embeds.to(dtype=self.text_encoder_2.dtype, device=device)
378
- else:
379
- negative_prompt_embeds = negative_prompt_embeds.to(dtype=self.unet.dtype, device=device)
380
-
381
- negative_prompt_embeds = negative_prompt_embeds.repeat(1, num_images_per_prompt, 1)
382
- negative_prompt_embeds = negative_prompt_embeds.view(batch_size * num_images_per_prompt, seq_len, -1)
383
-
384
- pooled_prompt_embeds = pooled_prompt_embeds.repeat(1, num_images_per_prompt).view(
385
- bs_embed * num_images_per_prompt, -1
386
- )
387
- if do_classifier_free_guidance:
388
- negative_pooled_prompt_embeds = negative_pooled_prompt_embeds.repeat(1, num_images_per_prompt).view(
389
- bs_embed * num_images_per_prompt, -1
390
- )
391
-
392
- if self.text_encoder is not None:
393
- if isinstance(self, StableDiffusionXLLoraLoaderMixin) and USE_PEFT_BACKEND:
394
- # Retrieve the original scale by scaling back the LoRA layers
395
- unscale_lora_layers(self.text_encoder, lora_scale)
396
-
397
- if self.text_encoder_2 is not None:
398
- if isinstance(self, StableDiffusionXLLoraLoaderMixin) and USE_PEFT_BACKEND:
399
- # Retrieve the original scale by scaling back the LoRA layers
400
- unscale_lora_layers(self.text_encoder_2, lora_scale)
401
-
402
- return prompt_embeds, negative_prompt_embeds, pooled_prompt_embeds, negative_pooled_prompt_embeds
403
-
404
- # Copied from diffusers.pipelines.stable_diffusion.pipeline_stable_diffusion.StableDiffusionPipeline.encode_image
405
- def encode_image(self, image, device, num_images_per_prompt, output_hidden_states=None):
406
- dtype = next(self.image_encoder.parameters()).dtype
407
-
408
- if not isinstance(image, torch.Tensor):
409
- image = self.feature_extractor(image, return_tensors="pt").pixel_values
410
-
411
- image = image.to(device=device, dtype=dtype)
412
- if output_hidden_states:
413
- image_enc_hidden_states = self.image_encoder(image, output_hidden_states=True).hidden_states[-2]
414
- image_enc_hidden_states = image_enc_hidden_states.repeat_interleave(num_images_per_prompt, dim=0)
415
- uncond_image_enc_hidden_states = self.image_encoder(
416
- torch.zeros_like(image), output_hidden_states=True
417
- ).hidden_states[-2]
418
- uncond_image_enc_hidden_states = uncond_image_enc_hidden_states.repeat_interleave(
419
- num_images_per_prompt, dim=0
420
- )
421
- return image_enc_hidden_states, uncond_image_enc_hidden_states
422
- else:
423
- image_embeds = self.image_encoder(image).image_embeds
424
- image_embeds = image_embeds.repeat_interleave(num_images_per_prompt, dim=0)
425
- uncond_image_embeds = torch.zeros_like(image_embeds)
426
-
427
- return image_embeds, uncond_image_embeds
428
-
429
- # Copied from diffusers.pipelines.stable_diffusion.pipeline_stable_diffusion.StableDiffusionPipeline.prepare_ip_adapter_image_embeds
430
- def prepare_ip_adapter_image_embeds(
431
- self, ip_adapter_image, ip_adapter_image_embeds, device, num_images_per_prompt, do_classifier_free_guidance
432
- ):
433
- image_embeds = []
434
- if do_classifier_free_guidance:
435
- negative_image_embeds = []
436
- if ip_adapter_image_embeds is None:
437
- if not isinstance(ip_adapter_image, list):
438
- ip_adapter_image = [ip_adapter_image]
439
-
440
- if len(ip_adapter_image) != len(self.unet.encoder_hid_proj.image_projection_layers):
441
- raise ValueError(
442
- f"`ip_adapter_image` must have same length as the number of IP Adapters. Got {len(ip_adapter_image)} images and {len(self.unet.encoder_hid_proj.image_projection_layers)} IP Adapters."
443
- )
444
-
445
- for single_ip_adapter_image, image_proj_layer in zip(
446
- ip_adapter_image, self.unet.encoder_hid_proj.image_projection_layers
447
- ):
448
- output_hidden_state = not isinstance(image_proj_layer, ImageProjection)
449
- single_image_embeds, single_negative_image_embeds = self.encode_image(
450
- single_ip_adapter_image, device, 1, output_hidden_state
451
- )
452
-
453
- image_embeds.append(single_image_embeds[None, :])
454
- if do_classifier_free_guidance:
455
- negative_image_embeds.append(single_negative_image_embeds[None, :])
456
- else:
457
- for single_image_embeds in ip_adapter_image_embeds:
458
- if do_classifier_free_guidance:
459
- single_negative_image_embeds, single_image_embeds = single_image_embeds.chunk(2)
460
- negative_image_embeds.append(single_negative_image_embeds)
461
- image_embeds.append(single_image_embeds)
462
-
463
- ip_adapter_image_embeds = []
464
- for i, single_image_embeds in enumerate(image_embeds):
465
- single_image_embeds = torch.cat([single_image_embeds] * num_images_per_prompt, dim=0)
466
- if do_classifier_free_guidance:
467
- single_negative_image_embeds = torch.cat([negative_image_embeds[i]] * num_images_per_prompt, dim=0)
468
- single_image_embeds = torch.cat([single_negative_image_embeds, single_image_embeds], dim=0)
469
-
470
- single_image_embeds = single_image_embeds.to(device=device)
471
- ip_adapter_image_embeds.append(single_image_embeds)
472
-
473
- return ip_adapter_image_embeds
474
-
475
- # Copied from diffusers.pipelines.stable_diffusion.pipeline_stable_diffusion.StableDiffusionPipeline.prepare_extra_step_kwargs
476
- def prepare_extra_step_kwargs(self, generator, eta):
477
- # prepare extra kwargs for the scheduler step, since not all schedulers have the same signature
478
- # eta (η) is only used with the DDIMScheduler, it will be ignored for other schedulers.
479
- # eta corresponds to η in DDIM paper: https://arxiv.org/abs/2010.02502
480
- # and should be between [0, 1]
481
-
482
- accepts_eta = "eta" in set(inspect.signature(self.scheduler.step).parameters.keys())
483
- extra_step_kwargs = {}
484
- if accepts_eta:
485
- extra_step_kwargs["eta"] = eta
486
-
487
- # check if the scheduler accepts generator
488
- accepts_generator = "generator" in set(inspect.signature(self.scheduler.step).parameters.keys())
489
- if accepts_generator:
490
- extra_step_kwargs["generator"] = generator
491
- return extra_step_kwargs
492
-
493
- # Copied from diffusers.pipelines.stable_diffusion.pipeline_stable_diffusion.StableDiffusionPipeline.prepare_latents
494
- def prepare_latents(self, batch_size, num_channels_latents, height, width, dtype, device, generator, latents=None):
495
- shape = (
496
- batch_size,
497
- num_channels_latents,
498
- int(height) // self.vae_scale_factor,
499
- int(width) // self.vae_scale_factor,
500
- )
501
- if isinstance(generator, list) and len(generator) != batch_size:
502
- raise ValueError(
503
- f"You have passed a list of generators of length {len(generator)}, but requested an effective batch"
504
- f" size of {batch_size}. Make sure the batch size matches the length of the generators."
505
- )
506
-
507
- if latents is None:
508
- latents = randn_tensor(shape, generator=generator, device=device, dtype=dtype)
509
- else:
510
- latents = latents.to(device)
511
-
512
- # scale the initial noise by the standard deviation required by the scheduler
513
- latents = latents * self.scheduler.init_noise_sigma
514
- return latents
515
-
516
- def _get_add_time_ids(
517
- self, original_size, crops_coords_top_left, target_size, dtype, text_encoder_projection_dim=None
518
- ):
519
- add_time_ids = list(original_size + crops_coords_top_left + target_size)
520
-
521
- passed_add_embed_dim = (
522
- self.unet.config.addition_time_embed_dim * len(add_time_ids) + text_encoder_projection_dim
523
- )
524
- expected_add_embed_dim = self.unet.add_embedding.linear_1.in_features
525
-
526
- if expected_add_embed_dim != passed_add_embed_dim:
527
- raise ValueError(
528
- f"Model expects an added time embedding vector of length {expected_add_embed_dim}, but a vector of {passed_add_embed_dim} was created. The model has an incorrect config. Please check `unet.config.time_embedding_type` and `text_encoder_2.config.projection_dim`."
529
- )
530
 
531
- add_time_ids = torch.tensor([add_time_ids], dtype=dtype)
532
- return add_time_ids
533
-
534
- def upcast_vae(self):
535
- dtype = self.vae.dtype
536
- self.vae.to(dtype=torch.float32)
537
- use_torch_2_0_or_xformers = isinstance(
538
- self.vae.decoder.mid_block.attentions[0].processor,
539
- (
540
- AttnProcessor2_0,
541
- XFormersAttnProcessor,
542
- FusedAttnProcessor2_0,
543
- ),
544
- )
545
- # if xformers or torch_2_0 is used attention block does not need
546
- # to be in float32 which can save lots of memory
547
- if use_torch_2_0_or_xformers:
548
- self.vae.post_quant_conv.to(dtype)
549
- self.vae.decoder.conv_in.to(dtype)
550
- self.vae.decoder.mid_block.to(dtype)
551
-
552
- # Copied from diffusers.pipelines.latent_consistency_models.pipeline_latent_consistency_text2img.LatentConsistencyModelPipeline.get_guidance_scale_embedding
553
- def get_guidance_scale_embedding(
554
- self, w: torch.Tensor, embedding_dim: int = 512, dtype: torch.dtype = torch.float32
555
- ) -> torch.Tensor:
556
- """
557
- See https://github.com/google-research/vdm/blob/dc27b98a554f65cdc654b800da5aa1846545d41b/model_vdm.py#L298
558
-
559
- Args:
560
- w (`torch.Tensor`):
561
- Generate embedding vectors with a specified guidance scale to subsequently enrich timestep embeddings.
562
- embedding_dim (`int`, *optional*, defaults to 512):
563
- Dimension of the embeddings to generate.
564
- dtype (`torch.dtype`, *optional*, defaults to `torch.float32`):
565
- Data type of the generated embeddings.
566
-
567
- Returns:
568
- `torch.Tensor`: Embedding vectors with shape `(len(w), embedding_dim)`.
569
- """
570
- assert len(w.shape) == 1
571
- w = w * 1000.0
572
-
573
- half_dim = embedding_dim // 2
574
- emb = torch.log(torch.tensor(10000.0)) / (half_dim - 1)
575
- emb = torch.exp(torch.arange(half_dim, dtype=dtype) * -emb)
576
- emb = w.to(dtype)[:, None] * emb[None, :]
577
- emb = torch.cat([torch.sin(emb), torch.cos(emb)], dim=1)
578
- if embedding_dim % 2 == 1: # zero pad
579
- emb = torch.nn.functional.pad(emb, (0, 1))
580
- assert emb.shape == (w.shape[0], embedding_dim)
581
- return emb
582
-
583
- @property
584
- def guidance_scale(self):
585
- return self._guidance_scale
586
-
587
- @property
588
- def guidance_rescale(self):
589
- return self._guidance_rescale
590
-
591
- @property
592
- def clip_skip(self):
593
- return self._clip_skip
594
-
595
- # here `guidance_scale` is defined analog to the guidance weight `w` of equation (2)
596
- # of the Imagen paper: https://arxiv.org/pdf/2205.11487.pdf . `guidance_scale = 1`
597
- # corresponds to doing no classifier free guidance.
598
- @property
599
- def do_classifier_free_guidance(self):
600
- return self._guidance_scale > 1 and self.unet.config.time_cond_proj_dim is None
601
-
602
- @property
603
- def cross_attention_kwargs(self):
604
- return self._cross_attention_kwargs
605
-
606
- @property
607
- def denoising_end(self):
608
- return self._denoising_end
609
-
610
- @property
611
- def num_timesteps(self):
612
- return self._num_timesteps
613
-
614
- @property
615
- def interrupt(self):
616
- return self._interrupt
617
-
618
- @torch.no_grad()
619
- def __call__(
620
- self,
621
- prompt: Union[str, List[str]] = None,
622
- prompt_2: Optional[Union[str, List[str]]] = None,
623
- height: Optional[int] = None,
624
- width: Optional[int] = None,
625
- num_inference_steps: int = 50,
626
- timesteps: List[int] = None,
627
- sigmas: List[float] = None,
628
- denoising_end: Optional[float] = None,
629
- guidance_scale: float = 5.0,
630
- negative_prompt: Optional[Union[str, List[str]]] = None,
631
- negative_prompt_2: Optional[Union[str, List[str]]] = None,
632
- num_images_per_prompt: Optional[int] = 1,
633
- eta: float = 0.0,
634
- generator: Optional[Union[torch.Generator, List[torch.Generator]]] = None,
635
- latents: Optional[torch.Tensor] = None,
636
- prompt_embeds: Optional[torch.Tensor] = None,
637
- negative_prompt_embeds: Optional[torch.Tensor] = None,
638
- pooled_prompt_embeds: Optional[torch.Tensor] = None,
639
- negative_pooled_prompt_embeds: Optional[torch.Tensor] = None,
640
- ip_adapter_image: Optional[PipelineImageInput] = None,
641
- ip_adapter_image_embeds: Optional[List[torch.Tensor]] = None,
642
- output_type: Optional[str] = "pil",
643
- return_dict: bool = True,
644
- cross_attention_kwargs: Optional[Dict[str, Any]] = None,
645
- guidance_rescale: float = 0.0,
646
- end_cfg: float = 0.9,
647
- original_size: Optional[Tuple[int, int]] = None,
648
- crops_coords_top_left: Tuple[int, int] = (0, 0),
649
- target_size: Optional[Tuple[int, int]] = None,
650
- negative_original_size: Optional[Tuple[int, int]] = None,
651
- negative_crops_coords_top_left: Tuple[int, int] = (0, 0),
652
- negative_target_size: Optional[Tuple[int, int]] = None,
653
- clip_skip: Optional[int] = None,
654
- callback_on_step_end: Optional[
655
- Union[Callable[[int, int, Dict], None], PipelineCallback, MultiPipelineCallbacks]
656
- ] = None,
657
- callback_on_step_end_tensor_inputs: List[str] = ["latents"],
658
- **kwargs,
659
- ):
660
- callback = kwargs.pop("callback", None)
661
- callback_steps = kwargs.pop("callback_steps", None)
662
-
663
- if callback is not None:
664
- deprecate(
665
- "callback",
666
- "1.0.0",
667
- "Passing `callback` as an input argument to `__call__` is deprecated, consider use `callback_on_step_end`",
668
- )
669
- if callback_steps is not None:
670
- deprecate(
671
- "callback_steps",
672
- "1.0.0",
673
- "Passing `callback_steps` as an input argument to `__call__` is deprecated, consider use `callback_on_step_end`",
674
- )
675
-
676
- if isinstance(callback_on_step_end, (PipelineCallback, MultiPipelineCallbacks)):
677
- callback_on_step_end_tensor_inputs = callback_on_step_end.tensor_inputs
678
-
679
- # 0. Default height and width to unet
680
- height = height or self.default_sample_size * self.vae_scale_factor
681
- width = width or self.default_sample_size * self.vae_scale_factor
682
-
683
- original_size = original_size or (height, width)
684
- target_size = target_size or (height, width)
685
-
686
- self._guidance_scale = guidance_scale
687
- self._guidance_rescale = guidance_rescale
688
- self._clip_skip = clip_skip
689
- self._cross_attention_kwargs = cross_attention_kwargs
690
- self._denoising_end = denoising_end
691
- self._interrupt = False
692
-
693
- # 2. Define call parameters
694
- if prompt is not None and isinstance(prompt, str):
695
- batch_size = 1
696
- elif prompt is not None and isinstance(prompt, list):
697
- batch_size = len(prompt)
698
- else:
699
- batch_size = prompt_embeds.shape[0]
700
-
701
- device = self._execution_device
702
-
703
- # 3. Encode input prompt
704
- lora_scale = (
705
- self.cross_attention_kwargs.get("scale", None) if self.cross_attention_kwargs is not None else None
706
- )
707
-
708
- (
709
- prompt_embeds,
710
- negative_prompt_embeds,
711
- pooled_prompt_embeds,
712
- negative_pooled_prompt_embeds,
713
- ) = self.encode_prompt(
714
- prompt=prompt,
715
- prompt_2=prompt_2,
716
- device=device,
717
- num_images_per_prompt=num_images_per_prompt,
718
- do_classifier_free_guidance=self.do_classifier_free_guidance,
719
- negative_prompt=negative_prompt,
720
- negative_prompt_2=negative_prompt_2,
721
- prompt_embeds=prompt_embeds,
722
- negative_prompt_embeds=negative_prompt_embeds,
723
- pooled_prompt_embeds=pooled_prompt_embeds,
724
- negative_pooled_prompt_embeds=negative_pooled_prompt_embeds,
725
- lora_scale=lora_scale,
726
- clip_skip=self.clip_skip,
727
- )
728
-
729
- # 4. Prepare timesteps
730
- timesteps, num_inference_steps = retrieve_timesteps(
731
- self.scheduler, num_inference_steps, device, timesteps, sigmas
732
- )
733
-
734
- # 5. Prepare latent variables
735
- num_channels_latents = self.unet.config.in_channels
736
- latents = self.prepare_latents(
737
- batch_size * num_images_per_prompt,
738
- num_channels_latents,
739
- height,
740
- width,
741
- prompt_embeds.dtype,
742
- device,
743
- generator,
744
- latents,
745
- )
746
-
747
- # 6. Prepare extra step kwargs. TODO: Logic should ideally just be moved out of the pipeline
748
- extra_step_kwargs = self.prepare_extra_step_kwargs(generator, eta)
749
-
750
- # 7. Prepare added time ids & embeddings
751
- add_text_embeds = pooled_prompt_embeds
752
- if self.text_encoder_2 is None:
753
- text_encoder_projection_dim = int(pooled_prompt_embeds.shape[-1])
754
- else:
755
- text_encoder_projection_dim = self.text_encoder_2.config.projection_dim
756
-
757
- add_time_ids = self._get_add_time_ids(
758
- original_size,
759
- crops_coords_top_left,
760
- target_size,
761
- dtype=prompt_embeds.dtype,
762
- text_encoder_projection_dim=text_encoder_projection_dim,
763
- )
764
- if negative_original_size is not None and negative_target_size is not None:
765
- negative_add_time_ids = self._get_add_time_ids(
766
- negative_original_size,
767
- negative_crops_coords_top_left,
768
- negative_target_size,
769
- dtype=prompt_embeds.dtype,
770
- text_encoder_projection_dim=text_encoder_projection_dim,
771
- )
772
- else:
773
- negative_add_time_ids = add_time_ids
774
-
775
- if self.do_classifier_free_guidance:
776
- prompt_embeds = torch.cat([negative_prompt_embeds, prompt_embeds], dim=0)
777
- add_text_embeds = torch.cat([negative_pooled_prompt_embeds, add_text_embeds], dim=0)
778
- add_time_ids = torch.cat([negative_add_time_ids, add_time_ids], dim=0)
779
-
780
- prompt_embeds = prompt_embeds.to(device)
781
- add_text_embeds = add_text_embeds.to(device)
782
- add_time_ids = add_time_ids.to(device).repeat(batch_size * num_images_per_prompt, 1)
783
-
784
- if ip_adapter_image is not None or ip_adapter_image_embeds is not None:
785
- image_embeds = self.prepare_ip_adapter_image_embeds(
786
- ip_adapter_image,
787
- ip_adapter_image_embeds,
788
- device,
789
- batch_size * num_images_per_prompt,
790
- self.do_classifier_free_guidance,
791
- )
792
-
793
- # 8. Denoising loop
794
- num_warmup_steps = max(len(timesteps) - num_inference_steps * self.scheduler.order, 0)
795
-
796
- # 8.1 Apply denoising_end
797
- if (
798
- self.denoising_end is not None
799
- and isinstance(self.denoising_end, float)
800
- and self.denoising_end > 0
801
- and self.denoising_end < 1
802
- ):
803
- discrete_timestep_cutoff = int(
804
- round(
805
- self.scheduler.config.num_train_timesteps
806
- - (self.denoising_end * self.scheduler.config.num_train_timesteps)
807
- )
808
- )
809
- num_inference_steps = len(list(filter(lambda ts: ts >= discrete_timestep_cutoff, timesteps)))
810
- timesteps = timesteps[:num_inference_steps]
811
-
812
- # 9. Optionally get Guidance Scale Embedding
813
- timestep_cond = None
814
- if self.unet.config.time_cond_proj_dim is not None:
815
- guidance_scale_tensor = torch.tensor(self.guidance_scale - 1).repeat(batch_size * num_images_per_prompt)
816
- timestep_cond = self.get_guidance_scale_embedding(
817
- guidance_scale_tensor, embedding_dim=self.unet.config.time_cond_proj_dim
818
- ).to(device=device, dtype=latents.dtype)
819
-
820
- self._num_timesteps = len(timesteps)
821
- with self.progress_bar(total=num_inference_steps) as progress_bar:
822
- do_classifier_free_guidance = self.do_classifier_free_guidance
823
- for i, t in enumerate(timesteps):
824
- if self.interrupt:
825
- continue
826
- if end_cfg is not None and i / num_inference_steps > end_cfg and do_classifier_free_guidance:
827
- do_classifier_free_guidance = False
828
- prompt_embeds = 1.5*torch.chunk(prompt_embeds, 2, dim=0)[-1]
829
- add_text_embeds = 1.5*torch.chunk(add_text_embeds, 2, dim=0)[-1]
830
- add_time_ids = 1.25*torch.chunk(add_time_ids, 2, dim=0)[-1]
831
- # expand the latents if we are doing classifier free guidance
832
- latent_model_input = torch.cat([latents] * 2) if do_classifier_free_guidance else latents
833
-
834
- latent_model_input = self.scheduler.scale_model_input(latent_model_input, t)
835
-
836
- # predict the noise residual
837
- added_cond_kwargs = {"text_embeds": add_text_embeds, "time_ids": add_time_ids}
838
- if ip_adapter_image is not None or ip_adapter_image_embeds is not None:
839
- added_cond_kwargs["image_embeds"] = image_embeds
840
- noise_pred = self.unet(
841
- latent_model_input,
842
- t,
843
- encoder_hidden_states=prompt_embeds,
844
- timestep_cond=timestep_cond,
845
- cross_attention_kwargs=self.cross_attention_kwargs,
846
- added_cond_kwargs=added_cond_kwargs,
847
- return_dict=False,
848
- )[0]
849
-
850
- # perform guidance
851
- if do_classifier_free_guidance:
852
- noise_pred_uncond, noise_pred_text = noise_pred.chunk(2)
853
- noise_pred = noise_pred_uncond + self.guidance_scale * (noise_pred_text - noise_pred_uncond)
854
-
855
- if do_classifier_free_guidance and self.guidance_rescale > 0.0:
856
- # Based on 3.4. in https://arxiv.org/pdf/2305.08891.pdf
857
- noise_pred = rescale_noise_cfg(noise_pred, noise_pred_text, guidance_rescale=self.guidance_rescale)
858
-
859
- # compute the previous noisy sample x_t -> x_t-1
860
- latents_dtype = latents.dtype
861
- latents = self.scheduler.step(noise_pred, t, latents, **extra_step_kwargs, return_dict=False)[0]
862
- if latents.dtype != latents_dtype:
863
- if torch.backends.mps.is_available():
864
- # some platforms (eg. apple mps) misbehave due to a pytorch bug: https://github.com/pytorch/pytorch/pull/99272
865
- latents = latents.to(latents_dtype)
866
-
867
- if callback_on_step_end is not None:
868
- callback_kwargs = {}
869
- for k in callback_on_step_end_tensor_inputs:
870
- callback_kwargs[k] = locals()[k]
871
- callback_outputs = callback_on_step_end(self, i, t, callback_kwargs)
872
-
873
- latents = callback_outputs.pop("latents", latents)
874
- prompt_embeds = callback_outputs.pop("prompt_embeds", prompt_embeds)
875
- negative_prompt_embeds = callback_outputs.pop("negative_prompt_embeds", negative_prompt_embeds)
876
- add_text_embeds = callback_outputs.pop("add_text_embeds", add_text_embeds)
877
- negative_pooled_prompt_embeds = callback_outputs.pop(
878
- "negative_pooled_prompt_embeds", negative_pooled_prompt_embeds
879
- )
880
- add_time_ids = callback_outputs.pop("add_time_ids", add_time_ids)
881
- negative_add_time_ids = callback_outputs.pop("negative_add_time_ids", negative_add_time_ids)
882
-
883
- # call the callback, if provided
884
- if i == len(timesteps) - 1 or ((i + 1) > num_warmup_steps and (i + 1) % self.scheduler.order == 0):
885
- progress_bar.update()
886
- if callback is not None and i % callback_steps == 0:
887
- step_idx = i // getattr(self.scheduler, "order", 1)
888
- callback(step_idx, t, latents)
889
-
890
- if XLA_AVAILABLE:
891
- xm.mark_step()
892
-
893
- if not output_type == "latent":
894
- # make sure the VAE is in float32 mode, as it overflows in float16
895
- needs_upcasting = self.vae.dtype == torch.float16 and self.vae.config.force_upcast
896
-
897
- if needs_upcasting:
898
- self.upcast_vae()
899
- latents = latents.to(next(iter(self.vae.post_quant_conv.parameters())).dtype)
900
- elif latents.dtype != self.vae.dtype:
901
- if torch.backends.mps.is_available():
902
- # some platforms (eg. apple mps) misbehave due to a pytorch bug: https://github.com/pytorch/pytorch/pull/99272
903
- self.vae = self.vae.to(latents.dtype)
904
-
905
- # unscale/denormalize the latents
906
- # denormalize with the mean and std if available and not None
907
- has_latents_mean = hasattr(self.vae.config, "latents_mean") and self.vae.config.latents_mean is not None
908
- has_latents_std = hasattr(self.vae.config, "latents_std") and self.vae.config.latents_std is not None
909
- if has_latents_mean and has_latents_std:
910
- latents_mean = (
911
- torch.tensor(self.vae.config.latents_mean).view(1, 4, 1, 1).to(latents.device, latents.dtype)
912
- )
913
- latents_std = (
914
- torch.tensor(self.vae.config.latents_std).view(1, 4, 1, 1).to(latents.device, latents.dtype)
915
- )
916
- latents = latents * latents_std / self.vae.config.scaling_factor + latents_mean
917
- else:
918
- latents = latents / self.vae.config.scaling_factor
919
-
920
- image = self.vae.decode(latents, return_dict=False)[0]
921
 
922
- # cast back to fp16 if needed
923
- if needs_upcasting:
924
- self.vae.to(dtype=torch.float16)
925
- else:
926
- image = latents
927
 
928
- if not output_type == "latent":
929
- # apply watermark if available
930
- if self.watermark is not None:
931
- image = self.watermark.apply_watermark(image)
932
 
933
- image = self.image_processor.postprocess(image, output_type=output_type)
 
 
 
 
934
 
935
- # Offload all models
936
- self.maybe_free_model_hooks()
937
 
938
- if not return_dict:
939
- return (image,)
 
 
 
940
 
941
- return StableDiffusionXLPipelineOutput(images=image)
942
 
943
- def load_pipeline(pipeline=None) -> StableDiffusionXLPipeline:
944
- """Load and prepare the pipeline."""
945
- if not pipeline:
946
- pipeline = StableDiffusionXLPipeline_new.from_pretrained(
947
- "./models/newdream-sdxl-20",
948
- torch_dtype=torch.float16,
949
- local_files_only=True,
950
- ).to("cuda")
951
-
952
- pipeline.scheduler = SchedulerWrapper(DDIMScheduler.from_config(pipeline.scheduler.config))
953
- pipeline = compile_pipe(pipeline)
954
- load_pipe(pipeline, dir="cached_pipe")
955
-
956
- # Warm-up runs
957
- for _ in range(4):
958
- pipeline(
959
- prompt="a cat and a dog",
960
- num_inference_steps=18
961
- )
962
- pipeline.scheduler.prepare_loss()
963
- return pipeline
964
 
 
 
 
 
 
 
 
 
 
 
965
 
966
- def infer(request: TextToImageRequest, pipeline: StableDiffusionXLPipeline) -> Image:
967
- """Generate image from text prompt."""
968
- generator = Generator(pipeline.device).manual_seed(request.seed) if request.seed else None
969
-
970
- image_0 = pipeline(
971
  prompt=request.prompt,
972
  negative_prompt=request.negative_prompt,
973
  width=request.width,
974
  height=request.height,
975
  generator=generator,
976
- num_inference_steps=18,
 
 
977
  ).images[0]
978
-
979
- filter_image = max_pixel_filter(image_0)
980
- return filter_image
981
-
982
-
 
1
  import torch
2
+ from PIL.Image import Image
3
+ from diffusers import StableDiffusionXLPipeline, AutoPipelineForImage2Image
4
  from pipelines.models import TextToImageRequest
5
  from torch import Generator
6
+ from DeepCache import DeepCacheSDHelper
 
 
 
 
 
 
 
 
 
 
 
 
 
7
 
8
+ '''
9
+ def callback_dynamic_cfg(pipeline, step_index, timestep, callback_kwargs):
10
+ if step_index == int(pipeline.num_timesteps * 0.5):
11
+ callback_kwargs['prompt_embeds'] = callback_kwargs['prompt_embeds'].chunk(2)[-1]
12
+ callback_kwargs['add_text_embeds'] = callback_kwargs['add_text_embeds'].chunk(2)[-1]
13
+ callback_kwargs['add_time_ids'] = callback_kwargs['add_time_ids'].chunk(2)[-1]
14
+ pipeline._guidance_scale = 0.0
15
 
16
+ return callback_kwargs
17
+ '''
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
18
 
19
+ # ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 
 
20
 
21
+ def load_pipeline() -> dict: #StableDiffusionXLPipeline, AutoPipelineForImage2Image:
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
22
 
23
+ pipeline_dict = {}
24
+ pipeline = StableDiffusionXLPipeline.from_pretrained(
25
+ "./models/newdream-sdxl-20",
26
+ torch_dtype=torch.float16,
27
+ #local_files_only=True,
28
+ use_safetensors=True,
29
+ variant='fp16',
30
+ ).to("cuda")
31
+
32
+ refiner = AutoPipelineForImage2Image.from_pretrained(
33
+ 'stabilityai/stable-diffusion-xl-refiner-1.0',
34
+ use_safetensors=True,
35
+ torch_dtype=torch.float16,
36
+ variant='fp16',
37
+ ).to('cuda')
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
38
 
39
+
40
+ helper = DeepCacheSDHelper(pipe=pipeline)
41
+ helper.set_params(cache_interval=3, cache_branch_id=0)
42
+ helper.enable()
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
43
 
44
+ refiner_helper = DeepCacheSDHelper(pipe=refiner)
45
+ refiner_helper.set_params(cache_interval=3, cache_branch_id=0)
46
+ refiner_helper.enable()
47
+
 
48
 
49
+ for _ in range(5):
50
+ pipeline(prompt="")
 
 
51
 
52
+ pipeline_dict = {
53
+ 'base_pipeline': pipeline,
54
+ 'refiner': refiner
55
+ }
56
+ return pipeline_dict #base_pipeline, refiner
57
 
 
 
58
 
59
+ def infer(request: TextToImageRequest, pipeline_dict: dict) -> Image: #pipeline: StableDiffusionXLPipeline, refiner: AutoPipelineForImage2Image) -> Image:
60
+ if request.seed is None:
61
+ generator = None
62
+ else:
63
+ generator = Generator(pipeline_dict['base_pipeline'].device).manual_seed(request.seed)
64
 
 
65
 
66
+ image = pipeline_dict['base_pipeline'](
67
+ prompt=request.prompt,
68
+ negative_prompt=request.negative_prompt,
69
+ width=request.width,
70
+ height=request.height,
71
+ generator=generator,
72
+ num_inference_steps=27,
73
+ denoising_end=0.8,
74
+ output_type='latent',
75
+ ).images
 
 
 
 
 
 
 
 
 
 
 
76
 
77
+ return pipeline_dict['refiner'](
78
+ prompt=request.prompt,
79
+ negative_prompt=request.negative_prompt,
80
+ width=request.width,
81
+ height=request.height,
82
+ generator=generator,
83
+ num_inference_steps=27,
84
+ denoising_start=0.8,
85
+ image=image,
86
+ ).images[0]
87
 
88
+ '''
89
+ return pipeline(
 
 
 
90
  prompt=request.prompt,
91
  negative_prompt=request.negative_prompt,
92
  width=request.width,
93
  height=request.height,
94
  generator=generator,
95
+ num_inference_steps=27,
96
+ #callback_on_step_end=callback_dynamic_cfg,
97
+ #callback_on_step_end_tensor_inputs=['prompt_embeds', 'add_text_embeds', 'add_time_ids'],
98
  ).images[0]
99
+ '''
 
 
 
 
uv.lock CHANGED
@@ -34,19 +34,6 @@ version = "4.9.3"
34
  source = { registry = "https://pypi.org/simple" }
35
  sdist = { url = "https://files.pythonhosted.org/packages/3e/38/7859ff46355f76f8d19459005ca000b6e7012f2f1ca597746cbcd1fbfe5e/antlr4-python3-runtime-4.9.3.tar.gz", hash = "sha256:f224469b4168294902bb1efa80a8bf7855f24c99aef99cbefc1bcd3cce77881b", size = 117034 }
36
 
37
- [[package]]
38
- name = "bitsandbytes"
39
- version = "0.44.1"
40
- source = { registry = "https://pypi.org/simple" }
41
- dependencies = [
42
- { name = "numpy" },
43
- { name = "torch" },
44
- ]
45
- wheels = [
46
- { url = "https://files.pythonhosted.org/packages/e4/e6/ccb84da7ffaf208a71c2c3c8e1120b34759df640db959660be9a98505eb4/bitsandbytes-0.44.1-py3-none-manylinux_2_24_x86_64.whl", hash = "sha256:b2f24c6cbf11fc8c5d69b3dcecee9f7011451ec59d6ac833e873c9f105259668", size = 122419627 },
47
- { url = "https://files.pythonhosted.org/packages/5f/f5/11bddebb5addc0a005b0c1cecc6e4c6e4055ad7b860bdcbf6374e12a51f5/bitsandbytes-0.44.1-py3-none-win_amd64.whl", hash = "sha256:8e68e12aa25d2cf9a1730ad72890a5d1a19daa23f459a6a4679331f353d58cb4", size = 121451331 },
48
- ]
49
-
50
  [[package]]
51
  name = "certifi"
52
  version = "2024.8.30"
@@ -89,9 +76,23 @@ wheels = [
89
  { url = "https://files.pythonhosted.org/packages/d1/d6/3965ed04c63042e047cb6a3e6ed1a63a35087b6a609aa3a15ed8ac56c221/colorama-0.4.6-py2.py3-none-any.whl", hash = "sha256:4f1d9991f5acc0ca119f9d443620b77f9d6b33703e51011c16baf57afb285fc6", size = 25335 },
90
  ]
91
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
92
  [[package]]
93
  name = "diffusers"
94
- version = "0.28.2"
95
  source = { registry = "https://pypi.org/simple" }
96
  dependencies = [
97
  { name = "filelock" },
@@ -103,9 +104,9 @@ dependencies = [
103
  { name = "requests" },
104
  { name = "safetensors" },
105
  ]
106
- sdist = { url = "https://files.pythonhosted.org/packages/45/aa/f40919df7672c278b10509bb0f648a2f4b12ebb82174c0e51a25cbf76421/diffusers-0.28.2.tar.gz", hash = "sha256:0e1e881c821bd6dc2d88252a228a2532ae3577eb4f8b351c9c4abb184aee9b3f", size = 1704805 }
107
  wheels = [
108
- { url = "https://files.pythonhosted.org/packages/8c/1d/decefc6459a40df26e17631e42fb7c3814f8424037a26d4bad187800179e/diffusers-0.28.2-py3-none-any.whl", hash = "sha256:9713b7666510723ad6b7e8f4702664ef20c59e4bc241d26c7ca086be3041082e", size = 2184296 },
109
  ]
110
 
111
  [[package]]
@@ -114,51 +115,29 @@ version = "6"
114
  source = { editable = "." }
115
  dependencies = [
116
  { name = "accelerate" },
117
- { name = "bitsandbytes" },
118
  { name = "diffusers" },
119
  { name = "edge-maxxing-pipelines" },
120
- { name = "huggingface-hub" },
121
- { name = "numpy" },
122
  { name = "omegaconf" },
123
- { name = "onediff" },
124
- { name = "onediffx" },
125
- { name = "oneflow" },
126
- { name = "setuptools" },
127
- { name = "stable-fast" },
128
- { name = "tomesd" },
129
  { name = "torch" },
130
- { name = "torchvision" },
131
  { name = "transformers" },
132
- { name = "triton" },
133
- { name = "xformers" },
134
  ]
135
 
136
  [package.metadata]
137
  requires-dist = [
138
  { name = "accelerate", specifier = "==0.31.0" },
139
- { name = "bitsandbytes", specifier = ">=0.44.1" },
140
- { name = "diffusers", specifier = "==0.28.2" },
141
- { name = "edge-maxxing-pipelines", git = "https://github.com/womboai/edge-maxxing?subdirectory=pipelines" },
142
- { name = "huggingface-hub", specifier = "==0.25.2" },
143
- { name = "numpy", specifier = "==1.26.4" },
144
  { name = "omegaconf", specifier = "==2.3.0" },
145
- { name = "onediff", specifier = "==1.2.0" },
146
- { name = "onediffx", specifier = "==1.2.0" },
147
- { name = "oneflow", url = "https://github.com/siliconflow/oneflow_releases/releases/download/community_cu118/oneflow-0.9.1.dev20240802%2Bcu118-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl" },
148
- { name = "setuptools", specifier = ">=75.2.0" },
149
- { name = "stable-fast", url = "https://github.com/chengzeyi/stable-fast/releases/download/v1.0.5/stable_fast-1.0.5+torch222cu121-cp310-cp310-manylinux2014_x86_64.whl" },
150
- { name = "tomesd", specifier = ">=0.1.3" },
151
- { name = "torch", specifier = "==2.2.2" },
152
- { name = "torchvision", specifier = "==0.17.2" },
153
  { name = "transformers", specifier = "==4.41.2" },
154
- { name = "triton", specifier = "==2.2.0" },
155
- { name = "xformers", specifier = "==0.0.25.post1" },
156
  ]
157
 
158
  [[package]]
159
  name = "edge-maxxing-pipelines"
160
  version = "1.0.0"
161
- source = { git = "https://github.com/womboai/edge-maxxing?subdirectory=pipelines#5e655562d2587b575f3b2ad50e8c40560d79fd6f" }
162
  dependencies = [
163
  { name = "pydantic" },
164
  ]
@@ -183,7 +162,7 @@ wheels = [
183
 
184
  [[package]]
185
  name = "huggingface-hub"
186
- version = "0.25.2"
187
  source = { registry = "https://pypi.org/simple" }
188
  dependencies = [
189
  { name = "filelock" },
@@ -194,9 +173,9 @@ dependencies = [
194
  { name = "tqdm" },
195
  { name = "typing-extensions" },
196
  ]
197
- sdist = { url = "https://files.pythonhosted.org/packages/df/fd/5f81bae67096c5ab50d29a0230b8374f0245916cca192f8ee2fada51f4f6/huggingface_hub-0.25.2.tar.gz", hash = "sha256:a1014ea111a5f40ccd23f7f7ba8ac46e20fa3b658ced1f86a00c75c06ec6423c", size = 365806 }
198
  wheels = [
199
- { url = "https://files.pythonhosted.org/packages/64/09/a535946bf2dc88e61341f39dc507530411bb3ea4eac493e5ec833e8f35bd/huggingface_hub-0.25.2-py3-none-any.whl", hash = "sha256:1897caf88ce7f97fe0110603d8f66ac264e3ba6accdf30cd66cc0fed5282ad25", size = 436575 },
200
  ]
201
 
202
  [[package]]
@@ -232,18 +211,6 @@ wheels = [
232
  { url = "https://files.pythonhosted.org/packages/31/80/3a54838c3fb461f6fec263ebf3a3a41771bd05190238de3486aae8540c36/jinja2-3.1.4-py3-none-any.whl", hash = "sha256:bc5dd2abb727a5319567b7a813e6a2e7318c39f4f487cfe6c89c6f9c7d25197d", size = 133271 },
233
  ]
234
 
235
- [[package]]
236
- name = "markdown-it-py"
237
- version = "3.0.0"
238
- source = { registry = "https://pypi.org/simple" }
239
- dependencies = [
240
- { name = "mdurl" },
241
- ]
242
- sdist = { url = "https://files.pythonhosted.org/packages/38/71/3b932df36c1a044d397a1f92d1cf91ee0a503d91e470cbd670aa66b07ed0/markdown-it-py-3.0.0.tar.gz", hash = "sha256:e3f60a94fa066dc52ec76661e37c851cb232d92f9886b15cb560aaada2df8feb", size = 74596 }
243
- wheels = [
244
- { url = "https://files.pythonhosted.org/packages/42/d7/1ec15b46af6af88f19b8e5ffea08fa375d433c998b8a7639e76935c14f1f/markdown_it_py-3.0.0-py3-none-any.whl", hash = "sha256:355216845c60bd96232cd8d8c40e8f9765cc86f46880e43a8fd22dc1a1a8cab1", size = 87528 },
245
- ]
246
-
247
  [[package]]
248
  name = "markupsafe"
249
  version = "3.0.2"
@@ -262,15 +229,6 @@ wheels = [
262
  { url = "https://files.pythonhosted.org/packages/44/06/e7175d06dd6e9172d4a69a72592cb3f7a996a9c396eee29082826449bbc3/MarkupSafe-3.0.2-cp310-cp310-win_amd64.whl", hash = "sha256:6af100e168aa82a50e186c82875a5893c5597a0c1ccdb0d8b40240b1f28b969a", size = 15514 },
263
  ]
264
 
265
- [[package]]
266
- name = "mdurl"
267
- version = "0.1.2"
268
- source = { registry = "https://pypi.org/simple" }
269
- sdist = { url = "https://files.pythonhosted.org/packages/d6/54/cfe61301667036ec958cb99bd3efefba235e65cdeb9c84d24a8293ba1d90/mdurl-0.1.2.tar.gz", hash = "sha256:bb413d29f5eea38f31dd4754dd7377d4465116fb207585f97bf925588687c1ba", size = 8729 }
270
- wheels = [
271
- { url = "https://files.pythonhosted.org/packages/b3/38/89ba8ad64ae25be8de66a6d463314cf1eb366222074cfda9ee839c56a4b4/mdurl-0.1.2-py3-none-any.whl", hash = "sha256:84008a41e51615a49fc9966191ff91509e3c40b939176e643fd50a5c2196b8f8", size = 9979 },
272
- ]
273
-
274
  [[package]]
275
  name = "mpmath"
276
  version = "1.3.0"
@@ -291,29 +249,24 @@ wheels = [
291
 
292
  [[package]]
293
  name = "numpy"
294
- version = "1.26.4"
295
- source = { registry = "https://pypi.org/simple" }
296
- sdist = { url = "https://files.pythonhosted.org/packages/65/6e/09db70a523a96d25e115e71cc56a6f9031e7b8cd166c1ac8438307c14058/numpy-1.26.4.tar.gz", hash = "sha256:2a02aba9ed12e4ac4eb3ea9421c420301a0c6460d9830d74a9df87efa4912010", size = 15786129 }
297
- wheels = [
298
- { url = "https://files.pythonhosted.org/packages/a7/94/ace0fdea5241a27d13543ee117cbc65868e82213fb31a8eb7fe9ff23f313/numpy-1.26.4-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:9ff0f4f29c51e2803569d7a51c2304de5554655a60c5d776e35b4a41413830d0", size = 20631468 },
299
- { url = "https://files.pythonhosted.org/packages/20/f7/b24208eba89f9d1b58c1668bc6c8c4fd472b20c45573cb767f59d49fb0f6/numpy-1.26.4-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:2e4ee3380d6de9c9ec04745830fd9e2eccb3e6cf790d39d7b98ffd19b0dd754a", size = 13966411 },
300
- { url = "https://files.pythonhosted.org/packages/fc/a5/4beee6488160798683eed5bdb7eead455892c3b4e1f78d79d8d3f3b084ac/numpy-1.26.4-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:d209d8969599b27ad20994c8e41936ee0964e6da07478d6c35016bc386b66ad4", size = 14219016 },
301
- { url = "https://files.pythonhosted.org/packages/4b/d7/ecf66c1cd12dc28b4040b15ab4d17b773b87fa9d29ca16125de01adb36cd/numpy-1.26.4-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:ffa75af20b44f8dba823498024771d5ac50620e6915abac414251bd971b4529f", size = 18240889 },
302
- { url = "https://files.pythonhosted.org/packages/24/03/6f229fe3187546435c4f6f89f6d26c129d4f5bed40552899fcf1f0bf9e50/numpy-1.26.4-cp310-cp310-musllinux_1_1_aarch64.whl", hash = "sha256:62b8e4b1e28009ef2846b4c7852046736bab361f7aeadeb6a5b89ebec3c7055a", size = 13876746 },
303
- { url = "https://files.pythonhosted.org/packages/39/fe/39ada9b094f01f5a35486577c848fe274e374bbf8d8f472e1423a0bbd26d/numpy-1.26.4-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:a4abb4f9001ad2858e7ac189089c42178fcce737e4169dc61321660f1a96c7d2", size = 18078620 },
304
- { url = "https://files.pythonhosted.org/packages/d5/ef/6ad11d51197aad206a9ad2286dc1aac6a378059e06e8cf22cd08ed4f20dc/numpy-1.26.4-cp310-cp310-win32.whl", hash = "sha256:bfe25acf8b437eb2a8b2d49d443800a5f18508cd811fea3181723922a8a82b07", size = 5972659 },
305
- { url = "https://files.pythonhosted.org/packages/19/77/538f202862b9183f54108557bfda67e17603fc560c384559e769321c9d92/numpy-1.26.4-cp310-cp310-win_amd64.whl", hash = "sha256:b97fe8060236edf3662adfc2c633f56a08ae30560c56310562cb4f95500022d5", size = 15808905 },
306
- ]
307
-
308
- [[package]]
309
- name = "nvidia-cublas-cu11"
310
- version = "11.11.3.6"
311
  source = { registry = "https://pypi.org/simple" }
 
312
  wheels = [
313
- { url = "https://files.pythonhosted.org/packages/46/be/c222e33e60d28ecd496a46fc4d78ccae0ee28e1fd7dc705b6288b4cad27e/nvidia_cublas_cu11-11.11.3.6-py3-none-manylinux1_x86_64.whl", hash = "sha256:39fb40e8f486dd8a2ddb8fdeefe1d5b28f5b99df01c87ab3676f057a74a5a6f3", size = 417870452 },
314
- { url = "https://files.pythonhosted.org/packages/96/df/c5ac9ac5096355c47c606e613ecc7aa50fbccf5e0145df857d11da6464b1/nvidia_cublas_cu11-11.11.3.6-py3-none-manylinux2014_aarch64.whl", hash = "sha256:5ccae9e069a2c6be9af9cb5a0b0c6928c19c7915e390d15f598a1eead2a01a7a", size = 291428448 },
315
- { url = "https://files.pythonhosted.org/packages/ea/2e/9d99c60771d275ecf6c914a612e9a577f740a615bc826bec132368e1d3ae/nvidia_cublas_cu11-11.11.3.6-py3-none-manylinux2014_x86_64.whl", hash = "sha256:60252822adea5d0b10cd990a7dc7bedf7435f30ae40083c7a624a85a43225abc", size = 417870460 },
316
- { url = "https://files.pythonhosted.org/packages/0b/1d/7a78cd36fd5e3da4021b3ac2c2c8b2651dd72345b7c3ecc0d3e051884f50/nvidia_cublas_cu11-11.11.3.6-py3-none-win_amd64.whl", hash = "sha256:6ab12b1302bef8ac1ff4414edd1c059e57f4833abef9151683fb8f4de25900be", size = 427234740 },
 
 
 
 
 
 
 
 
 
 
317
  ]
318
 
319
  [[package]]
@@ -348,38 +301,15 @@ wheels = [
348
  { url = "https://files.pythonhosted.org/packages/eb/d5/c68b1d2cdfcc59e72e8a5949a37ddb22ae6cade80cd4a57a84d4c8b55472/nvidia_cuda_runtime_cu12-12.1.105-py3-none-manylinux1_x86_64.whl", hash = "sha256:6e258468ddf5796e25f1dc591a31029fa317d97a0a94ed93468fc86301d61e40", size = 823596 },
349
  ]
350
 
351
- [[package]]
352
- name = "nvidia-cudnn-cu11"
353
- version = "9.5.0.50"
354
- source = { registry = "https://pypi.org/simple" }
355
- dependencies = [
356
- { name = "nvidia-cublas-cu11" },
357
- ]
358
- wheels = [
359
- { url = "https://files.pythonhosted.org/packages/a6/d6/ec0bf8fd29c907e68de69248e5dbc3e78b63a613163d54ebfc4ca9362421/nvidia_cudnn_cu11-9.5.0.50-py3-none-manylinux2014_x86_64.whl", hash = "sha256:15ddd1c8e2904f35debb4a0452f4df57eeb9d363e760de5a5c2ca0daba8e545a", size = 558442361 },
360
- { url = "https://files.pythonhosted.org/packages/2e/01/e7aeb8f9f2336a44c946e629eeb2d204ec672ecd94a47d3b1abaa10a05f1/nvidia_cudnn_cu11-9.5.0.50-py3-none-win_amd64.whl", hash = "sha256:ecf46a9ca869c1628f0ce91c160d53cbd28f0805dca856f85f3e65b4ef3496b1", size = 553719005 },
361
- ]
362
-
363
  [[package]]
364
  name = "nvidia-cudnn-cu12"
365
- version = "8.9.2.26"
366
  source = { registry = "https://pypi.org/simple" }
367
  dependencies = [
368
  { name = "nvidia-cublas-cu12" },
369
  ]
370
  wheels = [
371
- { url = "https://files.pythonhosted.org/packages/ff/74/a2e2be7fb83aaedec84f391f082cf765dfb635e7caa9b49065f73e4835d8/nvidia_cudnn_cu12-8.9.2.26-py3-none-manylinux1_x86_64.whl", hash = "sha256:5ccb288774fdfb07a7e7025ffec286971c06d8d7b4fb162525334616d7629ff9", size = 731725872 },
372
- ]
373
-
374
- [[package]]
375
- name = "nvidia-cufft-cu11"
376
- version = "10.9.0.58"
377
- source = { registry = "https://pypi.org/simple" }
378
- wheels = [
379
- { url = "https://files.pythonhosted.org/packages/74/79/b912a77e38e41f15a0581a59f5c3548d1ddfdda3225936fb67c342719e7a/nvidia_cufft_cu11-10.9.0.58-py3-none-manylinux1_x86_64.whl", hash = "sha256:222f9da70c80384632fd6035e4c3f16762d64ea7a843829cb278f98b3cb7dd81", size = 168405414 },
380
- { url = "https://files.pythonhosted.org/packages/71/7a/a2ad9951d57c3cc23f4fa6d84b146afd9f375ffbc744b38935930ac4393f/nvidia_cufft_cu11-10.9.0.58-py3-none-manylinux2014_aarch64.whl", hash = "sha256:34b7315104e615b230dc3c2d1861f13bff9ec465c5d3b4bb65b4986d03a1d8d4", size = 111231060 },
381
- { url = "https://files.pythonhosted.org/packages/64/c8/133717b43182ba063803e983e7680a94826a9f4ff5734af0ca315803f1b3/nvidia_cufft_cu11-10.9.0.58-py3-none-manylinux2014_x86_64.whl", hash = "sha256:e21037259995243cc370dd63c430d77ae9280bedb68d5b5a18226bfc92e5d748", size = 168405419 },
382
- { url = "https://files.pythonhosted.org/packages/f8/b4/e432a74f8db0e84f734dc14d36c0e529225132bf7e239da21f55893351a6/nvidia_cufft_cu11-10.9.0.58-py3-none-win_amd64.whl", hash = "sha256:c4d316f17c745ec9c728e30409612eaf77a8404c3733cdf6c9c1569634d1ca03", size = 172237004 },
383
  ]
384
 
385
  [[package]]
@@ -411,17 +341,6 @@ wheels = [
411
  { url = "https://files.pythonhosted.org/packages/bc/1d/8de1e5c67099015c834315e333911273a8c6aaba78923dd1d1e25fc5f217/nvidia_cusolver_cu12-11.4.5.107-py3-none-manylinux1_x86_64.whl", hash = "sha256:8a7ec542f0412294b15072fa7dab71d31334014a69f953004ea7a118206fe0dd", size = 124161928 },
412
  ]
413
 
414
- [[package]]
415
- name = "nvidia-cusparse-cu11"
416
- version = "11.7.5.86"
417
- source = { registry = "https://pypi.org/simple" }
418
- wheels = [
419
- { url = "https://files.pythonhosted.org/packages/c1/e0/21b829c535d569831835a4ca5d049a19ba00d3e91f3e12ab4ad27bd7385f/nvidia_cusparse_cu11-11.7.5.86-py3-none-manylinux1_x86_64.whl", hash = "sha256:4ae709fe78d3f23f60acaba8c54b8ad556cf16ca486e0cc1aa92dca7555d2d2b", size = 204126221 },
420
- { url = "https://files.pythonhosted.org/packages/a2/6e/4eb2842e7ab1804072bca43030a8b92731e5a35f6a4a1b8f1aa8fa5f411c/nvidia_cusparse_cu11-11.7.5.86-py3-none-manylinux2014_aarch64.whl", hash = "sha256:6c7da46abee7567e619d4aa2e90a1b032cfcbd1211d429853b1a6e87514a14b2", size = 203917797 },
421
- { url = "https://files.pythonhosted.org/packages/ed/5c/b0333b07c51ced77397c2fb0d9826072cea0da9d421aa7e792aa0f8ecc72/nvidia_cusparse_cu11-11.7.5.86-py3-none-manylinux2014_x86_64.whl", hash = "sha256:8d7cf1628fd8d462b5d2ba6678fae34733a48ecb80495b9c68672ec6a6dde5ef", size = 204126227 },
422
- { url = "https://files.pythonhosted.org/packages/b8/36/a670e8ca1deccd3c63be4d0286491cf5c6375253f0d948e7cc5167fe1da9/nvidia_cusparse_cu11-11.7.5.86-py3-none-win_amd64.whl", hash = "sha256:a0f6ee81cd91be606fc2f55992d06b09cd4e86d74b6ae5e8dd1631cf7f5a8706", size = 203420667 },
423
- ]
424
-
425
  [[package]]
426
  name = "nvidia-cusparse-cu12"
427
  version = "12.1.0.106"
@@ -433,20 +352,13 @@ wheels = [
433
  { url = "https://files.pythonhosted.org/packages/65/5b/cfaeebf25cd9fdec14338ccb16f6b2c4c7fa9163aefcf057d86b9cc248bb/nvidia_cusparse_cu12-12.1.0.106-py3-none-manylinux1_x86_64.whl", hash = "sha256:f3b50f42cf363f86ab21f720998517a659a48131e8d538dc02f8768237bd884c", size = 195958278 },
434
  ]
435
 
436
- [[package]]
437
- name = "nvidia-nccl-cu11"
438
- version = "2.21.5"
439
- source = { registry = "https://pypi.org/simple" }
440
- wheels = [
441
- { url = "https://files.pythonhosted.org/packages/ac/9a/8b6a28b3b87d5fddab0e92cd835339eb8fbddaa71ae67518c8c1b3d05bae/nvidia_nccl_cu11-2.21.5-py3-none-manylinux2014_x86_64.whl", hash = "sha256:49d8350629c7888701d1fd200934942671cb5c728f49acc5a0b3a768820bed29", size = 147811630 },
442
- ]
443
-
444
  [[package]]
445
  name = "nvidia-nccl-cu12"
446
- version = "2.19.3"
447
  source = { registry = "https://pypi.org/simple" }
448
  wheels = [
449
- { url = "https://files.pythonhosted.org/packages/38/00/d0d4e48aef772ad5aebcf70b73028f88db6e5640b36c38e90445b7a57c45/nvidia_nccl_cu12-2.19.3-py3-none-manylinux1_x86_64.whl", hash = "sha256:a9734707a2c96443331c1e48c717024aa6678a0e2a4cb66b2c364d18cee6b48d", size = 165987969 },
 
450
  ]
451
 
452
  [[package]]
@@ -479,80 +391,6 @@ wheels = [
479
  { url = "https://files.pythonhosted.org/packages/e3/94/1843518e420fa3ed6919835845df698c7e27e183cb997394e4a670973a65/omegaconf-2.3.0-py3-none-any.whl", hash = "sha256:7b4df175cdb08ba400f45cae3bdcae7ba8365db4d165fc65fd04b050ab63b46b", size = 79500 },
480
  ]
481
 
482
- [[package]]
483
- name = "onediff"
484
- version = "1.2.0"
485
- source = { registry = "https://pypi.org/simple" }
486
- dependencies = [
487
- { name = "accelerate" },
488
- { name = "diffusers" },
489
- { name = "torch" },
490
- { name = "transformers" },
491
- ]
492
- sdist = { url = "https://files.pythonhosted.org/packages/d5/30/b493cbca73c5cdd2499a3ec37e451fa4c826e02be6bb6bc66c44d98293cc/onediff-1.2.0.tar.gz", hash = "sha256:8655b18698ca252093c06db53d4620de4065d1e507f9d7b1cbe3f123ed17bd26", size = 73823417 }
493
- wheels = [
494
- { url = "https://files.pythonhosted.org/packages/3c/22/5b6de9dae4b8ed161bfcab9a7d6d7660cca4ee1d7db733950b67905f7f66/onediff-1.2.0-py3-none-any.whl", hash = "sha256:84bb2285ae7f38e450229779ab96b591e4f530e1f22b7320f41b06f7aec181a3", size = 104932 },
495
- ]
496
-
497
- [[package]]
498
- name = "onediffx"
499
- version = "1.2.0"
500
- source = { registry = "https://pypi.org/simple" }
501
- dependencies = [
502
- { name = "accelerate" },
503
- { name = "diffusers" },
504
- { name = "omegaconf" },
505
- { name = "onefx" },
506
- { name = "torch" },
507
- { name = "transformers" },
508
- ]
509
- sdist = { url = "https://files.pythonhosted.org/packages/b9/e1/b0797217862a9eb48bdb5f3e53ed8c9b69fe582de1e7c3a4b948f7ed862a/onediffx-1.2.0.tar.gz", hash = "sha256:3e0934e71f966d41d04951826ae36ebfb25be8c23ca7f5e6f7b177fd92f0791b", size = 95945 }
510
- wheels = [
511
- { url = "https://files.pythonhosted.org/packages/f4/dd/412be6d3646355b5e5b75066f715fc34d0bbdcfbf18d0934b9f107c59239/onediffx-1.2.0-py3-none-any.whl", hash = "sha256:86dea026ac30bc04a2f4cd25ac4a511b1c4b4154657bc48c7e05f4a238085f14", size = 67899 },
512
- ]
513
-
514
- [[package]]
515
- name = "oneflow"
516
- version = "0.9.1.dev20240802+cu118"
517
- source = { url = "https://github.com/siliconflow/oneflow_releases/releases/download/community_cu118/oneflow-0.9.1.dev20240802%2Bcu118-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl" }
518
- dependencies = [
519
- { name = "numpy" },
520
- { name = "nvidia-cublas-cu11" },
521
- { name = "nvidia-cudnn-cu11" },
522
- { name = "nvidia-cufft-cu11" },
523
- { name = "nvidia-cusparse-cu11" },
524
- { name = "nvidia-nccl-cu11" },
525
- { name = "pillow" },
526
- { name = "protobuf" },
527
- { name = "requests" },
528
- { name = "rich" },
529
- { name = "tqdm" },
530
- ]
531
- wheels = [
532
- { url = "https://github.com/siliconflow/oneflow_releases/releases/download/community_cu118/oneflow-0.9.1.dev20240802%2Bcu118-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:0a9de80a3c059ec78bec7dfa6952f5618aaa05f29182b49634e0211195281e19" },
533
- ]
534
-
535
- [package.metadata]
536
- requires-dist = [
537
- { name = "numpy", specifier = ">=1.22.1" },
538
- { name = "nvidia-cublas-cu11" },
539
- { name = "nvidia-cudnn-cu11" },
540
- { name = "nvidia-cufft-cu11" },
541
- { name = "nvidia-cusparse-cu11" },
542
- { name = "nvidia-nccl-cu11" },
543
- { name = "pillow" },
544
- { name = "protobuf", specifier = ">=3.9.2" },
545
- { name = "requests" },
546
- { name = "rich" },
547
- { name = "tqdm" },
548
- ]
549
-
550
- [[package]]
551
- name = "onefx"
552
- version = "0.0.3"
553
- source = { registry = "https://pypi.org/simple" }
554
- sdist = { url = "https://files.pythonhosted.org/packages/3c/c4/2dc5fd8ab613d32e24d54204b4d448b315fa50e5f1ce3197938f2219fa09/onefx-0.0.3.tar.gz", hash = "sha256:d3f3f816891cdfdb6d69e4a78b72d5cafd7d40e165ce419f89f855f47a3dbe34", size = 147260 }
555
-
556
  [[package]]
557
  name = "packaging"
558
  version = "24.1"
@@ -588,20 +426,6 @@ wheels = [
588
  { url = "https://files.pythonhosted.org/packages/ec/3d/c32a51d848401bd94cabb8767a39621496491ee7cd5199856b77da9b18ad/pillow-11.0.0-pp310-pypy310_pp73-win_amd64.whl", hash = "sha256:224aaa38177597bb179f3ec87eeefcce8e4f85e608025e9cfac60de237ba6316", size = 2567508 },
589
  ]
590
 
591
- [[package]]
592
- name = "protobuf"
593
- version = "5.28.3"
594
- source = { registry = "https://pypi.org/simple" }
595
- sdist = { url = "https://files.pythonhosted.org/packages/74/6e/e69eb906fddcb38f8530a12f4b410699972ab7ced4e21524ece9d546ac27/protobuf-5.28.3.tar.gz", hash = "sha256:64badbc49180a5e401f373f9ce7ab1d18b63f7dd4a9cdc43c92b9f0b481cef7b", size = 422479 }
596
- wheels = [
597
- { url = "https://files.pythonhosted.org/packages/d1/c5/05163fad52d7c43e124a545f1372d18266db36036377ad29de4271134a6a/protobuf-5.28.3-cp310-abi3-win32.whl", hash = "sha256:0c4eec6f987338617072592b97943fdbe30d019c56126493111cf24344c1cc24", size = 419624 },
598
- { url = "https://files.pythonhosted.org/packages/9c/4c/4563ebe001ff30dca9d7ed12e471fa098d9759712980cde1fd03a3a44fb7/protobuf-5.28.3-cp310-abi3-win_amd64.whl", hash = "sha256:91fba8f445723fcf400fdbe9ca796b19d3b1242cd873907979b9ed71e4afe868", size = 431464 },
599
- { url = "https://files.pythonhosted.org/packages/1c/f2/baf397f3dd1d3e4af7e3f5a0382b868d25ac068eefe1ebde05132333436c/protobuf-5.28.3-cp38-abi3-macosx_10_9_universal2.whl", hash = "sha256:a3f6857551e53ce35e60b403b8a27b0295f7d6eb63d10484f12bc6879c715687", size = 414743 },
600
- { url = "https://files.pythonhosted.org/packages/85/50/cd61a358ba1601f40e7d38bcfba22e053f40ef2c50d55b55926aecc8fec7/protobuf-5.28.3-cp38-abi3-manylinux2014_aarch64.whl", hash = "sha256:3fa2de6b8b29d12c61911505d893afe7320ce7ccba4df913e2971461fa36d584", size = 316511 },
601
- { url = "https://files.pythonhosted.org/packages/5d/ae/3257b09328c0b4e59535e497b0c7537d4954038bdd53a2f0d2f49d15a7c4/protobuf-5.28.3-cp38-abi3-manylinux2014_x86_64.whl", hash = "sha256:712319fbdddb46f21abb66cd33cb9e491a5763b2febd8f228251add221981135", size = 316624 },
602
- { url = "https://files.pythonhosted.org/packages/ad/c3/2377c159e28ea89a91cf1ca223f827ae8deccb2c9c401e5ca233cd73002f/protobuf-5.28.3-py3-none-any.whl", hash = "sha256:cee1757663fa32a1ee673434fcf3bf24dd54763c79690201208bafec62f19eed", size = 169511 },
603
- ]
604
-
605
  [[package]]
606
  name = "psutil"
607
  version = "6.1.0"
@@ -662,15 +486,6 @@ wheels = [
662
  { url = "https://files.pythonhosted.org/packages/a9/f9/b6bcaf874f410564a78908739c80861a171788ef4d4f76f5009656672dfe/pydantic_core-2.23.4-pp310-pypy310_pp73-win_amd64.whl", hash = "sha256:9a5bce9d23aac8f0cf0836ecfc033896aa8443b501c58d0602dbfd5bd5b37753", size = 1920344 },
663
  ]
664
 
665
- [[package]]
666
- name = "pygments"
667
- version = "2.18.0"
668
- source = { registry = "https://pypi.org/simple" }
669
- sdist = { url = "https://files.pythonhosted.org/packages/8e/62/8336eff65bcbc8e4cb5d05b55faf041285951b6e80f33e2bff2024788f31/pygments-2.18.0.tar.gz", hash = "sha256:786ff802f32e91311bff3889f6e9a86e81505fe99f2735bb6d60ae0c5004f199", size = 4891905 }
670
- wheels = [
671
- { url = "https://files.pythonhosted.org/packages/f7/3f/01c8b82017c199075f8f788d0d906b9ffbbc5a47dc9918a945e13d5a2bda/pygments-2.18.0-py3-none-any.whl", hash = "sha256:b8e6aca0523f3ab76fee51799c488e38782ac06eafcf95e7ba832985c8e7b13a", size = 1205513 },
672
- ]
673
-
674
  [[package]]
675
  name = "pyyaml"
676
  version = "6.0.2"
@@ -727,20 +542,6 @@ wheels = [
727
  { url = "https://files.pythonhosted.org/packages/f9/9b/335f9764261e915ed497fcdeb11df5dfd6f7bf257d4a6a2a686d80da4d54/requests-2.32.3-py3-none-any.whl", hash = "sha256:70761cfe03c773ceb22aa2f671b4757976145175cdfca038c02654d061d6dcc6", size = 64928 },
728
  ]
729
 
730
- [[package]]
731
- name = "rich"
732
- version = "13.9.3"
733
- source = { registry = "https://pypi.org/simple" }
734
- dependencies = [
735
- { name = "markdown-it-py" },
736
- { name = "pygments" },
737
- { name = "typing-extensions" },
738
- ]
739
- sdist = { url = "https://files.pythonhosted.org/packages/d9/e9/cf9ef5245d835065e6673781dbd4b8911d352fb770d56cf0879cf11b7ee1/rich-13.9.3.tar.gz", hash = "sha256:bc1e01b899537598cf02579d2b9f4a415104d3fc439313a7a2c165d76557a08e", size = 222889 }
740
- wheels = [
741
- { url = "https://files.pythonhosted.org/packages/9a/e2/10e9819cf4a20bd8ea2f5dabafc2e6bf4a78d6a0965daeb60a4b34d1c11f/rich-13.9.3-py3-none-any.whl", hash = "sha256:9836f5096eb2172c9e77df411c1b009bace4193d6a481d534fea75ebba758283", size = 242157 },
742
- ]
743
-
744
  [[package]]
745
  name = "safetensors"
746
  version = "0.4.5"
@@ -768,40 +569,6 @@ wheels = [
768
  { url = "https://files.pythonhosted.org/packages/19/46/5d11dc300feaad285c2f1bd784ff3f689f5e0ab6be49aaf568f3a77019eb/safetensors-0.4.5-pp310-pypy310_pp73-musllinux_1_1_x86_64.whl", hash = "sha256:21742b391b859e67b26c0b2ac37f52c9c0944a879a25ad2f9f9f3cd61e7fda8f", size = 606660 },
769
  ]
770
 
771
- [[package]]
772
- name = "setuptools"
773
- version = "75.2.0"
774
- source = { registry = "https://pypi.org/simple" }
775
- sdist = { url = "https://files.pythonhosted.org/packages/07/37/b31be7e4b9f13b59cde9dcaeff112d401d49e0dc5b37ed4a9fc8fb12f409/setuptools-75.2.0.tar.gz", hash = "sha256:753bb6ebf1f465a1912e19ed1d41f403a79173a9acf66a42e7e6aec45c3c16ec", size = 1350308 }
776
- wheels = [
777
- { url = "https://files.pythonhosted.org/packages/31/2d/90165d51ecd38f9a02c6832198c13a4e48652485e2ccf863ebb942c531b6/setuptools-75.2.0-py3-none-any.whl", hash = "sha256:a7fcb66f68b4d9e8e66b42f9876150a3371558f98fa32222ffaa5bced76406f8", size = 1249825 },
778
- ]
779
-
780
- [[package]]
781
- name = "stable-fast"
782
- version = "1.0.5+torch222cu121"
783
- source = { url = "https://github.com/chengzeyi/stable-fast/releases/download/v1.0.5/stable_fast-1.0.5+torch222cu121-cp310-cp310-manylinux2014_x86_64.whl" }
784
- dependencies = [
785
- { name = "torch" },
786
- ]
787
- wheels = [
788
- { url = "https://github.com/chengzeyi/stable-fast/releases/download/v1.0.5/stable_fast-1.0.5+torch222cu121-cp310-cp310-manylinux2014_x86_64.whl", hash = "sha256:03d193666c52016096ecfdf0e8e2183fb5aa8ea51e99d5132b353a1e9a6c1264" },
789
- ]
790
-
791
- [package.metadata]
792
- requires-dist = [
793
- { name = "diffusers", marker = "extra == 'diffusers'", specifier = ">=0.19.0" },
794
- { name = "numpy", marker = "extra == 'dev'" },
795
- { name = "opencv-python", marker = "extra == 'dev'" },
796
- { name = "pillow", marker = "extra == 'dev'" },
797
- { name = "prettytable", marker = "extra == 'dev'" },
798
- { name = "pytest", marker = "extra == 'dev'" },
799
- { name = "torch" },
800
- { name = "transformers", marker = "extra == 'diffusers'" },
801
- { name = "triton", marker = "extra == 'triton'", specifier = ">=2.1.0" },
802
- { name = "xformers", marker = "extra == 'xformers'", specifier = ">=0.0.20" },
803
- ]
804
-
805
  [[package]]
806
  name = "sympy"
807
  version = "1.13.3"
@@ -844,21 +611,9 @@ wheels = [
844
  { url = "https://files.pythonhosted.org/packages/45/b6/36c1bb106bbe96012c9367df89ed01599cada036c0b96d38fbbdbeb75c9f/tokenizers-0.19.1-pp310-pypy310_pp73-musllinux_1_1_x86_64.whl", hash = "sha256:43350270bfc16b06ad3f6f07eab21f089adb835544417afda0f83256a8bf8b75", size = 9945103 },
845
  ]
846
 
847
- [[package]]
848
- name = "tomesd"
849
- version = "0.1.3"
850
- source = { registry = "https://pypi.org/simple" }
851
- dependencies = [
852
- { name = "torch" },
853
- ]
854
- sdist = { url = "https://files.pythonhosted.org/packages/29/37/ed74c7449fe5a8a4726be3dab4d879d000babf6ea538658171933b1f000e/tomesd-0.1.3.tar.gz", hash = "sha256:15bba2e952f4643c8355951e892fda918ddccbdff2238dc368d42bd078fcedc9", size = 14032 }
855
- wheels = [
856
- { url = "https://files.pythonhosted.org/packages/0c/02/367c67c8f510313f143a7818e92254a5f861c7d94c98ad6a08d25db52fee/tomesd-0.1.3-py3-none-any.whl", hash = "sha256:3d5aa0857fe2c2aab253891050601ca13a87d8d7a99b6760b9ca0856aa0c6355", size = 11467 },
857
- ]
858
-
859
  [[package]]
860
  name = "torch"
861
- version = "2.2.2"
862
  source = { registry = "https://pypi.org/simple" }
863
  dependencies = [
864
  { name = "filelock" },
@@ -881,28 +636,10 @@ dependencies = [
881
  { name = "typing-extensions" },
882
  ]
883
  wheels = [
884
- { url = "https://files.pythonhosted.org/packages/33/b3/1fcc3bccfddadfd6845dcbfe26eb4b099f1dfea5aa0e5cfb92b3c98dba5b/torch-2.2.2-cp310-cp310-manylinux1_x86_64.whl", hash = "sha256:bc889d311a855dd2dfd164daf8cc903a6b7273a747189cebafdd89106e4ad585", size = 755526581 },
885
- { url = "https://files.pythonhosted.org/packages/c3/7c/aeb0c5789a3f10cf909640530cd75b314959b9d9914a4996ed2c7bf8779d/torch-2.2.2-cp310-cp310-manylinux2014_aarch64.whl", hash = "sha256:15dffa4cc3261fa73d02f0ed25f5fa49ecc9e12bf1ae0a4c1e7a88bbfaad9030", size = 86623646 },
886
- { url = "https://files.pythonhosted.org/packages/3a/81/684d99e536b20e869a7c1222cf1dd233311fb05d3628e9570992bfb65760/torch-2.2.2-cp310-cp310-win_amd64.whl", hash = "sha256:11e8fe261233aeabd67696d6b993eeb0896faa175c6b41b9a6c9f0334bdad1c5", size = 198579616 },
887
- { url = "https://files.pythonhosted.org/packages/3b/55/7192974ab13e5e5577f45d14ce70d42f5a9a686b4f57bbe8c9ab45c4a61a/torch-2.2.2-cp310-none-macosx_10_9_x86_64.whl", hash = "sha256:b2e2200b245bd9f263a0d41b6a2dab69c4aca635a01b30cca78064b0ef5b109e", size = 150788930 },
888
- { url = "https://files.pythonhosted.org/packages/33/6b/21496316c9b8242749ee2a9064406271efdf979e91d440e8a3806b5e84bf/torch-2.2.2-cp310-none-macosx_11_0_arm64.whl", hash = "sha256:877b3e6593b5e00b35bbe111b7057464e76a7dd186a287280d941b564b0563c2", size = 59707286 },
889
- ]
890
-
891
- [[package]]
892
- name = "torchvision"
893
- version = "0.17.2"
894
- source = { registry = "https://pypi.org/simple" }
895
- dependencies = [
896
- { name = "numpy" },
897
- { name = "pillow" },
898
- { name = "torch" },
899
- ]
900
- wheels = [
901
- { url = "https://files.pythonhosted.org/packages/a2/70/c781e0433ab7b8f6f693580e5065ae17c3785b2836200311765f99535ef8/torchvision-0.17.2-cp310-cp310-macosx_10_13_x86_64.whl", hash = "sha256:1f2910fe3c21ad6875b2720d46fad835b2e4b336e9553d31ca364d24c90b1d4f", size = 1666426 },
902
- { url = "https://files.pythonhosted.org/packages/64/3d/a0385fd301e6e2eefb1d9cf2ac97d0c33ebf4a764aba0f066e6e16324916/torchvision-0.17.2-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:ecc1c503fa8a54fbab777e06a7c228032b8ab78efebf35b28bc8f22f544f51f1", size = 1571154 },
903
- { url = "https://files.pythonhosted.org/packages/e0/2f/d13cb0ffc4808f85b880ef66ab6cfef10bd35e5c151dae68ea18cf6bf636/torchvision-0.17.2-cp310-cp310-manylinux1_x86_64.whl", hash = "sha256:f400145fc108833e7c2fc28486a04989ca742146d7a2a2cc48878ebbb40cdbbd", size = 6915896 },
904
- { url = "https://files.pythonhosted.org/packages/fb/41/c8a440ebb1d4958baf02f08f6df56a3a30bea3fdcdc99076cb7da023babe/torchvision-0.17.2-cp310-cp310-manylinux2014_aarch64.whl", hash = "sha256:e9e4bed404af33dfc92eecc2b513d21ddc4c242a7fd8708b3b09d3a26aa6f444", size = 14008514 },
905
- { url = "https://files.pythonhosted.org/packages/0a/b8/027b3c36e61a26d14d4e9a8413d4a09e5fd8d3e01e3efce78447ca1dc3dd/torchvision-0.17.2-cp310-cp310-win_amd64.whl", hash = "sha256:ba2e62f233eab3d42b648c122a3a29c47cc108ca314dfd5cbb59cd3a143fd623", size = 1165527 },
906
  ]
907
 
908
  [[package]]
@@ -940,13 +677,13 @@ wheels = [
940
 
941
  [[package]]
942
  name = "triton"
943
- version = "2.2.0"
944
  source = { registry = "https://pypi.org/simple" }
945
  dependencies = [
946
  { name = "filelock" },
947
  ]
948
  wheels = [
949
- { url = "https://files.pythonhosted.org/packages/95/05/ed974ce87fe8c8843855daa2136b3409ee1c126707ab54a8b72815c08b49/triton-2.2.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:a2294514340cfe4e8f4f9e5c66c702744c4a117d25e618bd08469d0bfed1e2e5", size = 167900779 },
950
  ]
951
 
952
  [[package]]
@@ -967,20 +704,6 @@ wheels = [
967
  { url = "https://files.pythonhosted.org/packages/ce/d9/5f4c13cecde62396b0d3fe530a50ccea91e7dfc1ccf0e09c228841bb5ba8/urllib3-2.2.3-py3-none-any.whl", hash = "sha256:ca899ca043dcb1bafa3e262d73aa25c465bfb49e0bd9dd5d59f1d0acba2f8fac", size = 126338 },
968
  ]
969
 
970
- [[package]]
971
- name = "xformers"
972
- version = "0.0.25.post1"
973
- source = { registry = "https://pypi.org/simple" }
974
- dependencies = [
975
- { name = "numpy" },
976
- { name = "torch" },
977
- ]
978
- sdist = { url = "https://files.pythonhosted.org/packages/ca/66/f5977922658ff2aea8b3222901fa0b9922778988c6d3a428cfd083892191/xformers-0.0.25.post1.tar.gz", hash = "sha256:397430bd0162fd5a75eb8bc50b0ba242200881e48fd6404a19376f853f8c0444", size = 4083274 }
979
- wheels = [
980
- { url = "https://files.pythonhosted.org/packages/5f/9b/f781a50d965717a2a2ea2c8d15e0f30deec8f9751a9874e850ba9ab0fadc/xformers-0.0.25.post1-cp310-cp310-manylinux2014_x86_64.whl", hash = "sha256:cdfe9560848fa5ba75fc04d3da8803658e35997adc6075ee6bbf6d67c1f0fa5e", size = 222517307 },
981
- { url = "https://files.pythonhosted.org/packages/25/19/301789926809dc167ac104c29e26703369b3d47e6c1a2861db9efccbdc10/xformers-0.0.25.post1-cp310-cp310-win_amd64.whl", hash = "sha256:ddc22273f2ff06b886d9e86f17997e4f1f3074fdeb5d46bcdf50b704430df528", size = 208697268 },
982
- ]
983
-
984
  [[package]]
985
  name = "zipp"
986
  version = "3.20.2"
 
34
  source = { registry = "https://pypi.org/simple" }
35
  sdist = { url = "https://files.pythonhosted.org/packages/3e/38/7859ff46355f76f8d19459005ca000b6e7012f2f1ca597746cbcd1fbfe5e/antlr4-python3-runtime-4.9.3.tar.gz", hash = "sha256:f224469b4168294902bb1efa80a8bf7855f24c99aef99cbefc1bcd3cce77881b", size = 117034 }
36
 
 
 
 
 
 
 
 
 
 
 
 
 
 
37
  [[package]]
38
  name = "certifi"
39
  version = "2024.8.30"
 
76
  { url = "https://files.pythonhosted.org/packages/d1/d6/3965ed04c63042e047cb6a3e6ed1a63a35087b6a609aa3a15ed8ac56c221/colorama-0.4.6-py2.py3-none-any.whl", hash = "sha256:4f1d9991f5acc0ca119f9d443620b77f9d6b33703e51011c16baf57afb285fc6", size = 25335 },
77
  ]
78
 
79
+ [[package]]
80
+ name = "deepcache"
81
+ version = "0.1.1"
82
+ source = { registry = "https://pypi.org/simple" }
83
+ dependencies = [
84
+ { name = "diffusers" },
85
+ { name = "torch" },
86
+ { name = "transformers" },
87
+ ]
88
+ sdist = { url = "https://files.pythonhosted.org/packages/97/f4/499a3bbe535e2d3612b5d0d44e94c80498856f99ae4b57d02da2a4128281/DeepCache-0.1.1.tar.gz", hash = "sha256:8bc995d8c0ee7f3eb51ca080c951916bf0eb044ebdc75215b1753621ac8f80e6", size = 190065 }
89
+ wheels = [
90
+ { url = "https://files.pythonhosted.org/packages/8e/40/f7024b19494d5cbf0ae85e04da2fed973690af971edfbfd181573b3a6b34/DeepCache-0.1.1-py3-none-any.whl", hash = "sha256:aa4aa5f8e9a2e5a41d59900305c3c86c20834537d0c67bf2d8bb7075618ae48a", size = 190872 },
91
+ ]
92
+
93
  [[package]]
94
  name = "diffusers"
95
+ version = "0.30.2"
96
  source = { registry = "https://pypi.org/simple" }
97
  dependencies = [
98
  { name = "filelock" },
 
104
  { name = "requests" },
105
  { name = "safetensors" },
106
  ]
107
+ sdist = { url = "https://files.pythonhosted.org/packages/04/ee/13a6327f04f21420ab4d8ada635aba7d884bf57b09f9b847b9af3818b348/diffusers-0.30.2.tar.gz", hash = "sha256:641875f78f36bdfa4b9af752b124d1fd6d431eadd5547fe0a3f354ae0af2636c", size = 2095560 }
108
  wheels = [
109
+ { url = "https://files.pythonhosted.org/packages/2f/ee/f67b0888229be96a276257579a58eb2331733d246fdb8620e09ca7253971/diffusers-0.30.2-py3-none-any.whl", hash = "sha256:739826043147c2b59560944591dfdea5d24cd4fb15e751abbe20679a289bece8", size = 2636928 },
110
  ]
111
 
112
  [[package]]
 
115
  source = { editable = "." }
116
  dependencies = [
117
  { name = "accelerate" },
118
+ { name = "deepcache" },
119
  { name = "diffusers" },
120
  { name = "edge-maxxing-pipelines" },
 
 
121
  { name = "omegaconf" },
 
 
 
 
 
 
122
  { name = "torch" },
 
123
  { name = "transformers" },
 
 
124
  ]
125
 
126
  [package.metadata]
127
  requires-dist = [
128
  { name = "accelerate", specifier = "==0.31.0" },
129
+ { name = "deepcache" },
130
+ { name = "diffusers", specifier = "==0.30.2" },
131
+ { name = "edge-maxxing-pipelines", git = "https://github.com/womboai/edge-maxxing?subdirectory=pipelines&rev=8d8ff45863416484b5b4bc547782591bbdfc696a#8d8ff45863416484b5b4bc547782591bbdfc696a" },
 
 
132
  { name = "omegaconf", specifier = "==2.3.0" },
133
+ { name = "torch", specifier = "==2.4.1" },
 
 
 
 
 
 
 
134
  { name = "transformers", specifier = "==4.41.2" },
 
 
135
  ]
136
 
137
  [[package]]
138
  name = "edge-maxxing-pipelines"
139
  version = "1.0.0"
140
+ source = { git = "https://github.com/womboai/edge-maxxing?subdirectory=pipelines&rev=8d8ff45863416484b5b4bc547782591bbdfc696a#8d8ff45863416484b5b4bc547782591bbdfc696a" }
141
  dependencies = [
142
  { name = "pydantic" },
143
  ]
 
162
 
163
  [[package]]
164
  name = "huggingface-hub"
165
+ version = "0.26.1"
166
  source = { registry = "https://pypi.org/simple" }
167
  dependencies = [
168
  { name = "filelock" },
 
173
  { name = "tqdm" },
174
  { name = "typing-extensions" },
175
  ]
176
+ sdist = { url = "https://files.pythonhosted.org/packages/44/99/c8fdef6fe09a1719e5e5de24b012de5824889168c96143f5531cab5af42b/huggingface_hub-0.26.1.tar.gz", hash = "sha256:414c0d9b769eecc86c70f9d939d0f48bb28e8461dd1130021542eff0212db890", size = 375458 }
177
  wheels = [
178
+ { url = "https://files.pythonhosted.org/packages/d7/4d/017d8d7cff5100092da8ea19139bcb1965bbadcbb5ddd0480e2badc299e8/huggingface_hub-0.26.1-py3-none-any.whl", hash = "sha256:5927a8fc64ae68859cd954b7cc29d1c8390a5e15caba6d3d349c973be8fdacf3", size = 447439 },
179
  ]
180
 
181
  [[package]]
 
211
  { url = "https://files.pythonhosted.org/packages/31/80/3a54838c3fb461f6fec263ebf3a3a41771bd05190238de3486aae8540c36/jinja2-3.1.4-py3-none-any.whl", hash = "sha256:bc5dd2abb727a5319567b7a813e6a2e7318c39f4f487cfe6c89c6f9c7d25197d", size = 133271 },
212
  ]
213
 
 
 
 
 
 
 
 
 
 
 
 
 
214
  [[package]]
215
  name = "markupsafe"
216
  version = "3.0.2"
 
229
  { url = "https://files.pythonhosted.org/packages/44/06/e7175d06dd6e9172d4a69a72592cb3f7a996a9c396eee29082826449bbc3/MarkupSafe-3.0.2-cp310-cp310-win_amd64.whl", hash = "sha256:6af100e168aa82a50e186c82875a5893c5597a0c1ccdb0d8b40240b1f28b969a", size = 15514 },
230
  ]
231
 
 
 
 
 
 
 
 
 
 
232
  [[package]]
233
  name = "mpmath"
234
  version = "1.3.0"
 
249
 
250
  [[package]]
251
  name = "numpy"
252
+ version = "2.1.2"
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
253
  source = { registry = "https://pypi.org/simple" }
254
+ sdist = { url = "https://files.pythonhosted.org/packages/4b/d1/8a730ea07f4a37d94f9172f4ce1d81064b7a64766b460378be278952de75/numpy-2.1.2.tar.gz", hash = "sha256:13532a088217fa624c99b843eeb54640de23b3414b14aa66d023805eb731066c", size = 18878063 }
255
  wheels = [
256
+ { url = "https://files.pythonhosted.org/packages/1c/a2/40a76d357f168e9f9f06d6cc2c8e22dd5fb2bfbe63fe2c433057258c145a/numpy-2.1.2-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:30d53720b726ec36a7f88dc873f0eec8447fbc93d93a8f079dfac2629598d6ee", size = 21150947 },
257
+ { url = "https://files.pythonhosted.org/packages/b5/d0/ba271ea9108d7278d3889a7eb38d77370a88713fb94339964e71ac184d4a/numpy-2.1.2-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:e8d3ca0a72dd8846eb6f7dfe8f19088060fcb76931ed592d29128e0219652884", size = 13758184 },
258
+ { url = "https://files.pythonhosted.org/packages/7c/b9/5c6507439cd756201010f7937bf90712c2469052ae094584af14557dd64f/numpy-2.1.2-cp310-cp310-macosx_14_0_arm64.whl", hash = "sha256:fc44e3c68ff00fd991b59092a54350e6e4911152682b4782f68070985aa9e648", size = 5354091 },
259
+ { url = "https://files.pythonhosted.org/packages/60/21/7938cf724d9e84e45fb886f3fc794ab431d71facfebc261e3e9f19f3233a/numpy-2.1.2-cp310-cp310-macosx_14_0_x86_64.whl", hash = "sha256:7c1c60328bd964b53f8b835df69ae8198659e2b9302ff9ebb7de4e5a5994db3d", size = 6887169 },
260
+ { url = "https://files.pythonhosted.org/packages/09/8d/42a124657f5d31902fca73921b25a0d022cead2b32ce7e6975762cd2995a/numpy-2.1.2-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:6cdb606a7478f9ad91c6283e238544451e3a95f30fb5467fbf715964341a8a86", size = 13888165 },
261
+ { url = "https://files.pythonhosted.org/packages/fb/25/ba023652a39a2c127200e85aed975fc6119b421e2c348e5d0171e2046edb/numpy-2.1.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:d666cb72687559689e9906197e3bec7b736764df6a2e58ee265e360663e9baf7", size = 16326954 },
262
+ { url = "https://files.pythonhosted.org/packages/34/58/23e6b07fad492b7c47cf09cd8bad6983658f0f925b6c535fd008e3e86274/numpy-2.1.2-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:c6eef7a2dbd0abfb0d9eaf78b73017dbfd0b54051102ff4e6a7b2980d5ac1a03", size = 16702916 },
263
+ { url = "https://files.pythonhosted.org/packages/91/24/37b5cf2dc7d385ac97f7b7fe50cba312abb70a2a5eac74c23af028811f73/numpy-2.1.2-cp310-cp310-musllinux_1_2_aarch64.whl", hash = "sha256:12edb90831ff481f7ef5f6bc6431a9d74dc0e5ff401559a71e5e4611d4f2d466", size = 14384372 },
264
+ { url = "https://files.pythonhosted.org/packages/ea/ec/0f6d471058a01d1a05a50d2793898de1549280fa715a8537987ee866b5d9/numpy-2.1.2-cp310-cp310-win32.whl", hash = "sha256:a65acfdb9c6ebb8368490dbafe83c03c7e277b37e6857f0caeadbbc56e12f4fb", size = 6535361 },
265
+ { url = "https://files.pythonhosted.org/packages/c2/3d/293cc5927f916a7bc6bf74da8f6defab63d1b13f0959d7e21878ad8a20d8/numpy-2.1.2-cp310-cp310-win_amd64.whl", hash = "sha256:860ec6e63e2c5c2ee5e9121808145c7bf86c96cca9ad396c0bd3e0f2798ccbe2", size = 12865501 },
266
+ { url = "https://files.pythonhosted.org/packages/73/c9/3e1d6bbe6d3d2e2c5a9483b24b2f29a229b323f62054278a3bba7fee11e5/numpy-2.1.2-pp310-pypy310_pp73-macosx_10_15_x86_64.whl", hash = "sha256:bdd407c40483463898b84490770199d5714dcc9dd9b792f6c6caccc523c00952", size = 20981945 },
267
+ { url = "https://files.pythonhosted.org/packages/6e/62/989c4988bde1a8e08117fccc3bab73d2886421fb98cde597168714f3c54e/numpy-2.1.2-pp310-pypy310_pp73-macosx_14_0_x86_64.whl", hash = "sha256:da65fb46d4cbb75cb417cddf6ba5e7582eb7bb0b47db4b99c9fe5787ce5d91f5", size = 6750558 },
268
+ { url = "https://files.pythonhosted.org/packages/53/b1/00ef9f30975f1312a53257f68e57b4513d14d537e03d507e2773a684b1e8/numpy-2.1.2-pp310-pypy310_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:1c193d0b0238638e6fc5f10f1b074a6993cb13b0b431f64079a509d63d3aa8b7", size = 16141552 },
269
+ { url = "https://files.pythonhosted.org/packages/c0/ec/0c04903b48dfea6be1d7b47ba70f98709fb7198fd970784a1400c391d522/numpy-2.1.2-pp310-pypy310_pp73-win_amd64.whl", hash = "sha256:a7d80b2e904faa63068ead63107189164ca443b42dd1930299e0d1cb041cec2e", size = 12789924 },
270
  ]
271
 
272
  [[package]]
 
301
  { url = "https://files.pythonhosted.org/packages/eb/d5/c68b1d2cdfcc59e72e8a5949a37ddb22ae6cade80cd4a57a84d4c8b55472/nvidia_cuda_runtime_cu12-12.1.105-py3-none-manylinux1_x86_64.whl", hash = "sha256:6e258468ddf5796e25f1dc591a31029fa317d97a0a94ed93468fc86301d61e40", size = 823596 },
302
  ]
303
 
 
 
 
 
 
 
 
 
 
 
 
 
304
  [[package]]
305
  name = "nvidia-cudnn-cu12"
306
+ version = "9.1.0.70"
307
  source = { registry = "https://pypi.org/simple" }
308
  dependencies = [
309
  { name = "nvidia-cublas-cu12" },
310
  ]
311
  wheels = [
312
+ { url = "https://files.pythonhosted.org/packages/9f/fd/713452cd72343f682b1c7b9321e23829f00b842ceaedcda96e742ea0b0b3/nvidia_cudnn_cu12-9.1.0.70-py3-none-manylinux2014_x86_64.whl", hash = "sha256:165764f44ef8c61fcdfdfdbe769d687e06374059fbb388b6c89ecb0e28793a6f", size = 664752741 },
 
 
 
 
 
 
 
 
 
 
 
313
  ]
314
 
315
  [[package]]
 
341
  { url = "https://files.pythonhosted.org/packages/bc/1d/8de1e5c67099015c834315e333911273a8c6aaba78923dd1d1e25fc5f217/nvidia_cusolver_cu12-11.4.5.107-py3-none-manylinux1_x86_64.whl", hash = "sha256:8a7ec542f0412294b15072fa7dab71d31334014a69f953004ea7a118206fe0dd", size = 124161928 },
342
  ]
343
 
 
 
 
 
 
 
 
 
 
 
 
344
  [[package]]
345
  name = "nvidia-cusparse-cu12"
346
  version = "12.1.0.106"
 
352
  { url = "https://files.pythonhosted.org/packages/65/5b/cfaeebf25cd9fdec14338ccb16f6b2c4c7fa9163aefcf057d86b9cc248bb/nvidia_cusparse_cu12-12.1.0.106-py3-none-manylinux1_x86_64.whl", hash = "sha256:f3b50f42cf363f86ab21f720998517a659a48131e8d538dc02f8768237bd884c", size = 195958278 },
353
  ]
354
 
 
 
 
 
 
 
 
 
355
  [[package]]
356
  name = "nvidia-nccl-cu12"
357
+ version = "2.20.5"
358
  source = { registry = "https://pypi.org/simple" }
359
  wheels = [
360
+ { url = "https://files.pythonhosted.org/packages/c1/bb/d09dda47c881f9ff504afd6f9ca4f502ded6d8fc2f572cacc5e39da91c28/nvidia_nccl_cu12-2.20.5-py3-none-manylinux2014_aarch64.whl", hash = "sha256:1fc150d5c3250b170b29410ba682384b14581db722b2531b0d8d33c595f33d01", size = 176238458 },
361
+ { url = "https://files.pythonhosted.org/packages/4b/2a/0a131f572aa09f741c30ccd45a8e56316e8be8dfc7bc19bf0ab7cfef7b19/nvidia_nccl_cu12-2.20.5-py3-none-manylinux2014_x86_64.whl", hash = "sha256:057f6bf9685f75215d0c53bf3ac4a10b3e6578351de307abad9e18a99182af56", size = 176249402 },
362
  ]
363
 
364
  [[package]]
 
391
  { url = "https://files.pythonhosted.org/packages/e3/94/1843518e420fa3ed6919835845df698c7e27e183cb997394e4a670973a65/omegaconf-2.3.0-py3-none-any.whl", hash = "sha256:7b4df175cdb08ba400f45cae3bdcae7ba8365db4d165fc65fd04b050ab63b46b", size = 79500 },
392
  ]
393
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
394
  [[package]]
395
  name = "packaging"
396
  version = "24.1"
 
426
  { url = "https://files.pythonhosted.org/packages/ec/3d/c32a51d848401bd94cabb8767a39621496491ee7cd5199856b77da9b18ad/pillow-11.0.0-pp310-pypy310_pp73-win_amd64.whl", hash = "sha256:224aaa38177597bb179f3ec87eeefcce8e4f85e608025e9cfac60de237ba6316", size = 2567508 },
427
  ]
428
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
429
  [[package]]
430
  name = "psutil"
431
  version = "6.1.0"
 
486
  { url = "https://files.pythonhosted.org/packages/a9/f9/b6bcaf874f410564a78908739c80861a171788ef4d4f76f5009656672dfe/pydantic_core-2.23.4-pp310-pypy310_pp73-win_amd64.whl", hash = "sha256:9a5bce9d23aac8f0cf0836ecfc033896aa8443b501c58d0602dbfd5bd5b37753", size = 1920344 },
487
  ]
488
 
 
 
 
 
 
 
 
 
 
489
  [[package]]
490
  name = "pyyaml"
491
  version = "6.0.2"
 
542
  { url = "https://files.pythonhosted.org/packages/f9/9b/335f9764261e915ed497fcdeb11df5dfd6f7bf257d4a6a2a686d80da4d54/requests-2.32.3-py3-none-any.whl", hash = "sha256:70761cfe03c773ceb22aa2f671b4757976145175cdfca038c02654d061d6dcc6", size = 64928 },
543
  ]
544
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
545
  [[package]]
546
  name = "safetensors"
547
  version = "0.4.5"
 
569
  { url = "https://files.pythonhosted.org/packages/19/46/5d11dc300feaad285c2f1bd784ff3f689f5e0ab6be49aaf568f3a77019eb/safetensors-0.4.5-pp310-pypy310_pp73-musllinux_1_1_x86_64.whl", hash = "sha256:21742b391b859e67b26c0b2ac37f52c9c0944a879a25ad2f9f9f3cd61e7fda8f", size = 606660 },
570
  ]
571
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
572
  [[package]]
573
  name = "sympy"
574
  version = "1.13.3"
 
611
  { url = "https://files.pythonhosted.org/packages/45/b6/36c1bb106bbe96012c9367df89ed01599cada036c0b96d38fbbdbeb75c9f/tokenizers-0.19.1-pp310-pypy310_pp73-musllinux_1_1_x86_64.whl", hash = "sha256:43350270bfc16b06ad3f6f07eab21f089adb835544417afda0f83256a8bf8b75", size = 9945103 },
612
  ]
613
 
 
 
 
 
 
 
 
 
 
 
 
 
614
  [[package]]
615
  name = "torch"
616
+ version = "2.4.1"
617
  source = { registry = "https://pypi.org/simple" }
618
  dependencies = [
619
  { name = "filelock" },
 
636
  { name = "typing-extensions" },
637
  ]
638
  wheels = [
639
+ { url = "https://files.pythonhosted.org/packages/41/05/d540049b1832d1062510efc6829634b7fbef5394c757d8312414fb65a3cb/torch-2.4.1-cp310-cp310-manylinux1_x86_64.whl", hash = "sha256:362f82e23a4cd46341daabb76fba08f04cd646df9bfaf5da50af97cb60ca4971", size = 797072810 },
640
+ { url = "https://files.pythonhosted.org/packages/a0/12/2162df9c47386ae7cedbc938f9703fee4792d93504fab8608d541e71ece3/torch-2.4.1-cp310-cp310-manylinux2014_aarch64.whl", hash = "sha256:e8ac1985c3ff0f60d85b991954cfc2cc25f79c84545aead422763148ed2759e3", size = 89699259 },
641
+ { url = "https://files.pythonhosted.org/packages/5d/4c/b2a59ff0e265f5ee154f0d81e948b1518b94f545357731e1a3245ee5d45b/torch-2.4.1-cp310-cp310-win_amd64.whl", hash = "sha256:91e326e2ccfb1496e3bee58f70ef605aeb27bd26be07ba64f37dcaac3d070ada", size = 199433813 },
642
+ { url = "https://files.pythonhosted.org/packages/dc/fb/1333ba666bbd53846638dd75a7a1d4eaf964aff1c482fc046e2311a1b499/torch-2.4.1-cp310-none-macosx_11_0_arm64.whl", hash = "sha256:d36a8ef100f5bff3e9c3cea934b9e0d7ea277cb8210c7152d34a9a6c5830eadd", size = 62139309 },
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
643
  ]
644
 
645
  [[package]]
 
677
 
678
  [[package]]
679
  name = "triton"
680
+ version = "3.0.0"
681
  source = { registry = "https://pypi.org/simple" }
682
  dependencies = [
683
  { name = "filelock" },
684
  ]
685
  wheels = [
686
+ { url = "https://files.pythonhosted.org/packages/45/27/14cc3101409b9b4b9241d2ba7deaa93535a217a211c86c4cc7151fb12181/triton-3.0.0-1-cp310-cp310-manylinux2014_x86_64.manylinux_2_17_x86_64.whl", hash = "sha256:e1efef76935b2febc365bfadf74bcb65a6f959a9872e5bddf44cc9e0adce1e1a", size = 209376304 },
687
  ]
688
 
689
  [[package]]
 
704
  { url = "https://files.pythonhosted.org/packages/ce/d9/5f4c13cecde62396b0d3fe530a50ccea91e7dfc1ccf0e09c228841bb5ba8/urllib3-2.2.3-py3-none-any.whl", hash = "sha256:ca899ca043dcb1bafa3e262d73aa25c465bfb49e0bd9dd5d59f1d0acba2f8fac", size = 126338 },
705
  ]
706
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
707
  [[package]]
708
  name = "zipp"
709
  version = "3.20.2"