InvokeAI 5.10.0.dev4__tar.gz → 5.10.1__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/InvokeAI.egg-info/PKG-INFO +3 -2
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/InvokeAI.egg-info/SOURCES.txt +15 -9
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/InvokeAI.egg-info/requires.txt +2 -1
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/PKG-INFO +3 -2
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/dependencies.py +2 -1
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/routers/model_manager.py +1 -0
- invokeai-5.10.1/invokeai/app/invocations/cogview4_denoise.py +363 -0
- invokeai-5.10.1/invokeai/app/invocations/cogview4_image_to_latents.py +69 -0
- invokeai-5.10.1/invokeai/app/invocations/cogview4_latents_to_image.py +86 -0
- invokeai-5.10.1/invokeai/app/invocations/cogview4_model_loader.py +55 -0
- invokeai-5.10.1/invokeai/app/invocations/cogview4_text_encoder.py +92 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/fields.py +9 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_denoise.py +3 -3
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_redux.py +50 -4
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/infill.py +4 -1
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/llava_onevision_vllm.py +12 -4
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/metadata.py +4 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/metadata_linked.py +141 -1
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/model.py +5 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/primitives.py +12 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/sd3_denoise.py +3 -3
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/run_app.py +6 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_install/model_install_default.py +8 -5
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_records/model_records_base.py +1 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/invocation_context.py +29 -3
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite/sqlite_util.py +2 -0
- invokeai-5.10.1/invokeai/app/services/shared/sqlite_migrator/migrations/migration_19.py +37 -0
- invokeai-5.10.1/invokeai/app/services/workflow_records/default_workflows/CogView4_TextToImage.json +343 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/step_callback.py +45 -33
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/denoise.py +2 -2
- invokeai-5.10.0.dev4/invokeai/backend/llava_onevision_model.py → invokeai-5.10.1/invokeai/backend/llava_onevision_pipeline.py +3 -24
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/config.py +2 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/legacy_probe.py +5 -0
- invokeai-5.10.1/invokeai/backend/model_manager/load/model_loaders/cogview4.py +60 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/llava_onevision.py +6 -3
- invokeai-5.10.0.dev4/invokeai/backend/model_manager/load/model_loaders/sig_lip_pipeline.py → invokeai-5.10.1/invokeai/backend/model_manager/load/model_loaders/sig_lip.py +3 -3
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_util.py +11 -4
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/starter_models.py +11 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/taxonomy.py +1 -0
- invokeai-5.10.0.dev4/invokeai/backend/flux/extensions/inpaint_extension.py → invokeai-5.10.1/invokeai/backend/rectified_flow/rectified_flow_inpaint_extension.py +11 -3
- invokeai-5.10.1/invokeai/backend/sig_lip/sig_lip_pipeline.py +20 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/diffusion/conditioning_data.py +10 -0
- invokeai-5.10.1/invokeai/frontend/web/dist/assets/App-D8Ndfa3W.js +145 -0
- invokeai-5.10.0.dev4/invokeai/frontend/web/dist/assets/ThemeLocaleProvider-BE0YQ6XM.js → invokeai-5.10.1/invokeai/frontend/web/dist/assets/ThemeLocaleProvider-BOEWUG60.js +1 -1
- invokeai-5.10.1/invokeai/frontend/web/dist/assets/index-em548e7X.js +511 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/index.html +1 -1
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/en.json +21 -6
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/it.json +37 -6
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/ja.json +363 -18
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/vi.json +58 -10
- invokeai-5.10.1/invokeai/version/invokeai_version.py +1 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/pyproject.toml +2 -1
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_model_probe.py +1 -0
- invokeai-5.10.0.dev4/invokeai/backend/sd3/extensions/inpaint_extension.py +0 -58
- invokeai-5.10.0.dev4/invokeai/backend/sig_lip/sig_lip_pipeline.py +0 -43
- invokeai-5.10.0.dev4/invokeai/frontend/cli/__init__.py +0 -0
- invokeai-5.10.0.dev4/invokeai/frontend/web/dist/assets/App-BxptzLdb.js +0 -139
- invokeai-5.10.0.dev4/invokeai/frontend/web/dist/assets/index-kn6zcPGp.js +0 -511
- invokeai-5.10.0.dev4/invokeai/version/invokeai_version.py +0 -1
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/InvokeAI.egg-info/dependency_links.txt +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/InvokeAI.egg-info/entry_points.txt +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/InvokeAI.egg-info/top_level.txt +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/LICENSE +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/LICENSE-SD1+SD2.txt +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/LICENSE-SDXL.txt +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/README.md +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/extract_metadata_from_image.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/no_cache_staticfiles.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/routers/app_info.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/routers/board_images.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/routers/boards.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/routers/download_queue.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/routers/images.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/routers/session_queue.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/routers/style_presets.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/routers/utilities.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/routers/workflows.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api/sockets.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/api_app.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/assets/images/caution.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/baseinvocation.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/batch.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/blend_latents.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/canny.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/collections.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/color_map.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/compel.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/composition-nodes.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/constants.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/content_shuffle.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/controlnet.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/create_denoise_mask.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/create_gradient_mask.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/crop_latents.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/custom_nodes/README.md +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/cv.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/denoise_latents.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/depth_anything.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/dw_openpose.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/facetools.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_control_lora_loader.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_controlnet.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_fill.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_ip_adapter.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_lora_loader.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_model_loader.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_text_encoder.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_vae_decode.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/flux_vae_encode.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/grounding_dino.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/hed.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/ideal_size.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/image.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/image_panels.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/image_to_latents.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/ip_adapter.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/latents_to_image.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/lineart.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/lineart_anime.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/load_custom_nodes.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/mask.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/math.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/mediapipe_face.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/mlsd.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/noise.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/normal_bae.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/param_easing.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/pidi.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/prompt.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/resize_latents.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/scheduler.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/sd3_image_to_latents.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/sd3_latents_to_image.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/sd3_model_loader.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/sd3_text_encoder.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/sdxl.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/segment_anything.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/spandrel_image_to_image.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/strings.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/t2i_adapter.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/tiled_multi_diffusion_denoise_latents.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/tiles.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/upscale.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/invocations/util.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/board_image_records/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/board_image_records/board_image_records_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/board_image_records/board_image_records_sqlite.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/board_images/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/board_images/board_images_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/board_images/board_images_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/board_images/board_images_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/board_records/board_records_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/board_records/board_records_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/board_records/board_records_sqlite.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/boards/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/boards/boards_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/boards/boards_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/boards/boards_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/bulk_download/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/bulk_download/bulk_download_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/bulk_download/bulk_download_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/bulk_download/bulk_download_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/config/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/config/config_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/config/config_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/download/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/download/download_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/download/download_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/events/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/events/events_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/events/events_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/events/events_fastapievents.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/image_files/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/image_files/image_files_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/image_files/image_files_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/image_files/image_files_disk.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/image_records/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/image_records/image_records_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/image_records/image_records_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/image_records/image_records_sqlite.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/images/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/images/images_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/images/images_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/images/images_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/invocation_cache/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/invocation_cache/invocation_cache_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/invocation_cache/invocation_cache_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/invocation_cache/invocation_cache_memory.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/invocation_services.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/invocation_stats/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/invocation_stats/invocation_stats_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/invocation_stats/invocation_stats_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/invocation_stats/invocation_stats_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/invoker.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/item_storage/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/item_storage/item_storage_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/item_storage/item_storage_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/item_storage/item_storage_memory.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_images/model_images_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_images/model_images_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_images/model_images_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_install/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_install/model_install_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_install/model_install_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_load/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_load/model_load_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_load/model_load_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_manager/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_manager/model_manager_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_manager/model_manager_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_manager/model_manager_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_records/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/model_records/model_records_sql.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/names/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/names/names_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/names/names_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/names/names_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/object_serializer/object_serializer_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/object_serializer/object_serializer_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/object_serializer/object_serializer_disk.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/object_serializer/object_serializer_forward_cache.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/session_processor/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/session_processor/session_processor_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/session_processor/session_processor_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/session_processor/session_processor_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/session_queue/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/session_queue/session_queue_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/session_queue/session_queue_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/session_queue/session_queue_sqlite.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/graph.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/pagination.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite/sqlite_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite/sqlite_database.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_1.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_10.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_11.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_12.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_13.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_14.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_15.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_16.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_17.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_18.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_2.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_3.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_4.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_5.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_6.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_7.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_8.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/migrations/migration_9.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/sqlite_migrator_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/shared/sqlite_migrator/sqlite_migrator_impl.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Anime.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Architectural Visualization.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Concept Art (Character).png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Concept Art (Fantasy).png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Concept Art (Painterly).png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Concept Art (Sci-Fi).png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Environment Art.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Illustration.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Interior Design (Visualization).png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Line Art.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Photography (Black and White).png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Photography (General).png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Photography (Landscape).png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Photography (Portrait).png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Photography (Studio Lighting).png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Product Rendering.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Sketch.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/Vehicles.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/default_style_preset_images/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/style_preset_images_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/style_preset_images_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_images/style_preset_images_disk.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_records/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_records/default_style_presets.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_records/style_preset_records_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_records/style_preset_records_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/style_preset_records/style_preset_records_sqlite.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/urls/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/urls/urls_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/urls/urls_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/ESRGAN Upscaling with Canny ControlNet.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/FLUX Image to Image.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/Face Detailer with IP-Adapter & Canny (See Note in Details).json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/Flux Text to Image.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/Multi ControlNet (Canny & Depth).json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/MultiDiffusion SD1.5.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/MultiDiffusion SDXL.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/Prompt from File.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/SD3.5 Text to Image.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/Text to Image - SD1.5.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/Text to Image - SDXL.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/Text to Image with LoRA.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/default_workflows/Tiled Upscaling (Beta).json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/workflow_records_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/workflow_records_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_records/workflow_records_sqlite.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_thumbnails/workflow_thumbnails_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_thumbnails/workflow_thumbnails_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/services/workflow_thumbnails/workflow_thumbnails_disk.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/shared/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/shared/models.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/controlnet_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/custom_openapi.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/metaenum.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/misc.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/model_exclude_null.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/profiler.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/startup_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/suppress_output.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/t5_model_identifier.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/thumbnails.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/ti_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/app/util/torch_cuda_allocator.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/assets/fonts/inter/Inter-Regular.ttf +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/controlnet/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/controlnet/controlnet_flux_output.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/controlnet/instantx_controlnet_flux.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/controlnet/state_dict_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/controlnet/xlabs_controlnet_flux.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/controlnet/zero_module.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/custom_block_processor.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/extensions/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/extensions/base_controlnet_extension.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/extensions/instantx_controlnet_extension.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/extensions/regional_prompting_extension.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/extensions/xlabs_controlnet_extension.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/extensions/xlabs_ip_adapter_extension.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/flux_state_dict_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/ip_adapter/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/ip_adapter/ip_double_stream_block_processor.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/ip_adapter/state_dict_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/ip_adapter/xlabs_ip_adapter_flux.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/math.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/model.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/modules/autoencoder.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/modules/conditioner.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/modules/layers.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/redux/flux_redux_model.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/redux/flux_redux_state_dict_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/sampling_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/text_conditioning.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/flux/util.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/assets/CIELab_to_UPLab.icc +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/basicsr/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/basicsr/arch_util.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/basicsr/rrdbnet_arch.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/canny.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/composition.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/content_shuffle.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/depth_anything/depth_anything_pipeline.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/dw_openpose/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/dw_openpose/onnxdet.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/dw_openpose/onnxpose.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/dw_openpose/utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/grounding_dino/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/grounding_dino/detection_result.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/grounding_dino/grounding_dino_pipeline.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/hed.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/infill_methods/cv2_inpaint.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/infill_methods/lama.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/infill_methods/mosaic.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/infill_methods/patchmatch.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/infill_methods/tile.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/invisible_watermark.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/lineart.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/lineart_anime.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/mediapipe_face/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/mediapipe_face/mediapipe_face_common.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/mlsd/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/mlsd/models/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/mlsd/models/mbv2_mlsd_large.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/mlsd/models/mbv2_mlsd_tiny.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/mlsd/utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/NNET.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/baseline.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/decoder.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/caffe2_benchmark.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/caffe2_validate.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/activations/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/activations/activations.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/activations/activations_jit.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/activations/activations_me.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/config.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/conv2d_layers.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/efficientnet_builder.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/gen_efficientnet.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/helpers.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/mobilenetv3.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/model_factory.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/geffnet/version.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/hubconf.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/onnx_export.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/onnx_optimize.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/onnx_to_caffe.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/onnx_validate.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/setup.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/efficientnet_repo/validate.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/encoder.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/normal_bae/nets/submodules/submodules.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/pidi/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/pidi/model.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/pngwriter.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/realesrgan/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/realesrgan/realesrgan.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/safety_checker.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/segment_anything/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/segment_anything/mask_refinement.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/segment_anything/segment_anything_pipeline.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/image_util/util.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/ip_adapter/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/ip_adapter/ip_adapter.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/ip_adapter/ip_attention_weights.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/ip_adapter/resampler.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_hash/hash_validator.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_hash/model_hash.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/load_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/load_default.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/memory_snapshot.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/cache_record.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/cache_stats.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/cached_model/cached_model_only_full_load.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/cached_model/cached_model_with_partial_load.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/dev_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/model_cache.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/cast_to_device.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/custom_conv1d.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/custom_conv2d.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/custom_embedding.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/custom_flux_rms_norm.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/custom_group_norm.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/custom_invoke_linear_8_bit_lt.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/custom_invoke_linear_nf4.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/custom_linear.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/custom_module_mixin.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/torch_module_autocast/torch_module_autocast.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_cache/utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loader_registry.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/clip_vision.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/controlnet.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/flux.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/generic_diffusers.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/ip_adapter.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/lora.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/onnx.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/spandrel_image_to_image.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/stable_diffusion.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/textual_inversion.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/model_loaders/vae.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/load/optimizations.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/merge.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/metadata/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/metadata/fetch/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/metadata/fetch/fetch_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/metadata/fetch/huggingface.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/metadata/metadata_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/model_on_disk.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/search.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/util/libc_util.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/util/model_util.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_manager/util/select_hf_files.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/model_patcher.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/onnx/onnx_runtime.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layer_patcher.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/base_layer_patch.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/dora_layer.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/flux_control_lora_layer.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/full_layer.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/ia3_layer.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/loha_layer.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/lokr_layer.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/lora_layer.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/lora_layer_base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/merged_layer_patch.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/norm_layer.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/param_shape_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/set_parameter_layer.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/layers/utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/lora_conversions/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/lora_conversions/flux_control_lora_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/lora_conversions/flux_diffusers_lora_conversion_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/lora_conversions/flux_kohya_lora_conversion_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/lora_conversions/flux_lora_constants.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/lora_conversions/flux_onetrainer_lora_conversion_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/lora_conversions/formats.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/lora_conversions/kohya_key_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/lora_conversions/sd_lora_conversion_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/lora_conversions/sdxl_lora_conversion_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/model_patch_raw.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/patches/pad_with_zeros.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/quantization/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/quantization/bnb_llm_int8.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/quantization/bnb_nf4.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/quantization/gguf/ggml_tensor.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/quantization/gguf/loaders.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/quantization/gguf/utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/quantization/scripts/load_flux_model_bnb_llm_int8.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/quantization/scripts/load_flux_model_bnb_nf4.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/quantization/scripts/quantize_t5_xxl_bnb_llm_int8.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/raw_model.py +0 -0
- {invokeai-5.10.0.dev4/invokeai/backend/sd3 → invokeai-5.10.1/invokeai/backend/rectified_flow}/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/spandrel_image_to_image_model.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/denoise_context.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/diffusers_pipeline.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/diffusion/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/diffusion/custom_atttention.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/diffusion/regional_ip_data.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/diffusion/regional_prompt_data.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/diffusion/shared_invokeai_diffusion.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/diffusion/unet_attention_patcher.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/diffusion_backend.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extension_callback_type.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions/base.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions/controlnet.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions/freeu.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions/inpaint.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions/inpaint_model.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions/lora.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions/preview.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions/rescale_cfg.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions/seamless.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions/t2i_adapter.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/extensions_manager.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/multi_diffusion_pipeline.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/schedulers/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/schedulers/schedulers.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/stable_diffusion/vae_tiling.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/textual_inversion.py +0 -0
- {invokeai-5.10.0.dev4/invokeai/backend/sd3/extensions → invokeai-5.10.1/invokeai/backend/tiles}/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/tiles/tiles.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/tiles/utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/attention.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/build_line.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/calc_tensor_size.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/catch_sigint.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/db_maintenance.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/devices.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/hotfixes.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/logging.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/mask.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/original_weights_storage.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/prefix_logger_adapter.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/silence_warnings.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/test_utils.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/backend/util/util.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/controlnet/cldm_v15.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/controlnet/cldm_v21.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/sd_xl_base.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/sd_xl_inpaint.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/sd_xl_refiner.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v1-finetune.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v1-finetune_style.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v1-inference-v.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v1-inference.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v1-inpainting-inference.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v1-m1-finetune.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v2-inference-v.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v2-inference.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v2-inpainting-inference-v.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v2-inpainting-inference.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/configs/stable-diffusion/v2-midas-inference.yaml +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/__init__.py +0 -0
- {invokeai-5.10.0.dev4/invokeai/backend/tiles → invokeai-5.10.1/invokeai/frontend/cli}/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/cli/arg_parser.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/install/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/install/import_images.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/ThemeLocaleProvider-DMkJ1hTD.css +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/commercial-license-bg-C_dHp7on.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/denoising-strength-4mznP2tj.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/commercial-license-bg.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/denoising-strength.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-alert-favicon.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-avatar-circle.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-avatar-square.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-favicon.png +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-favicon.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-key-char-lrg.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-key-char-sml.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-key-wht-lrg.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-key-wht-sml.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-symbol-char-lrg.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-symbol-char-sml.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-symbol-wht-lrg.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-symbol-wht-sml.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-symbol-ylw-lrg.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-tag-char-lrg.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-tag-char-sml.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-tag-lrg.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-tag-sml.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-wordmark-charcoal.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/invoke-wordmark-white.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/images/mask.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/inter-cyrillic-ext-wght-normal-B2xhLi22.woff2 +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/inter-cyrillic-wght-normal-CMZtQduZ.woff2 +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/inter-greek-ext-wght-normal-CGAr0uHJ.woff2 +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/inter-greek-wght-normal-CaVNZxsx.woff2 +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/inter-latin-ext-wght-normal-CFHvXkgd.woff2 +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/inter-latin-wght-normal-C2S99t-D.woff2 +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/inter-vietnamese-wght-normal-CBcvBZtf.woff2 +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/assets/worker-Dywf1EVc.js +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/ar.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/az.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/bg.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/de.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/es.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/fi.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/fr.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/he.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/hu.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/ko.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/mn.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/nl.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/pl.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/pt.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/pt_BR.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/ro.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/ru.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/sv.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/tr.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/uk.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/zh_CN.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/dist/locales/zh_Hant.json +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/scripts/clean_translations.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/frontend/web/static/docs/invoke-favicon-docs.svg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/invocation_api/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/invokeai/version/__init__.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/setup.cfg +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_config.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_dangerously_run_function_in_subprocess.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_docs.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_graph_execution_state.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_imports.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_invocation_cache_memory.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_item_storage_memory.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_model_hash.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_model_search.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_node_graph.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_nodes.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_object_serializer_disk.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_path.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_profiler.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_session_queue.py +0 -0
- {invokeai-5.10.0.dev4 → invokeai-5.10.1}/tests/test_sqlite_migrator.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: InvokeAI
|
|
3
|
-
Version: 5.10.
|
|
3
|
+
Version: 5.10.1
|
|
4
4
|
Summary: An implementation of Stable Diffusion which provides various new features and options to aid the image generation process
|
|
5
5
|
Author-email: The InvokeAI Project <lincoln.stein@gmail.com>
|
|
6
6
|
License: Apache License
|
|
@@ -212,7 +212,7 @@ License-File: LICENSE-SDXL.txt
|
|
|
212
212
|
Requires-Dist: accelerate
|
|
213
213
|
Requires-Dist: bitsandbytes; sys_platform != "darwin"
|
|
214
214
|
Requires-Dist: compel==2.0.2
|
|
215
|
-
Requires-Dist: diffusers[torch]
|
|
215
|
+
Requires-Dist: diffusers[torch]==0.33.0
|
|
216
216
|
Requires-Dist: gguf
|
|
217
217
|
Requires-Dist: invisible-watermark==0.2.0
|
|
218
218
|
Requires-Dist: mediapipe==0.10.14
|
|
@@ -221,6 +221,7 @@ Requires-Dist: onnx==1.16.1
|
|
|
221
221
|
Requires-Dist: onnxruntime==1.19.2
|
|
222
222
|
Requires-Dist: opencv-python==4.9.0.80
|
|
223
223
|
Requires-Dist: safetensors
|
|
224
|
+
Requires-Dist: sentencepiece
|
|
224
225
|
Requires-Dist: spandrel
|
|
225
226
|
Requires-Dist: torch~=2.6.0
|
|
226
227
|
Requires-Dist: torchsde
|
|
@@ -32,6 +32,11 @@ invokeai/app/invocations/baseinvocation.py
|
|
|
32
32
|
invokeai/app/invocations/batch.py
|
|
33
33
|
invokeai/app/invocations/blend_latents.py
|
|
34
34
|
invokeai/app/invocations/canny.py
|
|
35
|
+
invokeai/app/invocations/cogview4_denoise.py
|
|
36
|
+
invokeai/app/invocations/cogview4_image_to_latents.py
|
|
37
|
+
invokeai/app/invocations/cogview4_latents_to_image.py
|
|
38
|
+
invokeai/app/invocations/cogview4_model_loader.py
|
|
39
|
+
invokeai/app/invocations/cogview4_text_encoder.py
|
|
35
40
|
invokeai/app/invocations/collections.py
|
|
36
41
|
invokeai/app/invocations/color_map.py
|
|
37
42
|
invokeai/app/invocations/compel.py
|
|
@@ -212,6 +217,7 @@ invokeai/app/services/shared/sqlite_migrator/migrations/migration_15.py
|
|
|
212
217
|
invokeai/app/services/shared/sqlite_migrator/migrations/migration_16.py
|
|
213
218
|
invokeai/app/services/shared/sqlite_migrator/migrations/migration_17.py
|
|
214
219
|
invokeai/app/services/shared/sqlite_migrator/migrations/migration_18.py
|
|
220
|
+
invokeai/app/services/shared/sqlite_migrator/migrations/migration_19.py
|
|
215
221
|
invokeai/app/services/shared/sqlite_migrator/migrations/migration_2.py
|
|
216
222
|
invokeai/app/services/shared/sqlite_migrator/migrations/migration_3.py
|
|
217
223
|
invokeai/app/services/shared/sqlite_migrator/migrations/migration_4.py
|
|
@@ -254,6 +260,7 @@ invokeai/app/services/workflow_records/__init__.py
|
|
|
254
260
|
invokeai/app/services/workflow_records/workflow_records_base.py
|
|
255
261
|
invokeai/app/services/workflow_records/workflow_records_common.py
|
|
256
262
|
invokeai/app/services/workflow_records/workflow_records_sqlite.py
|
|
263
|
+
invokeai/app/services/workflow_records/default_workflows/CogView4_TextToImage.json
|
|
257
264
|
invokeai/app/services/workflow_records/default_workflows/ESRGAN Upscaling with Canny ControlNet.json
|
|
258
265
|
invokeai/app/services/workflow_records/default_workflows/FLUX Image to Image.json
|
|
259
266
|
invokeai/app/services/workflow_records/default_workflows/Face Detailer with IP-Adapter & Canny (See Note in Details).json
|
|
@@ -288,7 +295,7 @@ invokeai/app/util/ti_utils.py
|
|
|
288
295
|
invokeai/app/util/torch_cuda_allocator.py
|
|
289
296
|
invokeai/assets/fonts/inter/Inter-Regular.ttf
|
|
290
297
|
invokeai/backend/__init__.py
|
|
291
|
-
invokeai/backend/
|
|
298
|
+
invokeai/backend/llava_onevision_pipeline.py
|
|
292
299
|
invokeai/backend/model_patcher.py
|
|
293
300
|
invokeai/backend/raw_model.py
|
|
294
301
|
invokeai/backend/spandrel_image_to_image_model.py
|
|
@@ -309,7 +316,6 @@ invokeai/backend/flux/controlnet/xlabs_controlnet_flux.py
|
|
|
309
316
|
invokeai/backend/flux/controlnet/zero_module.py
|
|
310
317
|
invokeai/backend/flux/extensions/__init__.py
|
|
311
318
|
invokeai/backend/flux/extensions/base_controlnet_extension.py
|
|
312
|
-
invokeai/backend/flux/extensions/inpaint_extension.py
|
|
313
319
|
invokeai/backend/flux/extensions/instantx_controlnet_extension.py
|
|
314
320
|
invokeai/backend/flux/extensions/regional_prompting_extension.py
|
|
315
321
|
invokeai/backend/flux/extensions/xlabs_controlnet_extension.py
|
|
@@ -442,6 +448,7 @@ invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_mod
|
|
|
442
448
|
invokeai/backend/model_manager/load/model_cache/torch_module_autocast/custom_modules/utils.py
|
|
443
449
|
invokeai/backend/model_manager/load/model_loaders/__init__.py
|
|
444
450
|
invokeai/backend/model_manager/load/model_loaders/clip_vision.py
|
|
451
|
+
invokeai/backend/model_manager/load/model_loaders/cogview4.py
|
|
445
452
|
invokeai/backend/model_manager/load/model_loaders/controlnet.py
|
|
446
453
|
invokeai/backend/model_manager/load/model_loaders/flux.py
|
|
447
454
|
invokeai/backend/model_manager/load/model_loaders/generic_diffusers.py
|
|
@@ -449,7 +456,7 @@ invokeai/backend/model_manager/load/model_loaders/ip_adapter.py
|
|
|
449
456
|
invokeai/backend/model_manager/load/model_loaders/llava_onevision.py
|
|
450
457
|
invokeai/backend/model_manager/load/model_loaders/lora.py
|
|
451
458
|
invokeai/backend/model_manager/load/model_loaders/onnx.py
|
|
452
|
-
invokeai/backend/model_manager/load/model_loaders/
|
|
459
|
+
invokeai/backend/model_manager/load/model_loaders/sig_lip.py
|
|
453
460
|
invokeai/backend/model_manager/load/model_loaders/spandrel_image_to_image.py
|
|
454
461
|
invokeai/backend/model_manager/load/model_loaders/stable_diffusion.py
|
|
455
462
|
invokeai/backend/model_manager/load/model_loaders/textual_inversion.py
|
|
@@ -501,9 +508,8 @@ invokeai/backend/quantization/gguf/utils.py
|
|
|
501
508
|
invokeai/backend/quantization/scripts/load_flux_model_bnb_llm_int8.py
|
|
502
509
|
invokeai/backend/quantization/scripts/load_flux_model_bnb_nf4.py
|
|
503
510
|
invokeai/backend/quantization/scripts/quantize_t5_xxl_bnb_llm_int8.py
|
|
504
|
-
invokeai/backend/
|
|
505
|
-
invokeai/backend/
|
|
506
|
-
invokeai/backend/sd3/extensions/inpaint_extension.py
|
|
511
|
+
invokeai/backend/rectified_flow/__init__.py
|
|
512
|
+
invokeai/backend/rectified_flow/rectified_flow_inpaint_extension.py
|
|
507
513
|
invokeai/backend/sig_lip/sig_lip_pipeline.py
|
|
508
514
|
invokeai/backend/stable_diffusion/__init__.py
|
|
509
515
|
invokeai/backend/stable_diffusion/denoise_context.py
|
|
@@ -573,12 +579,12 @@ invokeai/frontend/install/__init__.py
|
|
|
573
579
|
invokeai/frontend/install/import_images.py
|
|
574
580
|
invokeai/frontend/web/__init__.py
|
|
575
581
|
invokeai/frontend/web/dist/index.html
|
|
576
|
-
invokeai/frontend/web/dist/assets/App-
|
|
577
|
-
invokeai/frontend/web/dist/assets/ThemeLocaleProvider-
|
|
582
|
+
invokeai/frontend/web/dist/assets/App-D8Ndfa3W.js
|
|
583
|
+
invokeai/frontend/web/dist/assets/ThemeLocaleProvider-BOEWUG60.js
|
|
578
584
|
invokeai/frontend/web/dist/assets/ThemeLocaleProvider-DMkJ1hTD.css
|
|
579
585
|
invokeai/frontend/web/dist/assets/commercial-license-bg-C_dHp7on.png
|
|
580
586
|
invokeai/frontend/web/dist/assets/denoising-strength-4mznP2tj.png
|
|
581
|
-
invokeai/frontend/web/dist/assets/index-
|
|
587
|
+
invokeai/frontend/web/dist/assets/index-em548e7X.js
|
|
582
588
|
invokeai/frontend/web/dist/assets/inter-cyrillic-ext-wght-normal-B2xhLi22.woff2
|
|
583
589
|
invokeai/frontend/web/dist/assets/inter-cyrillic-wght-normal-CMZtQduZ.woff2
|
|
584
590
|
invokeai/frontend/web/dist/assets/inter-greek-ext-wght-normal-CGAr0uHJ.woff2
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
accelerate
|
|
2
2
|
compel==2.0.2
|
|
3
|
-
diffusers[torch]
|
|
3
|
+
diffusers[torch]==0.33.0
|
|
4
4
|
gguf
|
|
5
5
|
invisible-watermark==0.2.0
|
|
6
6
|
mediapipe==0.10.14
|
|
@@ -9,6 +9,7 @@ onnx==1.16.1
|
|
|
9
9
|
onnxruntime==1.19.2
|
|
10
10
|
opencv-python==4.9.0.80
|
|
11
11
|
safetensors
|
|
12
|
+
sentencepiece
|
|
12
13
|
spandrel
|
|
13
14
|
torch~=2.6.0
|
|
14
15
|
torchsde
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: InvokeAI
|
|
3
|
-
Version: 5.10.
|
|
3
|
+
Version: 5.10.1
|
|
4
4
|
Summary: An implementation of Stable Diffusion which provides various new features and options to aid the image generation process
|
|
5
5
|
Author-email: The InvokeAI Project <lincoln.stein@gmail.com>
|
|
6
6
|
License: Apache License
|
|
@@ -212,7 +212,7 @@ License-File: LICENSE-SDXL.txt
|
|
|
212
212
|
Requires-Dist: accelerate
|
|
213
213
|
Requires-Dist: bitsandbytes; sys_platform != "darwin"
|
|
214
214
|
Requires-Dist: compel==2.0.2
|
|
215
|
-
Requires-Dist: diffusers[torch]
|
|
215
|
+
Requires-Dist: diffusers[torch]==0.33.0
|
|
216
216
|
Requires-Dist: gguf
|
|
217
217
|
Requires-Dist: invisible-watermark==0.2.0
|
|
218
218
|
Requires-Dist: mediapipe==0.10.14
|
|
@@ -221,6 +221,7 @@ Requires-Dist: onnx==1.16.1
|
|
|
221
221
|
Requires-Dist: onnxruntime==1.19.2
|
|
222
222
|
Requires-Dist: opencv-python==4.9.0.80
|
|
223
223
|
Requires-Dist: safetensors
|
|
224
|
+
Requires-Dist: sentencepiece
|
|
224
225
|
Requires-Dist: spandrel
|
|
225
226
|
Requires-Dist: torch~=2.6.0
|
|
226
227
|
Requires-Dist: torchsde
|
|
@@ -39,6 +39,7 @@ from invokeai.app.services.workflow_records.workflow_records_sqlite import Sqlit
|
|
|
39
39
|
from invokeai.app.services.workflow_thumbnails.workflow_thumbnails_disk import WorkflowThumbnailFileStorageDisk
|
|
40
40
|
from invokeai.backend.stable_diffusion.diffusion.conditioning_data import (
|
|
41
41
|
BasicConditioningInfo,
|
|
42
|
+
CogView4ConditioningInfo,
|
|
42
43
|
ConditioningFieldData,
|
|
43
44
|
FLUXConditioningInfo,
|
|
44
45
|
SD3ConditioningInfo,
|
|
@@ -112,7 +113,6 @@ class ApiDependencies:
|
|
|
112
113
|
safe_globals=[torch.Tensor],
|
|
113
114
|
ephemeral=True,
|
|
114
115
|
),
|
|
115
|
-
max_cache_size=0,
|
|
116
116
|
)
|
|
117
117
|
conditioning = ObjectSerializerForwardCache(
|
|
118
118
|
ObjectSerializerDisk[ConditioningFieldData](
|
|
@@ -123,6 +123,7 @@ class ApiDependencies:
|
|
|
123
123
|
SDXLConditioningInfo,
|
|
124
124
|
FLUXConditioningInfo,
|
|
125
125
|
SD3ConditioningInfo,
|
|
126
|
+
CogView4ConditioningInfo,
|
|
126
127
|
],
|
|
127
128
|
ephemeral=True,
|
|
128
129
|
),
|
|
@@ -0,0 +1,363 @@
|
|
|
1
|
+
from typing import Callable, Optional
|
|
2
|
+
|
|
3
|
+
import torch
|
|
4
|
+
import torchvision.transforms as tv_transforms
|
|
5
|
+
from diffusers.models.transformers.transformer_cogview4 import CogView4Transformer2DModel
|
|
6
|
+
from torchvision.transforms.functional import resize as tv_resize
|
|
7
|
+
from tqdm import tqdm
|
|
8
|
+
|
|
9
|
+
from invokeai.app.invocations.baseinvocation import BaseInvocation, Classification, invocation
|
|
10
|
+
from invokeai.app.invocations.constants import LATENT_SCALE_FACTOR
|
|
11
|
+
from invokeai.app.invocations.fields import (
|
|
12
|
+
CogView4ConditioningField,
|
|
13
|
+
DenoiseMaskField,
|
|
14
|
+
FieldDescriptions,
|
|
15
|
+
Input,
|
|
16
|
+
InputField,
|
|
17
|
+
LatentsField,
|
|
18
|
+
WithBoard,
|
|
19
|
+
WithMetadata,
|
|
20
|
+
)
|
|
21
|
+
from invokeai.app.invocations.model import TransformerField
|
|
22
|
+
from invokeai.app.invocations.primitives import LatentsOutput
|
|
23
|
+
from invokeai.app.services.shared.invocation_context import InvocationContext
|
|
24
|
+
from invokeai.backend.flux.sampling_utils import clip_timestep_schedule_fractional
|
|
25
|
+
from invokeai.backend.model_manager.config import BaseModelType
|
|
26
|
+
from invokeai.backend.rectified_flow.rectified_flow_inpaint_extension import RectifiedFlowInpaintExtension
|
|
27
|
+
from invokeai.backend.stable_diffusion.diffusers_pipeline import PipelineIntermediateState
|
|
28
|
+
from invokeai.backend.stable_diffusion.diffusion.conditioning_data import CogView4ConditioningInfo
|
|
29
|
+
from invokeai.backend.util.devices import TorchDevice
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
@invocation(
|
|
33
|
+
"cogview4_denoise",
|
|
34
|
+
title="Denoise - CogView4",
|
|
35
|
+
tags=["image", "cogview4"],
|
|
36
|
+
category="image",
|
|
37
|
+
version="1.0.0",
|
|
38
|
+
classification=Classification.Prototype,
|
|
39
|
+
)
|
|
40
|
+
class CogView4DenoiseInvocation(BaseInvocation, WithMetadata, WithBoard):
|
|
41
|
+
"""Run the denoising process with a CogView4 model."""
|
|
42
|
+
|
|
43
|
+
# If latents is provided, this means we are doing image-to-image.
|
|
44
|
+
latents: Optional[LatentsField] = InputField(
|
|
45
|
+
default=None, description=FieldDescriptions.latents, input=Input.Connection
|
|
46
|
+
)
|
|
47
|
+
# denoise_mask is used for image-to-image inpainting. Only the masked region is modified.
|
|
48
|
+
denoise_mask: Optional[DenoiseMaskField] = InputField(
|
|
49
|
+
default=None, description=FieldDescriptions.denoise_mask, input=Input.Connection
|
|
50
|
+
)
|
|
51
|
+
denoising_start: float = InputField(default=0.0, ge=0, le=1, description=FieldDescriptions.denoising_start)
|
|
52
|
+
denoising_end: float = InputField(default=1.0, ge=0, le=1, description=FieldDescriptions.denoising_end)
|
|
53
|
+
transformer: TransformerField = InputField(
|
|
54
|
+
description=FieldDescriptions.cogview4_model, input=Input.Connection, title="Transformer"
|
|
55
|
+
)
|
|
56
|
+
positive_conditioning: CogView4ConditioningField = InputField(
|
|
57
|
+
description=FieldDescriptions.positive_cond, input=Input.Connection
|
|
58
|
+
)
|
|
59
|
+
negative_conditioning: CogView4ConditioningField = InputField(
|
|
60
|
+
description=FieldDescriptions.negative_cond, input=Input.Connection
|
|
61
|
+
)
|
|
62
|
+
cfg_scale: float | list[float] = InputField(default=3.5, description=FieldDescriptions.cfg_scale, title="CFG Scale")
|
|
63
|
+
width: int = InputField(default=1024, multiple_of=32, description="Width of the generated image.")
|
|
64
|
+
height: int = InputField(default=1024, multiple_of=32, description="Height of the generated image.")
|
|
65
|
+
steps: int = InputField(default=25, gt=0, description=FieldDescriptions.steps)
|
|
66
|
+
seed: int = InputField(default=0, description="Randomness seed for reproducibility.")
|
|
67
|
+
|
|
68
|
+
@torch.no_grad()
|
|
69
|
+
def invoke(self, context: InvocationContext) -> LatentsOutput:
|
|
70
|
+
latents = self._run_diffusion(context)
|
|
71
|
+
latents = latents.detach().to("cpu")
|
|
72
|
+
|
|
73
|
+
name = context.tensors.save(tensor=latents)
|
|
74
|
+
return LatentsOutput.build(latents_name=name, latents=latents, seed=None)
|
|
75
|
+
|
|
76
|
+
def _prep_inpaint_mask(self, context: InvocationContext, latents: torch.Tensor) -> torch.Tensor | None:
|
|
77
|
+
"""Prepare the inpaint mask.
|
|
78
|
+
- Loads the mask
|
|
79
|
+
- Resizes if necessary
|
|
80
|
+
- Casts to same device/dtype as latents
|
|
81
|
+
|
|
82
|
+
Args:
|
|
83
|
+
context (InvocationContext): The invocation context, for loading the inpaint mask.
|
|
84
|
+
latents (torch.Tensor): A latent image tensor. Used to determine the target shape, device, and dtype for the
|
|
85
|
+
inpaint mask.
|
|
86
|
+
|
|
87
|
+
Returns:
|
|
88
|
+
torch.Tensor | None: Inpaint mask. Values of 0.0 represent the regions to be fully denoised, and 1.0
|
|
89
|
+
represent the regions to be preserved.
|
|
90
|
+
"""
|
|
91
|
+
if self.denoise_mask is None:
|
|
92
|
+
return None
|
|
93
|
+
mask = context.tensors.load(self.denoise_mask.mask_name)
|
|
94
|
+
|
|
95
|
+
# The input denoise_mask contains values in [0, 1], where 0.0 represents the regions to be fully denoised, and
|
|
96
|
+
# 1.0 represents the regions to be preserved.
|
|
97
|
+
# We invert the mask so that the regions to be preserved are 0.0 and the regions to be denoised are 1.0.
|
|
98
|
+
mask = 1.0 - mask
|
|
99
|
+
|
|
100
|
+
_, _, latent_height, latent_width = latents.shape
|
|
101
|
+
mask = tv_resize(
|
|
102
|
+
img=mask,
|
|
103
|
+
size=[latent_height, latent_width],
|
|
104
|
+
interpolation=tv_transforms.InterpolationMode.BILINEAR,
|
|
105
|
+
antialias=False,
|
|
106
|
+
)
|
|
107
|
+
|
|
108
|
+
mask = mask.to(device=latents.device, dtype=latents.dtype)
|
|
109
|
+
return mask
|
|
110
|
+
|
|
111
|
+
def _load_text_conditioning(
|
|
112
|
+
self,
|
|
113
|
+
context: InvocationContext,
|
|
114
|
+
conditioning_name: str,
|
|
115
|
+
dtype: torch.dtype,
|
|
116
|
+
device: torch.device,
|
|
117
|
+
) -> torch.Tensor:
|
|
118
|
+
# Load the conditioning data.
|
|
119
|
+
cond_data = context.conditioning.load(conditioning_name)
|
|
120
|
+
assert len(cond_data.conditionings) == 1
|
|
121
|
+
cogview4_conditioning = cond_data.conditionings[0]
|
|
122
|
+
assert isinstance(cogview4_conditioning, CogView4ConditioningInfo)
|
|
123
|
+
cogview4_conditioning = cogview4_conditioning.to(dtype=dtype, device=device)
|
|
124
|
+
|
|
125
|
+
return cogview4_conditioning.glm_embeds
|
|
126
|
+
|
|
127
|
+
def _get_noise(
|
|
128
|
+
self,
|
|
129
|
+
batch_size: int,
|
|
130
|
+
num_channels_latents: int,
|
|
131
|
+
height: int,
|
|
132
|
+
width: int,
|
|
133
|
+
dtype: torch.dtype,
|
|
134
|
+
device: torch.device,
|
|
135
|
+
seed: int,
|
|
136
|
+
) -> torch.Tensor:
|
|
137
|
+
# We always generate noise on the same device and dtype then cast to ensure consistency across devices/dtypes.
|
|
138
|
+
rand_device = "cpu"
|
|
139
|
+
rand_dtype = torch.float16
|
|
140
|
+
|
|
141
|
+
return torch.randn(
|
|
142
|
+
batch_size,
|
|
143
|
+
num_channels_latents,
|
|
144
|
+
int(height) // LATENT_SCALE_FACTOR,
|
|
145
|
+
int(width) // LATENT_SCALE_FACTOR,
|
|
146
|
+
device=rand_device,
|
|
147
|
+
dtype=rand_dtype,
|
|
148
|
+
generator=torch.Generator(device=rand_device).manual_seed(seed),
|
|
149
|
+
).to(device=device, dtype=dtype)
|
|
150
|
+
|
|
151
|
+
def _prepare_cfg_scale(self, num_timesteps: int) -> list[float]:
|
|
152
|
+
"""Prepare the CFG scale list.
|
|
153
|
+
|
|
154
|
+
Args:
|
|
155
|
+
num_timesteps (int): The number of timesteps in the scheduler. Could be different from num_steps depending
|
|
156
|
+
on the scheduler used (e.g. higher order schedulers).
|
|
157
|
+
|
|
158
|
+
Returns:
|
|
159
|
+
list[float]: _description_
|
|
160
|
+
"""
|
|
161
|
+
if isinstance(self.cfg_scale, float):
|
|
162
|
+
cfg_scale = [self.cfg_scale] * num_timesteps
|
|
163
|
+
elif isinstance(self.cfg_scale, list):
|
|
164
|
+
assert len(self.cfg_scale) == num_timesteps
|
|
165
|
+
cfg_scale = self.cfg_scale
|
|
166
|
+
else:
|
|
167
|
+
raise ValueError(f"Invalid CFG scale type: {type(self.cfg_scale)}")
|
|
168
|
+
|
|
169
|
+
return cfg_scale
|
|
170
|
+
|
|
171
|
+
def _convert_timesteps_to_sigmas(self, image_seq_len: int, timesteps: torch.Tensor) -> list[float]:
|
|
172
|
+
# The logic to prepare the timestep / sigma schedule is based on:
|
|
173
|
+
# https://github.com/huggingface/diffusers/blob/b38450d5d2e5b87d5ff7088ee5798c85587b9635/src/diffusers/pipelines/cogview4/pipeline_cogview4.py#L575-L595
|
|
174
|
+
# The default FlowMatchEulerDiscreteScheduler configs are based on:
|
|
175
|
+
# https://huggingface.co/THUDM/CogView4-6B/blob/fb6f57289c73ac6d139e8d81bd5a4602d1877847/scheduler/scheduler_config.json
|
|
176
|
+
# This implementation differs slightly from the original for the sake of simplicity (differs in terminal value
|
|
177
|
+
# handling, not quantizing timesteps to integers, etc.).
|
|
178
|
+
|
|
179
|
+
def calculate_timestep_shift(
|
|
180
|
+
image_seq_len: int, base_seq_len: int = 256, base_shift: float = 0.25, max_shift: float = 0.75
|
|
181
|
+
) -> float:
|
|
182
|
+
m = (image_seq_len / base_seq_len) ** 0.5
|
|
183
|
+
mu = m * max_shift + base_shift
|
|
184
|
+
return mu
|
|
185
|
+
|
|
186
|
+
def time_shift_linear(mu: float, sigma: float, t: torch.Tensor) -> torch.Tensor:
|
|
187
|
+
return mu / (mu + (1 / t - 1) ** sigma)
|
|
188
|
+
|
|
189
|
+
mu = calculate_timestep_shift(image_seq_len)
|
|
190
|
+
sigmas = time_shift_linear(mu, 1.0, timesteps)
|
|
191
|
+
return sigmas.tolist()
|
|
192
|
+
|
|
193
|
+
def _run_diffusion(
|
|
194
|
+
self,
|
|
195
|
+
context: InvocationContext,
|
|
196
|
+
):
|
|
197
|
+
inference_dtype = torch.bfloat16
|
|
198
|
+
device = TorchDevice.choose_torch_device()
|
|
199
|
+
|
|
200
|
+
transformer_info = context.models.load(self.transformer.transformer)
|
|
201
|
+
assert isinstance(transformer_info.model, CogView4Transformer2DModel)
|
|
202
|
+
|
|
203
|
+
# Load/process the conditioning data.
|
|
204
|
+
# TODO(ryand): Make CFG optional.
|
|
205
|
+
do_classifier_free_guidance = True
|
|
206
|
+
pos_prompt_embeds = self._load_text_conditioning(
|
|
207
|
+
context=context,
|
|
208
|
+
conditioning_name=self.positive_conditioning.conditioning_name,
|
|
209
|
+
dtype=inference_dtype,
|
|
210
|
+
device=device,
|
|
211
|
+
)
|
|
212
|
+
neg_prompt_embeds = self._load_text_conditioning(
|
|
213
|
+
context=context,
|
|
214
|
+
conditioning_name=self.negative_conditioning.conditioning_name,
|
|
215
|
+
dtype=inference_dtype,
|
|
216
|
+
device=device,
|
|
217
|
+
)
|
|
218
|
+
|
|
219
|
+
# Prepare misc. conditioning variables.
|
|
220
|
+
# TODO(ryand): We could expose these as params (like with SDXL). But, we should experiment to see if they are
|
|
221
|
+
# useful first.
|
|
222
|
+
original_size = torch.tensor([(self.height, self.width)], dtype=pos_prompt_embeds.dtype, device=device)
|
|
223
|
+
target_size = torch.tensor([(self.height, self.width)], dtype=pos_prompt_embeds.dtype, device=device)
|
|
224
|
+
crops_coords_top_left = torch.tensor([(0, 0)], dtype=pos_prompt_embeds.dtype, device=device)
|
|
225
|
+
|
|
226
|
+
# Prepare the timestep / sigma schedule.
|
|
227
|
+
patch_size = transformer_info.model.config.patch_size # type: ignore
|
|
228
|
+
assert isinstance(patch_size, int)
|
|
229
|
+
image_seq_len = ((self.height // LATENT_SCALE_FACTOR) * (self.width // LATENT_SCALE_FACTOR)) // (patch_size**2)
|
|
230
|
+
# We add an extra step to the end to account for the final timestep of 0.0.
|
|
231
|
+
timesteps: list[float] = torch.linspace(1, 0, self.steps + 1).tolist()
|
|
232
|
+
# Clip the timesteps schedule based on denoising_start and denoising_end.
|
|
233
|
+
timesteps = clip_timestep_schedule_fractional(timesteps, self.denoising_start, self.denoising_end)
|
|
234
|
+
sigmas = self._convert_timesteps_to_sigmas(image_seq_len, torch.tensor(timesteps))
|
|
235
|
+
total_steps = len(timesteps) - 1
|
|
236
|
+
|
|
237
|
+
# Prepare the CFG scale list.
|
|
238
|
+
cfg_scale = self._prepare_cfg_scale(total_steps)
|
|
239
|
+
|
|
240
|
+
# Load the input latents, if provided.
|
|
241
|
+
init_latents = context.tensors.load(self.latents.latents_name) if self.latents else None
|
|
242
|
+
if init_latents is not None:
|
|
243
|
+
init_latents = init_latents.to(device=device, dtype=inference_dtype)
|
|
244
|
+
|
|
245
|
+
# Generate initial latent noise.
|
|
246
|
+
num_channels_latents = transformer_info.model.config.in_channels # type: ignore
|
|
247
|
+
assert isinstance(num_channels_latents, int)
|
|
248
|
+
noise = self._get_noise(
|
|
249
|
+
batch_size=1,
|
|
250
|
+
num_channels_latents=num_channels_latents,
|
|
251
|
+
height=self.height,
|
|
252
|
+
width=self.width,
|
|
253
|
+
dtype=inference_dtype,
|
|
254
|
+
device=device,
|
|
255
|
+
seed=self.seed,
|
|
256
|
+
)
|
|
257
|
+
|
|
258
|
+
# Prepare input latent image.
|
|
259
|
+
if init_latents is not None:
|
|
260
|
+
# Noise the init_latents by the appropriate amount for the first timestep.
|
|
261
|
+
s_0 = sigmas[0]
|
|
262
|
+
latents = s_0 * noise + (1.0 - s_0) * init_latents
|
|
263
|
+
else:
|
|
264
|
+
# init_latents are not provided, so we are not doing image-to-image (i.e. we are starting from pure noise).
|
|
265
|
+
if self.denoising_start > 1e-5:
|
|
266
|
+
raise ValueError("denoising_start should be 0 when initial latents are not provided.")
|
|
267
|
+
latents = noise
|
|
268
|
+
|
|
269
|
+
# If len(timesteps) == 1, then short-circuit. We are just noising the input latents, but not taking any
|
|
270
|
+
# denoising steps.
|
|
271
|
+
if len(timesteps) <= 1:
|
|
272
|
+
return latents
|
|
273
|
+
|
|
274
|
+
# Prepare inpaint extension.
|
|
275
|
+
inpaint_mask = self._prep_inpaint_mask(context, latents)
|
|
276
|
+
inpaint_extension: RectifiedFlowInpaintExtension | None = None
|
|
277
|
+
if inpaint_mask is not None:
|
|
278
|
+
assert init_latents is not None
|
|
279
|
+
inpaint_extension = RectifiedFlowInpaintExtension(
|
|
280
|
+
init_latents=init_latents,
|
|
281
|
+
inpaint_mask=inpaint_mask,
|
|
282
|
+
noise=noise,
|
|
283
|
+
)
|
|
284
|
+
|
|
285
|
+
step_callback = self._build_step_callback(context)
|
|
286
|
+
|
|
287
|
+
step_callback(
|
|
288
|
+
PipelineIntermediateState(
|
|
289
|
+
step=0,
|
|
290
|
+
order=1,
|
|
291
|
+
total_steps=total_steps,
|
|
292
|
+
timestep=int(timesteps[0]),
|
|
293
|
+
latents=latents,
|
|
294
|
+
),
|
|
295
|
+
)
|
|
296
|
+
|
|
297
|
+
with transformer_info.model_on_device() as (_, transformer):
|
|
298
|
+
assert isinstance(transformer, CogView4Transformer2DModel)
|
|
299
|
+
|
|
300
|
+
# Denoising loop
|
|
301
|
+
for step_idx in tqdm(range(total_steps)):
|
|
302
|
+
t_curr = timesteps[step_idx]
|
|
303
|
+
sigma_curr = sigmas[step_idx]
|
|
304
|
+
sigma_prev = sigmas[step_idx + 1]
|
|
305
|
+
|
|
306
|
+
# Expand the timestep to match the latent model input.
|
|
307
|
+
# Multiply by 1000 to match the default FlowMatchEulerDiscreteScheduler num_train_timesteps.
|
|
308
|
+
timestep = torch.tensor([t_curr * 1000], device=device).expand(latents.shape[0])
|
|
309
|
+
|
|
310
|
+
# TODO(ryand): Support both sequential and batched CFG inference.
|
|
311
|
+
noise_pred_cond = transformer(
|
|
312
|
+
hidden_states=latents,
|
|
313
|
+
encoder_hidden_states=pos_prompt_embeds,
|
|
314
|
+
timestep=timestep,
|
|
315
|
+
original_size=original_size,
|
|
316
|
+
target_size=target_size,
|
|
317
|
+
crop_coords=crops_coords_top_left,
|
|
318
|
+
return_dict=False,
|
|
319
|
+
)[0]
|
|
320
|
+
|
|
321
|
+
# Apply CFG.
|
|
322
|
+
if do_classifier_free_guidance:
|
|
323
|
+
noise_pred_uncond = transformer(
|
|
324
|
+
hidden_states=latents,
|
|
325
|
+
encoder_hidden_states=neg_prompt_embeds,
|
|
326
|
+
timestep=timestep,
|
|
327
|
+
original_size=original_size,
|
|
328
|
+
target_size=target_size,
|
|
329
|
+
crop_coords=crops_coords_top_left,
|
|
330
|
+
return_dict=False,
|
|
331
|
+
)[0]
|
|
332
|
+
|
|
333
|
+
noise_pred = noise_pred_uncond + cfg_scale[step_idx] * (noise_pred_cond - noise_pred_uncond)
|
|
334
|
+
else:
|
|
335
|
+
noise_pred = noise_pred_cond
|
|
336
|
+
|
|
337
|
+
# Compute the previous noisy sample x_t -> x_t-1.
|
|
338
|
+
latents_dtype = latents.dtype
|
|
339
|
+
# TODO(ryand): Is casting to float32 necessary for precision/stability? I copied this from SD3.
|
|
340
|
+
latents = latents.to(dtype=torch.float32)
|
|
341
|
+
latents = latents + (sigma_prev - sigma_curr) * noise_pred
|
|
342
|
+
latents = latents.to(dtype=latents_dtype)
|
|
343
|
+
|
|
344
|
+
if inpaint_extension is not None:
|
|
345
|
+
latents = inpaint_extension.merge_intermediate_latents_with_init_latents(latents, sigma_prev)
|
|
346
|
+
|
|
347
|
+
step_callback(
|
|
348
|
+
PipelineIntermediateState(
|
|
349
|
+
step=step_idx + 1,
|
|
350
|
+
order=1,
|
|
351
|
+
total_steps=total_steps,
|
|
352
|
+
timestep=int(t_curr),
|
|
353
|
+
latents=latents,
|
|
354
|
+
),
|
|
355
|
+
)
|
|
356
|
+
|
|
357
|
+
return latents
|
|
358
|
+
|
|
359
|
+
def _build_step_callback(self, context: InvocationContext) -> Callable[[PipelineIntermediateState], None]:
|
|
360
|
+
def step_callback(state: PipelineIntermediateState) -> None:
|
|
361
|
+
context.util.sd_step_callback(state, BaseModelType.CogView4)
|
|
362
|
+
|
|
363
|
+
return step_callback
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import einops
|
|
2
|
+
import torch
|
|
3
|
+
from diffusers.models.autoencoders.autoencoder_kl import AutoencoderKL
|
|
4
|
+
|
|
5
|
+
from invokeai.app.invocations.baseinvocation import BaseInvocation, Classification, invocation
|
|
6
|
+
from invokeai.app.invocations.fields import (
|
|
7
|
+
FieldDescriptions,
|
|
8
|
+
ImageField,
|
|
9
|
+
Input,
|
|
10
|
+
InputField,
|
|
11
|
+
WithBoard,
|
|
12
|
+
WithMetadata,
|
|
13
|
+
)
|
|
14
|
+
from invokeai.app.invocations.model import VAEField
|
|
15
|
+
from invokeai.app.invocations.primitives import LatentsOutput
|
|
16
|
+
from invokeai.app.services.shared.invocation_context import InvocationContext
|
|
17
|
+
from invokeai.backend.model_manager.load.load_base import LoadedModel
|
|
18
|
+
from invokeai.backend.stable_diffusion.diffusers_pipeline import image_resized_to_grid_as_tensor
|
|
19
|
+
from invokeai.backend.util.devices import TorchDevice
|
|
20
|
+
|
|
21
|
+
# TODO(ryand): This is effectively a copy of SD3ImageToLatentsInvocation and a subset of ImageToLatentsInvocation. We
|
|
22
|
+
# should refactor to avoid this duplication.
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
@invocation(
|
|
26
|
+
"cogview4_i2l",
|
|
27
|
+
title="Image to Latents - CogView4",
|
|
28
|
+
tags=["image", "latents", "vae", "i2l", "cogview4"],
|
|
29
|
+
category="image",
|
|
30
|
+
version="1.0.0",
|
|
31
|
+
classification=Classification.Prototype,
|
|
32
|
+
)
|
|
33
|
+
class CogView4ImageToLatentsInvocation(BaseInvocation, WithMetadata, WithBoard):
|
|
34
|
+
"""Generates latents from an image."""
|
|
35
|
+
|
|
36
|
+
image: ImageField = InputField(description="The image to encode.")
|
|
37
|
+
vae: VAEField = InputField(description=FieldDescriptions.vae, input=Input.Connection)
|
|
38
|
+
|
|
39
|
+
@staticmethod
|
|
40
|
+
def vae_encode(vae_info: LoadedModel, image_tensor: torch.Tensor) -> torch.Tensor:
|
|
41
|
+
with vae_info as vae:
|
|
42
|
+
assert isinstance(vae, AutoencoderKL)
|
|
43
|
+
|
|
44
|
+
vae.disable_tiling()
|
|
45
|
+
|
|
46
|
+
image_tensor = image_tensor.to(device=TorchDevice.choose_torch_device(), dtype=vae.dtype)
|
|
47
|
+
with torch.inference_mode():
|
|
48
|
+
image_tensor_dist = vae.encode(image_tensor).latent_dist
|
|
49
|
+
# TODO: Use seed to make sampling reproducible.
|
|
50
|
+
latents: torch.Tensor = image_tensor_dist.sample().to(dtype=vae.dtype)
|
|
51
|
+
|
|
52
|
+
latents = vae.config.scaling_factor * latents
|
|
53
|
+
|
|
54
|
+
return latents
|
|
55
|
+
|
|
56
|
+
@torch.no_grad()
|
|
57
|
+
def invoke(self, context: InvocationContext) -> LatentsOutput:
|
|
58
|
+
image = context.images.get_pil(self.image.image_name)
|
|
59
|
+
|
|
60
|
+
image_tensor = image_resized_to_grid_as_tensor(image.convert("RGB"))
|
|
61
|
+
if image_tensor.dim() == 3:
|
|
62
|
+
image_tensor = einops.rearrange(image_tensor, "c h w -> 1 c h w")
|
|
63
|
+
|
|
64
|
+
vae_info = context.models.load(self.vae.vae)
|
|
65
|
+
latents = self.vae_encode(vae_info=vae_info, image_tensor=image_tensor)
|
|
66
|
+
|
|
67
|
+
latents = latents.to("cpu")
|
|
68
|
+
name = context.tensors.save(tensor=latents)
|
|
69
|
+
return LatentsOutput.build(latents_name=name, latents=latents, seed=None)
|