mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
Merge branch 'main' into boards-ui-update
This commit is contained in:
commit
faf65c988a
@ -9,9 +9,9 @@ runs:
|
|||||||
node-version: '18'
|
node-version: '18'
|
||||||
|
|
||||||
- name: setup pnpm
|
- name: setup pnpm
|
||||||
uses: pnpm/action-setup@v2
|
uses: pnpm/action-setup@v4
|
||||||
with:
|
with:
|
||||||
version: 8
|
version: 8.15.6
|
||||||
run_install: false
|
run_install: false
|
||||||
|
|
||||||
- name: get pnpm store directory
|
- name: get pnpm store directory
|
||||||
|
2
.github/pull_request_template.md
vendored
2
.github/pull_request_template.md
vendored
@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
## QA Instructions
|
## QA Instructions
|
||||||
|
|
||||||
<!--WHEN APPLICABLE: Describe how we can test the changes in this PR.-->
|
<!--WHEN APPLICABLE: Describe how you have tested the changes in this PR. Provide enough detail that a reviewer can reproduce your tests.-->
|
||||||
|
|
||||||
## Merge Plan
|
## Merge Plan
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@ echo 2. Open the developer console
|
|||||||
echo 3. Command-line help
|
echo 3. Command-line help
|
||||||
echo Q - Quit
|
echo Q - Quit
|
||||||
echo.
|
echo.
|
||||||
echo To update, download and run the installer from https://github.com/invoke-ai/InvokeAI/releases/latest.
|
echo To update, download and run the installer from https://github.com/invoke-ai/InvokeAI/releases/latest
|
||||||
echo.
|
echo.
|
||||||
set /P choice="Please enter 1-4, Q: [1] "
|
set /P choice="Please enter 1-4, Q: [1] "
|
||||||
if not defined choice set choice=1
|
if not defined choice set choice=1
|
||||||
|
@ -4,37 +4,39 @@ from logging import Logger
|
|||||||
|
|
||||||
import torch
|
import torch
|
||||||
|
|
||||||
|
from invokeai.app.services.board_image_records.board_image_records_sqlite import SqliteBoardImageRecordStorage
|
||||||
|
from invokeai.app.services.board_images.board_images_default import BoardImagesService
|
||||||
|
from invokeai.app.services.board_records.board_records_sqlite import SqliteBoardRecordStorage
|
||||||
|
from invokeai.app.services.boards.boards_default import BoardService
|
||||||
|
from invokeai.app.services.bulk_download.bulk_download_default import BulkDownloadService
|
||||||
|
from invokeai.app.services.config.config_default import InvokeAIAppConfig
|
||||||
|
from invokeai.app.services.download.download_default import DownloadQueueService
|
||||||
|
from invokeai.app.services.events.events_fastapievents import FastAPIEventService
|
||||||
|
from invokeai.app.services.image_files.image_files_disk import DiskImageFileStorage
|
||||||
|
from invokeai.app.services.image_records.image_records_sqlite import SqliteImageRecordStorage
|
||||||
|
from invokeai.app.services.images.images_default import ImageService
|
||||||
|
from invokeai.app.services.invocation_cache.invocation_cache_memory import MemoryInvocationCache
|
||||||
|
from invokeai.app.services.invocation_services import InvocationServices
|
||||||
|
from invokeai.app.services.invocation_stats.invocation_stats_default import InvocationStatsService
|
||||||
|
from invokeai.app.services.invoker import Invoker
|
||||||
|
from invokeai.app.services.model_images.model_images_default import ModelImageFileStorageDisk
|
||||||
|
from invokeai.app.services.model_manager.model_manager_default import ModelManagerService
|
||||||
|
from invokeai.app.services.model_records.model_records_sql import ModelRecordServiceSQL
|
||||||
|
from invokeai.app.services.names.names_default import SimpleNameService
|
||||||
from invokeai.app.services.object_serializer.object_serializer_disk import ObjectSerializerDisk
|
from invokeai.app.services.object_serializer.object_serializer_disk import ObjectSerializerDisk
|
||||||
from invokeai.app.services.object_serializer.object_serializer_forward_cache import ObjectSerializerForwardCache
|
from invokeai.app.services.object_serializer.object_serializer_forward_cache import ObjectSerializerForwardCache
|
||||||
|
from invokeai.app.services.session_processor.session_processor_default import (
|
||||||
|
DefaultSessionProcessor,
|
||||||
|
DefaultSessionRunner,
|
||||||
|
)
|
||||||
|
from invokeai.app.services.session_queue.session_queue_sqlite import SqliteSessionQueue
|
||||||
from invokeai.app.services.shared.sqlite.sqlite_util import init_db
|
from invokeai.app.services.shared.sqlite.sqlite_util import init_db
|
||||||
|
from invokeai.app.services.urls.urls_default import LocalUrlService
|
||||||
|
from invokeai.app.services.workflow_records.workflow_records_sqlite import SqliteWorkflowRecordsStorage
|
||||||
from invokeai.backend.stable_diffusion.diffusion.conditioning_data import ConditioningFieldData
|
from invokeai.backend.stable_diffusion.diffusion.conditioning_data import ConditioningFieldData
|
||||||
from invokeai.backend.util.logging import InvokeAILogger
|
from invokeai.backend.util.logging import InvokeAILogger
|
||||||
from invokeai.version.invokeai_version import __version__
|
from invokeai.version.invokeai_version import __version__
|
||||||
|
|
||||||
from ..services.board_image_records.board_image_records_sqlite import SqliteBoardImageRecordStorage
|
|
||||||
from ..services.board_images.board_images_default import BoardImagesService
|
|
||||||
from ..services.board_records.board_records_sqlite import SqliteBoardRecordStorage
|
|
||||||
from ..services.boards.boards_default import BoardService
|
|
||||||
from ..services.bulk_download.bulk_download_default import BulkDownloadService
|
|
||||||
from ..services.config import InvokeAIAppConfig
|
|
||||||
from ..services.download import DownloadQueueService
|
|
||||||
from ..services.events.events_fastapievents import FastAPIEventService
|
|
||||||
from ..services.image_files.image_files_disk import DiskImageFileStorage
|
|
||||||
from ..services.image_records.image_records_sqlite import SqliteImageRecordStorage
|
|
||||||
from ..services.images.images_default import ImageService
|
|
||||||
from ..services.invocation_cache.invocation_cache_memory import MemoryInvocationCache
|
|
||||||
from ..services.invocation_services import InvocationServices
|
|
||||||
from ..services.invocation_stats.invocation_stats_default import InvocationStatsService
|
|
||||||
from ..services.invoker import Invoker
|
|
||||||
from ..services.model_images.model_images_default import ModelImageFileStorageDisk
|
|
||||||
from ..services.model_manager.model_manager_default import ModelManagerService
|
|
||||||
from ..services.model_records import ModelRecordServiceSQL
|
|
||||||
from ..services.names.names_default import SimpleNameService
|
|
||||||
from ..services.session_processor.session_processor_default import DefaultSessionProcessor, DefaultSessionRunner
|
|
||||||
from ..services.session_queue.session_queue_sqlite import SqliteSessionQueue
|
|
||||||
from ..services.urls.urls_default import LocalUrlService
|
|
||||||
from ..services.workflow_records.workflow_records_sqlite import SqliteWorkflowRecordsStorage
|
|
||||||
|
|
||||||
|
|
||||||
# TODO: is there a better way to achieve this?
|
# TODO: is there a better way to achieve this?
|
||||||
def check_internet() -> bool:
|
def check_internet() -> bool:
|
||||||
|
@ -10,14 +10,13 @@ from fastapi import Body
|
|||||||
from fastapi.routing import APIRouter
|
from fastapi.routing import APIRouter
|
||||||
from pydantic import BaseModel, Field
|
from pydantic import BaseModel, Field
|
||||||
|
|
||||||
|
from invokeai.app.api.dependencies import ApiDependencies
|
||||||
from invokeai.app.invocations.upscale import ESRGAN_MODELS
|
from invokeai.app.invocations.upscale import ESRGAN_MODELS
|
||||||
from invokeai.app.services.invocation_cache.invocation_cache_common import InvocationCacheStatus
|
from invokeai.app.services.invocation_cache.invocation_cache_common import InvocationCacheStatus
|
||||||
from invokeai.backend.image_util.infill_methods.patchmatch import PatchMatch
|
from invokeai.backend.image_util.infill_methods.patchmatch import PatchMatch
|
||||||
from invokeai.backend.util.logging import logging
|
from invokeai.backend.util.logging import logging
|
||||||
from invokeai.version import __version__
|
from invokeai.version import __version__
|
||||||
|
|
||||||
from ..dependencies import ApiDependencies
|
|
||||||
|
|
||||||
|
|
||||||
class LogLevel(int, Enum):
|
class LogLevel(int, Enum):
|
||||||
NotSet = logging.NOTSET
|
NotSet = logging.NOTSET
|
||||||
|
@ -2,7 +2,7 @@ from fastapi import Body, HTTPException
|
|||||||
from fastapi.routing import APIRouter
|
from fastapi.routing import APIRouter
|
||||||
from pydantic import BaseModel, Field
|
from pydantic import BaseModel, Field
|
||||||
|
|
||||||
from ..dependencies import ApiDependencies
|
from invokeai.app.api.dependencies import ApiDependencies
|
||||||
|
|
||||||
board_images_router = APIRouter(prefix="/v1/board_images", tags=["boards"])
|
board_images_router = APIRouter(prefix="/v1/board_images", tags=["boards"])
|
||||||
|
|
||||||
|
@ -4,12 +4,11 @@ from fastapi import Body, HTTPException, Path, Query
|
|||||||
from fastapi.routing import APIRouter
|
from fastapi.routing import APIRouter
|
||||||
from pydantic import BaseModel, Field
|
from pydantic import BaseModel, Field
|
||||||
|
|
||||||
|
from invokeai.app.api.dependencies import ApiDependencies
|
||||||
from invokeai.app.services.board_records.board_records_common import BoardChanges
|
from invokeai.app.services.board_records.board_records_common import BoardChanges
|
||||||
from invokeai.app.services.boards.boards_common import BoardDTO
|
from invokeai.app.services.boards.boards_common import BoardDTO
|
||||||
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
||||||
|
|
||||||
from ..dependencies import ApiDependencies
|
|
||||||
|
|
||||||
boards_router = APIRouter(prefix="/v1/boards", tags=["boards"])
|
boards_router = APIRouter(prefix="/v1/boards", tags=["boards"])
|
||||||
|
|
||||||
|
|
||||||
|
@ -8,13 +8,12 @@ from fastapi.routing import APIRouter
|
|||||||
from pydantic.networks import AnyHttpUrl
|
from pydantic.networks import AnyHttpUrl
|
||||||
from starlette.exceptions import HTTPException
|
from starlette.exceptions import HTTPException
|
||||||
|
|
||||||
|
from invokeai.app.api.dependencies import ApiDependencies
|
||||||
from invokeai.app.services.download import (
|
from invokeai.app.services.download import (
|
||||||
DownloadJob,
|
DownloadJob,
|
||||||
UnknownJobIDException,
|
UnknownJobIDException,
|
||||||
)
|
)
|
||||||
|
|
||||||
from ..dependencies import ApiDependencies
|
|
||||||
|
|
||||||
download_queue_router = APIRouter(prefix="/v1/download_queue", tags=["download_queue"])
|
download_queue_router = APIRouter(prefix="/v1/download_queue", tags=["download_queue"])
|
||||||
|
|
||||||
|
|
||||||
|
@ -8,6 +8,7 @@ from fastapi.routing import APIRouter
|
|||||||
from PIL import Image
|
from PIL import Image
|
||||||
from pydantic import BaseModel, Field, JsonValue
|
from pydantic import BaseModel, Field, JsonValue
|
||||||
|
|
||||||
|
from invokeai.app.api.dependencies import ApiDependencies
|
||||||
from invokeai.app.invocations.fields import MetadataField
|
from invokeai.app.invocations.fields import MetadataField
|
||||||
from invokeai.app.services.image_records.image_records_common import (
|
from invokeai.app.services.image_records.image_records_common import (
|
||||||
ImageCategory,
|
ImageCategory,
|
||||||
@ -18,8 +19,6 @@ from invokeai.app.services.images.images_common import ImageDTO, ImageUrlsDTO
|
|||||||
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
||||||
from invokeai.app.services.shared.sqlite.sqlite_common import SQLiteDirection
|
from invokeai.app.services.shared.sqlite.sqlite_common import SQLiteDirection
|
||||||
|
|
||||||
from ..dependencies import ApiDependencies
|
|
||||||
|
|
||||||
images_router = APIRouter(prefix="/v1/images", tags=["images"])
|
images_router = APIRouter(prefix="/v1/images", tags=["images"])
|
||||||
|
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@ from pydantic import AnyHttpUrl, BaseModel, ConfigDict, Field
|
|||||||
from starlette.exceptions import HTTPException
|
from starlette.exceptions import HTTPException
|
||||||
from typing_extensions import Annotated
|
from typing_extensions import Annotated
|
||||||
|
|
||||||
|
from invokeai.app.api.dependencies import ApiDependencies
|
||||||
from invokeai.app.services.model_images.model_images_common import ModelImageFileNotFoundException
|
from invokeai.app.services.model_images.model_images_common import ModelImageFileNotFoundException
|
||||||
from invokeai.app.services.model_install.model_install_common import ModelInstallJob
|
from invokeai.app.services.model_install.model_install_common import ModelInstallJob
|
||||||
from invokeai.app.services.model_records import (
|
from invokeai.app.services.model_records import (
|
||||||
@ -35,8 +36,6 @@ from invokeai.backend.model_manager.metadata.metadata_base import ModelMetadataW
|
|||||||
from invokeai.backend.model_manager.search import ModelSearch
|
from invokeai.backend.model_manager.search import ModelSearch
|
||||||
from invokeai.backend.model_manager.starter_models import STARTER_MODELS, StarterModel, StarterModelWithoutDependencies
|
from invokeai.backend.model_manager.starter_models import STARTER_MODELS, StarterModel, StarterModelWithoutDependencies
|
||||||
|
|
||||||
from ..dependencies import ApiDependencies
|
|
||||||
|
|
||||||
model_manager_router = APIRouter(prefix="/v2/models", tags=["model_manager"])
|
model_manager_router = APIRouter(prefix="/v2/models", tags=["model_manager"])
|
||||||
|
|
||||||
# images are immutable; set a high max-age
|
# images are immutable; set a high max-age
|
||||||
|
@ -4,6 +4,7 @@ from fastapi import Body, Path, Query
|
|||||||
from fastapi.routing import APIRouter
|
from fastapi.routing import APIRouter
|
||||||
from pydantic import BaseModel
|
from pydantic import BaseModel
|
||||||
|
|
||||||
|
from invokeai.app.api.dependencies import ApiDependencies
|
||||||
from invokeai.app.services.session_processor.session_processor_common import SessionProcessorStatus
|
from invokeai.app.services.session_processor.session_processor_common import SessionProcessorStatus
|
||||||
from invokeai.app.services.session_queue.session_queue_common import (
|
from invokeai.app.services.session_queue.session_queue_common import (
|
||||||
QUEUE_ITEM_STATUS,
|
QUEUE_ITEM_STATUS,
|
||||||
@ -19,8 +20,6 @@ from invokeai.app.services.session_queue.session_queue_common import (
|
|||||||
)
|
)
|
||||||
from invokeai.app.services.shared.pagination import CursorPaginatedResults
|
from invokeai.app.services.shared.pagination import CursorPaginatedResults
|
||||||
|
|
||||||
from ..dependencies import ApiDependencies
|
|
||||||
|
|
||||||
session_queue_router = APIRouter(prefix="/v1/queue", tags=["queue"])
|
session_queue_router = APIRouter(prefix="/v1/queue", tags=["queue"])
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,14 +20,9 @@ from torch.backends.mps import is_available as is_mps_available
|
|||||||
# noinspection PyUnresolvedReferences
|
# noinspection PyUnresolvedReferences
|
||||||
import invokeai.backend.util.hotfixes # noqa: F401 (monkeypatching on import)
|
import invokeai.backend.util.hotfixes # noqa: F401 (monkeypatching on import)
|
||||||
import invokeai.frontend.web as web_dir
|
import invokeai.frontend.web as web_dir
|
||||||
|
from invokeai.app.api.dependencies import ApiDependencies
|
||||||
from invokeai.app.api.no_cache_staticfiles import NoCacheStaticFiles
|
from invokeai.app.api.no_cache_staticfiles import NoCacheStaticFiles
|
||||||
from invokeai.app.services.config.config_default import get_config
|
from invokeai.app.api.routers import (
|
||||||
from invokeai.app.util.custom_openapi import get_openapi_func
|
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
|
||||||
|
|
||||||
from ..backend.util.logging import InvokeAILogger
|
|
||||||
from .api.dependencies import ApiDependencies
|
|
||||||
from .api.routers import (
|
|
||||||
app_info,
|
app_info,
|
||||||
board_images,
|
board_images,
|
||||||
boards,
|
boards,
|
||||||
@ -38,7 +33,11 @@ from .api.routers import (
|
|||||||
utilities,
|
utilities,
|
||||||
workflows,
|
workflows,
|
||||||
)
|
)
|
||||||
from .api.sockets import SocketIO
|
from invokeai.app.api.sockets import SocketIO
|
||||||
|
from invokeai.app.services.config.config_default import get_config
|
||||||
|
from invokeai.app.util.custom_openapi import get_openapi_func
|
||||||
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
|
from invokeai.backend.util.logging import InvokeAILogger
|
||||||
|
|
||||||
app_config = get_config()
|
app_config = get_config()
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ from invokeai.app.util.misc import uuid_string
|
|||||||
from invokeai.backend.util.logging import InvokeAILogger
|
from invokeai.backend.util.logging import InvokeAILogger
|
||||||
|
|
||||||
if TYPE_CHECKING:
|
if TYPE_CHECKING:
|
||||||
from ..services.invocation_services import InvocationServices
|
from invokeai.app.services.invocation_services import InvocationServices
|
||||||
|
|
||||||
logger = InvokeAILogger.get_logger()
|
logger = InvokeAILogger.get_logger()
|
||||||
|
|
||||||
|
@ -4,13 +4,12 @@
|
|||||||
import numpy as np
|
import numpy as np
|
||||||
from pydantic import ValidationInfo, field_validator
|
from pydantic import ValidationInfo, field_validator
|
||||||
|
|
||||||
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
||||||
|
from invokeai.app.invocations.fields import InputField
|
||||||
from invokeai.app.invocations.primitives import IntegerCollectionOutput
|
from invokeai.app.invocations.primitives import IntegerCollectionOutput
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
from invokeai.app.util.misc import SEED_MAX
|
from invokeai.app.util.misc import SEED_MAX
|
||||||
|
|
||||||
from .baseinvocation import BaseInvocation, invocation
|
|
||||||
from .fields import InputField
|
|
||||||
|
|
||||||
|
|
||||||
@invocation(
|
@invocation(
|
||||||
"range", title="Integer Range", tags=["collection", "integer", "range"], category="collections", version="1.0.0"
|
"range", title="Integer Range", tags=["collection", "integer", "range"], category="collections", version="1.0.0"
|
||||||
|
@ -5,6 +5,7 @@ from compel import Compel, ReturnedEmbeddingsType
|
|||||||
from compel.prompt_parser import Blend, Conjunction, CrossAttentionControlSubstitute, FlattenedPrompt, Fragment
|
from compel.prompt_parser import Blend, Conjunction, CrossAttentionControlSubstitute, FlattenedPrompt, Fragment
|
||||||
from transformers import CLIPTextModel, CLIPTextModelWithProjection, CLIPTokenizer
|
from transformers import CLIPTextModel, CLIPTextModelWithProjection, CLIPTokenizer
|
||||||
|
|
||||||
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, BaseInvocationOutput, invocation, invocation_output
|
||||||
from invokeai.app.invocations.fields import (
|
from invokeai.app.invocations.fields import (
|
||||||
ConditioningField,
|
ConditioningField,
|
||||||
FieldDescriptions,
|
FieldDescriptions,
|
||||||
@ -14,6 +15,7 @@ from invokeai.app.invocations.fields import (
|
|||||||
TensorField,
|
TensorField,
|
||||||
UIComponent,
|
UIComponent,
|
||||||
)
|
)
|
||||||
|
from invokeai.app.invocations.model import CLIPField
|
||||||
from invokeai.app.invocations.primitives import ConditioningOutput
|
from invokeai.app.invocations.primitives import ConditioningOutput
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
from invokeai.app.util.ti_utils import generate_ti_list
|
from invokeai.app.util.ti_utils import generate_ti_list
|
||||||
@ -26,9 +28,6 @@ from invokeai.backend.stable_diffusion.diffusion.conditioning_data import (
|
|||||||
)
|
)
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
|
|
||||||
from .baseinvocation import BaseInvocation, BaseInvocationOutput, invocation, invocation_output
|
|
||||||
from .model import CLIPField
|
|
||||||
|
|
||||||
# unconditioned: Optional[torch.Tensor]
|
# unconditioned: Optional[torch.Tensor]
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
from typing import Literal
|
from typing import Literal
|
||||||
|
|
||||||
from invokeai.backend.stable_diffusion.schedulers import SCHEDULER_MAP
|
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
|
|
||||||
LATENT_SCALE_FACTOR = 8
|
LATENT_SCALE_FACTOR = 8
|
||||||
@ -11,9 +10,6 @@ factor is hard-coded to a literal '8' rather than using this constant.
|
|||||||
The ratio of image:latent dimensions is LATENT_SCALE_FACTOR:1, or 8:1.
|
The ratio of image:latent dimensions is LATENT_SCALE_FACTOR:1, or 8:1.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
SCHEDULER_NAME_VALUES = Literal[tuple(SCHEDULER_MAP.keys())]
|
|
||||||
"""A literal type representing the valid scheduler names."""
|
|
||||||
|
|
||||||
IMAGE_MODES = Literal["L", "RGB", "RGBA", "CMYK", "YCbCr", "LAB", "HSV", "I", "F"]
|
IMAGE_MODES = Literal["L", "RGB", "RGBA", "CMYK", "YCbCr", "LAB", "HSV", "I", "F"]
|
||||||
"""A literal type for PIL image modes supported by Invoke"""
|
"""A literal type for PIL image modes supported by Invoke"""
|
||||||
|
|
||||||
|
@ -22,6 +22,13 @@ from controlnet_aux.util import HWC3, ade_palette
|
|||||||
from PIL import Image
|
from PIL import Image
|
||||||
from pydantic import BaseModel, Field, field_validator, model_validator
|
from pydantic import BaseModel, Field, field_validator, model_validator
|
||||||
|
|
||||||
|
from invokeai.app.invocations.baseinvocation import (
|
||||||
|
BaseInvocation,
|
||||||
|
BaseInvocationOutput,
|
||||||
|
Classification,
|
||||||
|
invocation,
|
||||||
|
invocation_output,
|
||||||
|
)
|
||||||
from invokeai.app.invocations.fields import (
|
from invokeai.app.invocations.fields import (
|
||||||
FieldDescriptions,
|
FieldDescriptions,
|
||||||
ImageField,
|
ImageField,
|
||||||
@ -45,8 +52,6 @@ from invokeai.backend.image_util.lineart_anime import LineartAnimeProcessor
|
|||||||
from invokeai.backend.image_util.util import np_to_pil, pil_to_np
|
from invokeai.backend.image_util.util import np_to_pil, pil_to_np
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
|
|
||||||
from .baseinvocation import BaseInvocation, BaseInvocationOutput, Classification, invocation, invocation_output
|
|
||||||
|
|
||||||
|
|
||||||
class ControlField(BaseModel):
|
class ControlField(BaseModel):
|
||||||
image: ImageField = Field(description="The control image")
|
image: ImageField = Field(description="The control image")
|
||||||
|
@ -5,13 +5,11 @@ import cv2 as cv
|
|||||||
import numpy
|
import numpy
|
||||||
from PIL import Image, ImageOps
|
from PIL import Image, ImageOps
|
||||||
|
|
||||||
from invokeai.app.invocations.fields import ImageField
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
||||||
|
from invokeai.app.invocations.fields import ImageField, InputField, WithBoard, WithMetadata
|
||||||
from invokeai.app.invocations.primitives import ImageOutput
|
from invokeai.app.invocations.primitives import ImageOutput
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
|
|
||||||
from .baseinvocation import BaseInvocation, invocation
|
|
||||||
from .fields import InputField, WithBoard, WithMetadata
|
|
||||||
|
|
||||||
|
|
||||||
@invocation("cv_inpaint", title="OpenCV Inpaint", tags=["opencv", "inpaint"], category="inpaint", version="1.3.1")
|
@invocation("cv_inpaint", title="OpenCV Inpaint", tags=["opencv", "inpaint"], category="inpaint", version="1.3.1")
|
||||||
class CvInpaintInvocation(BaseInvocation, WithMetadata, WithBoard):
|
class CvInpaintInvocation(BaseInvocation, WithMetadata, WithBoard):
|
||||||
|
@ -17,7 +17,7 @@ from torchvision.transforms.functional import resize as tv_resize
|
|||||||
from transformers import CLIPVisionModelWithProjection
|
from transformers import CLIPVisionModelWithProjection
|
||||||
|
|
||||||
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
||||||
from invokeai.app.invocations.constants import LATENT_SCALE_FACTOR, SCHEDULER_NAME_VALUES
|
from invokeai.app.invocations.constants import LATENT_SCALE_FACTOR
|
||||||
from invokeai.app.invocations.controlnet_image_processors import ControlField
|
from invokeai.app.invocations.controlnet_image_processors import ControlField
|
||||||
from invokeai.app.invocations.fields import (
|
from invokeai.app.invocations.fields import (
|
||||||
ConditioningField,
|
ConditioningField,
|
||||||
@ -54,6 +54,7 @@ from invokeai.backend.stable_diffusion.diffusion.conditioning_data import (
|
|||||||
TextConditioningRegions,
|
TextConditioningRegions,
|
||||||
)
|
)
|
||||||
from invokeai.backend.stable_diffusion.schedulers import SCHEDULER_MAP
|
from invokeai.backend.stable_diffusion.schedulers import SCHEDULER_MAP
|
||||||
|
from invokeai.backend.stable_diffusion.schedulers.schedulers import SCHEDULER_NAME_VALUES
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
from invokeai.backend.util.hotfixes import ControlNetModel
|
from invokeai.backend.util.hotfixes import ControlNetModel
|
||||||
from invokeai.backend.util.mask import to_standard_float_mask
|
from invokeai.backend.util.mask import to_standard_float_mask
|
||||||
|
@ -160,6 +160,8 @@ class FieldDescriptions:
|
|||||||
fp32 = "Whether or not to use full float32 precision"
|
fp32 = "Whether or not to use full float32 precision"
|
||||||
precision = "Precision to use"
|
precision = "Precision to use"
|
||||||
tiled = "Processing using overlapping tiles (reduce memory consumption)"
|
tiled = "Processing using overlapping tiles (reduce memory consumption)"
|
||||||
|
vae_tile_size = "The tile size for VAE tiling in pixels (image space). If set to 0, the default tile size for the "
|
||||||
|
"model will be used. Larger tile sizes generally produce better results at the cost of higher memory usage."
|
||||||
detect_res = "Pixel resolution for detection"
|
detect_res = "Pixel resolution for detection"
|
||||||
image_res = "Pixel resolution for output image"
|
image_res = "Pixel resolution for output image"
|
||||||
safe_mode = "Whether or not to use safe mode"
|
safe_mode = "Whether or not to use safe mode"
|
||||||
|
@ -6,6 +6,7 @@ import cv2
|
|||||||
import numpy
|
import numpy
|
||||||
from PIL import Image, ImageChops, ImageFilter, ImageOps
|
from PIL import Image, ImageChops, ImageFilter, ImageOps
|
||||||
|
|
||||||
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, Classification, invocation
|
||||||
from invokeai.app.invocations.constants import IMAGE_MODES
|
from invokeai.app.invocations.constants import IMAGE_MODES
|
||||||
from invokeai.app.invocations.fields import (
|
from invokeai.app.invocations.fields import (
|
||||||
ColorField,
|
ColorField,
|
||||||
@ -21,8 +22,6 @@ from invokeai.app.services.shared.invocation_context import InvocationContext
|
|||||||
from invokeai.backend.image_util.invisible_watermark import InvisibleWatermark
|
from invokeai.backend.image_util.invisible_watermark import InvisibleWatermark
|
||||||
from invokeai.backend.image_util.safety_checker import SafetyChecker
|
from invokeai.backend.image_util.safety_checker import SafetyChecker
|
||||||
|
|
||||||
from .baseinvocation import BaseInvocation, Classification, invocation
|
|
||||||
|
|
||||||
|
|
||||||
@invocation("show_image", title="Show Image", tags=["image"], category="image", version="1.0.1")
|
@invocation("show_image", title="Show Image", tags=["image"], category="image", version="1.0.1")
|
||||||
class ShowImageInvocation(BaseInvocation):
|
class ShowImageInvocation(BaseInvocation):
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
from contextlib import nullcontext
|
||||||
from functools import singledispatchmethod
|
from functools import singledispatchmethod
|
||||||
|
|
||||||
import einops
|
import einops
|
||||||
@ -12,7 +13,7 @@ from diffusers.models.autoencoders.autoencoder_kl import AutoencoderKL
|
|||||||
from diffusers.models.autoencoders.autoencoder_tiny import AutoencoderTiny
|
from diffusers.models.autoencoders.autoencoder_tiny import AutoencoderTiny
|
||||||
|
|
||||||
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
||||||
from invokeai.app.invocations.constants import DEFAULT_PRECISION
|
from invokeai.app.invocations.constants import DEFAULT_PRECISION, LATENT_SCALE_FACTOR
|
||||||
from invokeai.app.invocations.fields import (
|
from invokeai.app.invocations.fields import (
|
||||||
FieldDescriptions,
|
FieldDescriptions,
|
||||||
ImageField,
|
ImageField,
|
||||||
@ -24,6 +25,7 @@ from invokeai.app.invocations.primitives import LatentsOutput
|
|||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
from invokeai.backend.model_manager import LoadedModel
|
from invokeai.backend.model_manager import LoadedModel
|
||||||
from invokeai.backend.stable_diffusion.diffusers_pipeline import image_resized_to_grid_as_tensor
|
from invokeai.backend.stable_diffusion.diffusers_pipeline import image_resized_to_grid_as_tensor
|
||||||
|
from invokeai.backend.stable_diffusion.vae_tiling import patch_vae_tiling_params
|
||||||
|
|
||||||
|
|
||||||
@invocation(
|
@invocation(
|
||||||
@ -31,7 +33,7 @@ from invokeai.backend.stable_diffusion.diffusers_pipeline import image_resized_t
|
|||||||
title="Image to Latents",
|
title="Image to Latents",
|
||||||
tags=["latents", "image", "vae", "i2l"],
|
tags=["latents", "image", "vae", "i2l"],
|
||||||
category="latents",
|
category="latents",
|
||||||
version="1.0.2",
|
version="1.1.0",
|
||||||
)
|
)
|
||||||
class ImageToLatentsInvocation(BaseInvocation):
|
class ImageToLatentsInvocation(BaseInvocation):
|
||||||
"""Encodes an image into latents."""
|
"""Encodes an image into latents."""
|
||||||
@ -44,12 +46,17 @@ class ImageToLatentsInvocation(BaseInvocation):
|
|||||||
input=Input.Connection,
|
input=Input.Connection,
|
||||||
)
|
)
|
||||||
tiled: bool = InputField(default=False, description=FieldDescriptions.tiled)
|
tiled: bool = InputField(default=False, description=FieldDescriptions.tiled)
|
||||||
|
# NOTE: tile_size = 0 is a special value. We use this rather than `int | None`, because the workflow UI does not
|
||||||
|
# offer a way to directly set None values.
|
||||||
|
tile_size: int = InputField(default=0, multiple_of=8, description=FieldDescriptions.vae_tile_size)
|
||||||
fp32: bool = InputField(default=DEFAULT_PRECISION == torch.float32, description=FieldDescriptions.fp32)
|
fp32: bool = InputField(default=DEFAULT_PRECISION == torch.float32, description=FieldDescriptions.fp32)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def vae_encode(vae_info: LoadedModel, upcast: bool, tiled: bool, image_tensor: torch.Tensor) -> torch.Tensor:
|
def vae_encode(
|
||||||
|
vae_info: LoadedModel, upcast: bool, tiled: bool, image_tensor: torch.Tensor, tile_size: int = 0
|
||||||
|
) -> torch.Tensor:
|
||||||
with vae_info as vae:
|
with vae_info as vae:
|
||||||
assert isinstance(vae, torch.nn.Module)
|
assert isinstance(vae, (AutoencoderKL, AutoencoderTiny))
|
||||||
orig_dtype = vae.dtype
|
orig_dtype = vae.dtype
|
||||||
if upcast:
|
if upcast:
|
||||||
vae.to(dtype=torch.float32)
|
vae.to(dtype=torch.float32)
|
||||||
@ -81,9 +88,18 @@ class ImageToLatentsInvocation(BaseInvocation):
|
|||||||
else:
|
else:
|
||||||
vae.disable_tiling()
|
vae.disable_tiling()
|
||||||
|
|
||||||
|
tiling_context = nullcontext()
|
||||||
|
if tile_size > 0:
|
||||||
|
tiling_context = patch_vae_tiling_params(
|
||||||
|
vae,
|
||||||
|
tile_sample_min_size=tile_size,
|
||||||
|
tile_latent_min_size=tile_size // LATENT_SCALE_FACTOR,
|
||||||
|
tile_overlap_factor=0.25,
|
||||||
|
)
|
||||||
|
|
||||||
# non_noised_latents_from_image
|
# non_noised_latents_from_image
|
||||||
image_tensor = image_tensor.to(device=vae.device, dtype=vae.dtype)
|
image_tensor = image_tensor.to(device=vae.device, dtype=vae.dtype)
|
||||||
with torch.inference_mode():
|
with torch.inference_mode(), tiling_context:
|
||||||
latents = ImageToLatentsInvocation._encode_to_tensor(vae, image_tensor)
|
latents = ImageToLatentsInvocation._encode_to_tensor(vae, image_tensor)
|
||||||
|
|
||||||
latents = vae.config.scaling_factor * latents
|
latents = vae.config.scaling_factor * latents
|
||||||
@ -101,7 +117,9 @@ class ImageToLatentsInvocation(BaseInvocation):
|
|||||||
if image_tensor.dim() == 3:
|
if image_tensor.dim() == 3:
|
||||||
image_tensor = einops.rearrange(image_tensor, "c h w -> 1 c h w")
|
image_tensor = einops.rearrange(image_tensor, "c h w -> 1 c h w")
|
||||||
|
|
||||||
latents = self.vae_encode(vae_info, self.fp32, self.tiled, image_tensor)
|
latents = self.vae_encode(
|
||||||
|
vae_info=vae_info, upcast=self.fp32, tiled=self.tiled, image_tensor=image_tensor, tile_size=self.tile_size
|
||||||
|
)
|
||||||
|
|
||||||
latents = latents.to("cpu")
|
latents = latents.to("cpu")
|
||||||
name = context.tensors.save(tensor=latents)
|
name = context.tensors.save(tensor=latents)
|
||||||
|
@ -3,7 +3,9 @@ from typing import Literal, get_args
|
|||||||
|
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
from invokeai.app.invocations.fields import ColorField, ImageField
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
||||||
|
from invokeai.app.invocations.fields import ColorField, ImageField, InputField, WithBoard, WithMetadata
|
||||||
|
from invokeai.app.invocations.image import PIL_RESAMPLING_MAP, PIL_RESAMPLING_MODES
|
||||||
from invokeai.app.invocations.primitives import ImageOutput
|
from invokeai.app.invocations.primitives import ImageOutput
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
from invokeai.app.util.misc import SEED_MAX
|
from invokeai.app.util.misc import SEED_MAX
|
||||||
@ -14,10 +16,6 @@ from invokeai.backend.image_util.infill_methods.patchmatch import PatchMatch, in
|
|||||||
from invokeai.backend.image_util.infill_methods.tile import infill_tile
|
from invokeai.backend.image_util.infill_methods.tile import infill_tile
|
||||||
from invokeai.backend.util.logging import InvokeAILogger
|
from invokeai.backend.util.logging import InvokeAILogger
|
||||||
|
|
||||||
from .baseinvocation import BaseInvocation, invocation
|
|
||||||
from .fields import InputField, WithBoard, WithMetadata
|
|
||||||
from .image import PIL_RESAMPLING_MAP, PIL_RESAMPLING_MODES
|
|
||||||
|
|
||||||
logger = InvokeAILogger.get_logger()
|
logger = InvokeAILogger.get_logger()
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,3 +1,5 @@
|
|||||||
|
from contextlib import nullcontext
|
||||||
|
|
||||||
import torch
|
import torch
|
||||||
from diffusers.image_processor import VaeImageProcessor
|
from diffusers.image_processor import VaeImageProcessor
|
||||||
from diffusers.models.attention_processor import (
|
from diffusers.models.attention_processor import (
|
||||||
@ -8,10 +10,9 @@ from diffusers.models.attention_processor import (
|
|||||||
)
|
)
|
||||||
from diffusers.models.autoencoders.autoencoder_kl import AutoencoderKL
|
from diffusers.models.autoencoders.autoencoder_kl import AutoencoderKL
|
||||||
from diffusers.models.autoencoders.autoencoder_tiny import AutoencoderTiny
|
from diffusers.models.autoencoders.autoencoder_tiny import AutoencoderTiny
|
||||||
from diffusers.models.unets.unet_2d_condition import UNet2DConditionModel
|
|
||||||
|
|
||||||
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
||||||
from invokeai.app.invocations.constants import DEFAULT_PRECISION
|
from invokeai.app.invocations.constants import DEFAULT_PRECISION, LATENT_SCALE_FACTOR
|
||||||
from invokeai.app.invocations.fields import (
|
from invokeai.app.invocations.fields import (
|
||||||
FieldDescriptions,
|
FieldDescriptions,
|
||||||
Input,
|
Input,
|
||||||
@ -24,6 +25,7 @@ from invokeai.app.invocations.model import VAEField
|
|||||||
from invokeai.app.invocations.primitives import ImageOutput
|
from invokeai.app.invocations.primitives import ImageOutput
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
from invokeai.backend.stable_diffusion import set_seamless
|
from invokeai.backend.stable_diffusion import set_seamless
|
||||||
|
from invokeai.backend.stable_diffusion.vae_tiling import patch_vae_tiling_params
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
|
|
||||||
|
|
||||||
@ -32,7 +34,7 @@ from invokeai.backend.util.devices import TorchDevice
|
|||||||
title="Latents to Image",
|
title="Latents to Image",
|
||||||
tags=["latents", "image", "vae", "l2i"],
|
tags=["latents", "image", "vae", "l2i"],
|
||||||
category="latents",
|
category="latents",
|
||||||
version="1.2.2",
|
version="1.3.0",
|
||||||
)
|
)
|
||||||
class LatentsToImageInvocation(BaseInvocation, WithMetadata, WithBoard):
|
class LatentsToImageInvocation(BaseInvocation, WithMetadata, WithBoard):
|
||||||
"""Generates an image from latents."""
|
"""Generates an image from latents."""
|
||||||
@ -46,6 +48,9 @@ class LatentsToImageInvocation(BaseInvocation, WithMetadata, WithBoard):
|
|||||||
input=Input.Connection,
|
input=Input.Connection,
|
||||||
)
|
)
|
||||||
tiled: bool = InputField(default=False, description=FieldDescriptions.tiled)
|
tiled: bool = InputField(default=False, description=FieldDescriptions.tiled)
|
||||||
|
# NOTE: tile_size = 0 is a special value. We use this rather than `int | None`, because the workflow UI does not
|
||||||
|
# offer a way to directly set None values.
|
||||||
|
tile_size: int = InputField(default=0, multiple_of=8, description=FieldDescriptions.vae_tile_size)
|
||||||
fp32: bool = InputField(default=DEFAULT_PRECISION == torch.float32, description=FieldDescriptions.fp32)
|
fp32: bool = InputField(default=DEFAULT_PRECISION == torch.float32, description=FieldDescriptions.fp32)
|
||||||
|
|
||||||
@torch.no_grad()
|
@torch.no_grad()
|
||||||
@ -53,9 +58,9 @@ class LatentsToImageInvocation(BaseInvocation, WithMetadata, WithBoard):
|
|||||||
latents = context.tensors.load(self.latents.latents_name)
|
latents = context.tensors.load(self.latents.latents_name)
|
||||||
|
|
||||||
vae_info = context.models.load(self.vae.vae)
|
vae_info = context.models.load(self.vae.vae)
|
||||||
assert isinstance(vae_info.model, (UNet2DConditionModel, AutoencoderKL, AutoencoderTiny))
|
assert isinstance(vae_info.model, (AutoencoderKL, AutoencoderTiny))
|
||||||
with set_seamless(vae_info.model, self.vae.seamless_axes), vae_info as vae:
|
with set_seamless(vae_info.model, self.vae.seamless_axes), vae_info as vae:
|
||||||
assert isinstance(vae, torch.nn.Module)
|
assert isinstance(vae, (AutoencoderKL, AutoencoderTiny))
|
||||||
latents = latents.to(vae.device)
|
latents = latents.to(vae.device)
|
||||||
if self.fp32:
|
if self.fp32:
|
||||||
vae.to(dtype=torch.float32)
|
vae.to(dtype=torch.float32)
|
||||||
@ -87,10 +92,19 @@ class LatentsToImageInvocation(BaseInvocation, WithMetadata, WithBoard):
|
|||||||
else:
|
else:
|
||||||
vae.disable_tiling()
|
vae.disable_tiling()
|
||||||
|
|
||||||
|
tiling_context = nullcontext()
|
||||||
|
if self.tile_size > 0:
|
||||||
|
tiling_context = patch_vae_tiling_params(
|
||||||
|
vae,
|
||||||
|
tile_sample_min_size=self.tile_size,
|
||||||
|
tile_latent_min_size=self.tile_size // LATENT_SCALE_FACTOR,
|
||||||
|
tile_overlap_factor=0.25,
|
||||||
|
)
|
||||||
|
|
||||||
# clear memory as vae decode can request a lot
|
# clear memory as vae decode can request a lot
|
||||||
TorchDevice.empty_cache()
|
TorchDevice.empty_cache()
|
||||||
|
|
||||||
with torch.inference_mode():
|
with torch.inference_mode(), tiling_context:
|
||||||
# copied from diffusers pipeline
|
# copied from diffusers pipeline
|
||||||
latents = latents / vae.config.scaling_factor
|
latents = latents / vae.config.scaling_factor
|
||||||
image = vae.decode(latents, return_dict=False)[0]
|
image = vae.decode(latents, return_dict=False)[0]
|
||||||
|
@ -5,12 +5,11 @@ from typing import Literal
|
|||||||
import numpy as np
|
import numpy as np
|
||||||
from pydantic import ValidationInfo, field_validator
|
from pydantic import ValidationInfo, field_validator
|
||||||
|
|
||||||
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
||||||
from invokeai.app.invocations.fields import FieldDescriptions, InputField
|
from invokeai.app.invocations.fields import FieldDescriptions, InputField
|
||||||
from invokeai.app.invocations.primitives import FloatOutput, IntegerOutput
|
from invokeai.app.invocations.primitives import FloatOutput, IntegerOutput
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
|
|
||||||
from .baseinvocation import BaseInvocation, invocation
|
|
||||||
|
|
||||||
|
|
||||||
@invocation("add", title="Add Integers", tags=["math", "add"], category="math", version="1.0.1")
|
@invocation("add", title="Add Integers", tags=["math", "add"], category="math", version="1.0.1")
|
||||||
class AddInvocation(BaseInvocation):
|
class AddInvocation(BaseInvocation):
|
||||||
|
@ -14,8 +14,7 @@ from invokeai.app.invocations.fields import (
|
|||||||
from invokeai.app.invocations.model import ModelIdentifierField
|
from invokeai.app.invocations.model import ModelIdentifierField
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
from invokeai.app.util.controlnet_utils import CONTROLNET_MODE_VALUES, CONTROLNET_RESIZE_VALUES
|
from invokeai.app.util.controlnet_utils import CONTROLNET_MODE_VALUES, CONTROLNET_RESIZE_VALUES
|
||||||
|
from invokeai.version.invokeai_version import __version__
|
||||||
from ...version import __version__
|
|
||||||
|
|
||||||
|
|
||||||
class MetadataItemField(BaseModel):
|
class MetadataItemField(BaseModel):
|
||||||
|
@ -3,18 +3,17 @@ from typing import List, Optional
|
|||||||
|
|
||||||
from pydantic import BaseModel, Field
|
from pydantic import BaseModel, Field
|
||||||
|
|
||||||
from invokeai.app.invocations.fields import FieldDescriptions, Input, InputField, OutputField, UIType
|
from invokeai.app.invocations.baseinvocation import (
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
|
||||||
from invokeai.app.shared.models import FreeUConfig
|
|
||||||
from invokeai.backend.model_manager.config import AnyModelConfig, BaseModelType, ModelType, SubModelType
|
|
||||||
|
|
||||||
from .baseinvocation import (
|
|
||||||
BaseInvocation,
|
BaseInvocation,
|
||||||
BaseInvocationOutput,
|
BaseInvocationOutput,
|
||||||
Classification,
|
Classification,
|
||||||
invocation,
|
invocation,
|
||||||
invocation_output,
|
invocation_output,
|
||||||
)
|
)
|
||||||
|
from invokeai.app.invocations.fields import FieldDescriptions, Input, InputField, OutputField, UIType
|
||||||
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
|
from invokeai.app.shared.models import FreeUConfig
|
||||||
|
from invokeai.backend.model_manager.config import AnyModelConfig, BaseModelType, ModelType, SubModelType
|
||||||
|
|
||||||
|
|
||||||
class ModelIdentifierField(BaseModel):
|
class ModelIdentifierField(BaseModel):
|
||||||
|
@ -4,18 +4,12 @@
|
|||||||
import torch
|
import torch
|
||||||
from pydantic import field_validator
|
from pydantic import field_validator
|
||||||
|
|
||||||
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, BaseInvocationOutput, invocation, invocation_output
|
||||||
from invokeai.app.invocations.constants import LATENT_SCALE_FACTOR
|
from invokeai.app.invocations.constants import LATENT_SCALE_FACTOR
|
||||||
from invokeai.app.invocations.fields import FieldDescriptions, InputField, LatentsField, OutputField
|
from invokeai.app.invocations.fields import FieldDescriptions, InputField, LatentsField, OutputField
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
from invokeai.app.util.misc import SEED_MAX
|
from invokeai.app.util.misc import SEED_MAX
|
||||||
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
from ...backend.util.devices import TorchDevice
|
|
||||||
from .baseinvocation import (
|
|
||||||
BaseInvocation,
|
|
||||||
BaseInvocationOutput,
|
|
||||||
invocation,
|
|
||||||
invocation_output,
|
|
||||||
)
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Utilities
|
Utilities
|
||||||
|
@ -39,12 +39,11 @@ from easing_functions import (
|
|||||||
)
|
)
|
||||||
from matplotlib.ticker import MaxNLocator
|
from matplotlib.ticker import MaxNLocator
|
||||||
|
|
||||||
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
||||||
|
from invokeai.app.invocations.fields import InputField
|
||||||
from invokeai.app.invocations.primitives import FloatCollectionOutput
|
from invokeai.app.invocations.primitives import FloatCollectionOutput
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
|
|
||||||
from .baseinvocation import BaseInvocation, invocation
|
|
||||||
from .fields import InputField
|
|
||||||
|
|
||||||
|
|
||||||
@invocation(
|
@invocation(
|
||||||
"float_range",
|
"float_range",
|
||||||
|
@ -4,6 +4,7 @@ from typing import Optional
|
|||||||
|
|
||||||
import torch
|
import torch
|
||||||
|
|
||||||
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, BaseInvocationOutput, invocation, invocation_output
|
||||||
from invokeai.app.invocations.constants import LATENT_SCALE_FACTOR
|
from invokeai.app.invocations.constants import LATENT_SCALE_FACTOR
|
||||||
from invokeai.app.invocations.fields import (
|
from invokeai.app.invocations.fields import (
|
||||||
ColorField,
|
ColorField,
|
||||||
@ -21,13 +22,6 @@ from invokeai.app.invocations.fields import (
|
|||||||
from invokeai.app.services.images.images_common import ImageDTO
|
from invokeai.app.services.images.images_common import ImageDTO
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
|
|
||||||
from .baseinvocation import (
|
|
||||||
BaseInvocation,
|
|
||||||
BaseInvocationOutput,
|
|
||||||
invocation,
|
|
||||||
invocation_output,
|
|
||||||
)
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Primitives: Boolean, Integer, Float, String, Image, Latents, Conditioning, Color
|
Primitives: Boolean, Integer, Float, String, Image, Latents, Conditioning, Color
|
||||||
- primitive nodes
|
- primitive nodes
|
||||||
|
@ -5,12 +5,11 @@ import numpy as np
|
|||||||
from dynamicprompts.generators import CombinatorialPromptGenerator, RandomPromptGenerator
|
from dynamicprompts.generators import CombinatorialPromptGenerator, RandomPromptGenerator
|
||||||
from pydantic import field_validator
|
from pydantic import field_validator
|
||||||
|
|
||||||
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
||||||
|
from invokeai.app.invocations.fields import InputField, UIComponent
|
||||||
from invokeai.app.invocations.primitives import StringCollectionOutput
|
from invokeai.app.invocations.primitives import StringCollectionOutput
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
|
|
||||||
from .baseinvocation import BaseInvocation, invocation
|
|
||||||
from .fields import InputField, UIComponent
|
|
||||||
|
|
||||||
|
|
||||||
@invocation(
|
@invocation(
|
||||||
"dynamic_prompt",
|
"dynamic_prompt",
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
from invokeai.app.invocations.baseinvocation import BaseInvocation, BaseInvocationOutput, invocation, invocation_output
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, BaseInvocationOutput, invocation, invocation_output
|
||||||
from invokeai.app.invocations.constants import SCHEDULER_NAME_VALUES
|
|
||||||
from invokeai.app.invocations.fields import (
|
from invokeai.app.invocations.fields import (
|
||||||
FieldDescriptions,
|
FieldDescriptions,
|
||||||
InputField,
|
InputField,
|
||||||
@ -7,6 +6,7 @@ from invokeai.app.invocations.fields import (
|
|||||||
UIType,
|
UIType,
|
||||||
)
|
)
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
|
from invokeai.backend.stable_diffusion.schedulers.schedulers import SCHEDULER_NAME_VALUES
|
||||||
|
|
||||||
|
|
||||||
@invocation_output("scheduler_output")
|
@invocation_output("scheduler_output")
|
||||||
|
@ -1,15 +1,9 @@
|
|||||||
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, BaseInvocationOutput, invocation, invocation_output
|
||||||
from invokeai.app.invocations.fields import FieldDescriptions, InputField, OutputField, UIType
|
from invokeai.app.invocations.fields import FieldDescriptions, InputField, OutputField, UIType
|
||||||
|
from invokeai.app.invocations.model import CLIPField, ModelIdentifierField, UNetField, VAEField
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
from invokeai.backend.model_manager import SubModelType
|
from invokeai.backend.model_manager import SubModelType
|
||||||
|
|
||||||
from .baseinvocation import (
|
|
||||||
BaseInvocation,
|
|
||||||
BaseInvocationOutput,
|
|
||||||
invocation,
|
|
||||||
invocation_output,
|
|
||||||
)
|
|
||||||
from .model import CLIPField, ModelIdentifierField, UNetField, VAEField
|
|
||||||
|
|
||||||
|
|
||||||
@invocation_output("sdxl_model_loader_output")
|
@invocation_output("sdxl_model_loader_output")
|
||||||
class SDXLModelLoaderOutput(BaseInvocationOutput):
|
class SDXLModelLoaderOutput(BaseInvocationOutput):
|
||||||
|
@ -2,17 +2,11 @@
|
|||||||
|
|
||||||
import re
|
import re
|
||||||
|
|
||||||
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, BaseInvocationOutput, invocation, invocation_output
|
||||||
|
from invokeai.app.invocations.fields import InputField, OutputField, UIComponent
|
||||||
|
from invokeai.app.invocations.primitives import StringOutput
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
|
|
||||||
from .baseinvocation import (
|
|
||||||
BaseInvocation,
|
|
||||||
BaseInvocationOutput,
|
|
||||||
invocation,
|
|
||||||
invocation_output,
|
|
||||||
)
|
|
||||||
from .fields import InputField, OutputField, UIComponent
|
|
||||||
from .primitives import StringOutput
|
|
||||||
|
|
||||||
|
|
||||||
@invocation_output("string_pos_neg_output")
|
@invocation_output("string_pos_neg_output")
|
||||||
class StringPosNegOutput(BaseInvocationOutput):
|
class StringPosNegOutput(BaseInvocationOutput):
|
||||||
|
@ -8,7 +8,7 @@ from diffusers.schedulers.scheduling_utils import SchedulerMixin
|
|||||||
from pydantic import field_validator
|
from pydantic import field_validator
|
||||||
|
|
||||||
from invokeai.app.invocations.baseinvocation import BaseInvocation, Classification, invocation
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, Classification, invocation
|
||||||
from invokeai.app.invocations.constants import LATENT_SCALE_FACTOR, SCHEDULER_NAME_VALUES
|
from invokeai.app.invocations.constants import LATENT_SCALE_FACTOR
|
||||||
from invokeai.app.invocations.controlnet_image_processors import ControlField
|
from invokeai.app.invocations.controlnet_image_processors import ControlField
|
||||||
from invokeai.app.invocations.denoise_latents import DenoiseLatentsInvocation, get_scheduler
|
from invokeai.app.invocations.denoise_latents import DenoiseLatentsInvocation, get_scheduler
|
||||||
from invokeai.app.invocations.fields import (
|
from invokeai.app.invocations.fields import (
|
||||||
@ -29,6 +29,7 @@ from invokeai.backend.stable_diffusion.multi_diffusion_pipeline import (
|
|||||||
MultiDiffusionPipeline,
|
MultiDiffusionPipeline,
|
||||||
MultiDiffusionRegionConditioning,
|
MultiDiffusionRegionConditioning,
|
||||||
)
|
)
|
||||||
|
from invokeai.backend.stable_diffusion.schedulers.schedulers import SCHEDULER_NAME_VALUES
|
||||||
from invokeai.backend.tiles.tiles import (
|
from invokeai.backend.tiles.tiles import (
|
||||||
calc_tiles_min_overlap,
|
calc_tiles_min_overlap,
|
||||||
)
|
)
|
||||||
|
@ -6,15 +6,13 @@ import numpy as np
|
|||||||
from PIL import Image
|
from PIL import Image
|
||||||
from pydantic import ConfigDict
|
from pydantic import ConfigDict
|
||||||
|
|
||||||
from invokeai.app.invocations.fields import ImageField
|
from invokeai.app.invocations.baseinvocation import BaseInvocation, invocation
|
||||||
|
from invokeai.app.invocations.fields import ImageField, InputField, WithBoard, WithMetadata
|
||||||
from invokeai.app.invocations.primitives import ImageOutput
|
from invokeai.app.invocations.primitives import ImageOutput
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContext
|
from invokeai.app.services.shared.invocation_context import InvocationContext
|
||||||
from invokeai.backend.image_util.basicsr.rrdbnet_arch import RRDBNet
|
from invokeai.backend.image_util.basicsr.rrdbnet_arch import RRDBNet
|
||||||
from invokeai.backend.image_util.realesrgan.realesrgan import RealESRGAN
|
from invokeai.backend.image_util.realesrgan.realesrgan import RealESRGAN
|
||||||
|
|
||||||
from .baseinvocation import BaseInvocation, invocation
|
|
||||||
from .fields import InputField, WithBoard, WithMetadata
|
|
||||||
|
|
||||||
# TODO: Populate this from disk?
|
# TODO: Populate this from disk?
|
||||||
# TODO: Use model manager to load?
|
# TODO: Use model manager to load?
|
||||||
ESRGAN_MODELS = Literal[
|
ESRGAN_MODELS = Literal[
|
||||||
|
@ -2,12 +2,11 @@ import sqlite3
|
|||||||
import threading
|
import threading
|
||||||
from typing import Optional, cast
|
from typing import Optional, cast
|
||||||
|
|
||||||
|
from invokeai.app.services.board_image_records.board_image_records_base import BoardImageRecordStorageBase
|
||||||
from invokeai.app.services.image_records.image_records_common import ImageRecord, deserialize_image_record
|
from invokeai.app.services.image_records.image_records_common import ImageRecord, deserialize_image_record
|
||||||
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
||||||
from invokeai.app.services.shared.sqlite.sqlite_database import SqliteDatabase
|
from invokeai.app.services.shared.sqlite.sqlite_database import SqliteDatabase
|
||||||
|
|
||||||
from .board_image_records_base import BoardImageRecordStorageBase
|
|
||||||
|
|
||||||
|
|
||||||
class SqliteBoardImageRecordStorage(BoardImageRecordStorageBase):
|
class SqliteBoardImageRecordStorage(BoardImageRecordStorageBase):
|
||||||
_conn: sqlite3.Connection
|
_conn: sqlite3.Connection
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
from typing import Optional
|
from typing import Optional
|
||||||
|
|
||||||
|
from invokeai.app.services.board_images.board_images_base import BoardImagesServiceABC
|
||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.invoker import Invoker
|
||||||
|
|
||||||
from .board_images_base import BoardImagesServiceABC
|
|
||||||
|
|
||||||
|
|
||||||
class BoardImagesService(BoardImagesServiceABC):
|
class BoardImagesService(BoardImagesServiceABC):
|
||||||
__invoker: Invoker
|
__invoker: Invoker
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
from abc import ABC, abstractmethod
|
from abc import ABC, abstractmethod
|
||||||
|
|
||||||
|
from invokeai.app.services.board_records.board_records_common import BoardChanges, BoardRecord
|
||||||
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
||||||
|
|
||||||
from .board_records_common import BoardChanges, BoardRecord
|
|
||||||
|
|
||||||
|
|
||||||
class BoardRecordStorageBase(ABC):
|
class BoardRecordStorageBase(ABC):
|
||||||
"""Low-level service responsible for interfacing with the board record store."""
|
"""Low-level service responsible for interfacing with the board record store."""
|
||||||
|
@ -2,12 +2,8 @@ import sqlite3
|
|||||||
import threading
|
import threading
|
||||||
from typing import Union, cast
|
from typing import Union, cast
|
||||||
|
|
||||||
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
from invokeai.app.services.board_records.board_records_base import BoardRecordStorageBase
|
||||||
from invokeai.app.services.shared.sqlite.sqlite_database import SqliteDatabase
|
from invokeai.app.services.board_records.board_records_common import (
|
||||||
from invokeai.app.util.misc import uuid_string
|
|
||||||
|
|
||||||
from .board_records_base import BoardRecordStorageBase
|
|
||||||
from .board_records_common import (
|
|
||||||
BoardChanges,
|
BoardChanges,
|
||||||
BoardRecord,
|
BoardRecord,
|
||||||
BoardRecordDeleteException,
|
BoardRecordDeleteException,
|
||||||
@ -15,6 +11,9 @@ from .board_records_common import (
|
|||||||
BoardRecordSaveException,
|
BoardRecordSaveException,
|
||||||
deserialize_board_record,
|
deserialize_board_record,
|
||||||
)
|
)
|
||||||
|
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
||||||
|
from invokeai.app.services.shared.sqlite.sqlite_database import SqliteDatabase
|
||||||
|
from invokeai.app.util.misc import uuid_string
|
||||||
|
|
||||||
|
|
||||||
class SqliteBoardRecordStorage(BoardRecordStorageBase):
|
class SqliteBoardRecordStorage(BoardRecordStorageBase):
|
||||||
|
@ -1,10 +1,9 @@
|
|||||||
from abc import ABC, abstractmethod
|
from abc import ABC, abstractmethod
|
||||||
|
|
||||||
from invokeai.app.services.board_records.board_records_common import BoardChanges
|
from invokeai.app.services.board_records.board_records_common import BoardChanges
|
||||||
|
from invokeai.app.services.boards.boards_common import BoardDTO
|
||||||
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
||||||
|
|
||||||
from .boards_common import BoardDTO
|
|
||||||
|
|
||||||
|
|
||||||
class BoardServiceABC(ABC):
|
class BoardServiceABC(ABC):
|
||||||
"""High-level service for board management."""
|
"""High-level service for board management."""
|
||||||
|
@ -2,7 +2,7 @@ from typing import Optional
|
|||||||
|
|
||||||
from pydantic import Field
|
from pydantic import Field
|
||||||
|
|
||||||
from ..board_records.board_records_common import BoardRecord
|
from invokeai.app.services.board_records.board_records_common import BoardRecord
|
||||||
|
|
||||||
|
|
||||||
class BoardDTO(BoardRecord):
|
class BoardDTO(BoardRecord):
|
||||||
|
@ -1,11 +1,9 @@
|
|||||||
from invokeai.app.services.board_records.board_records_common import BoardChanges
|
from invokeai.app.services.board_records.board_records_common import BoardChanges
|
||||||
from invokeai.app.services.boards.boards_common import BoardDTO
|
from invokeai.app.services.boards.boards_base import BoardServiceABC
|
||||||
|
from invokeai.app.services.boards.boards_common import BoardDTO, board_record_to_dto
|
||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.invoker import Invoker
|
||||||
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
||||||
|
|
||||||
from .boards_base import BoardServiceABC
|
|
||||||
from .boards_common import board_record_to_dto
|
|
||||||
|
|
||||||
|
|
||||||
class BoardService(BoardServiceABC):
|
class BoardService(BoardServiceABC):
|
||||||
__invoker: Invoker
|
__invoker: Invoker
|
||||||
|
@ -4,6 +4,7 @@ from typing import Optional, Union
|
|||||||
from zipfile import ZipFile
|
from zipfile import ZipFile
|
||||||
|
|
||||||
from invokeai.app.services.board_records.board_records_common import BoardRecordNotFoundException
|
from invokeai.app.services.board_records.board_records_common import BoardRecordNotFoundException
|
||||||
|
from invokeai.app.services.bulk_download.bulk_download_base import BulkDownloadBase
|
||||||
from invokeai.app.services.bulk_download.bulk_download_common import (
|
from invokeai.app.services.bulk_download.bulk_download_common import (
|
||||||
DEFAULT_BULK_DOWNLOAD_ID,
|
DEFAULT_BULK_DOWNLOAD_ID,
|
||||||
BulkDownloadException,
|
BulkDownloadException,
|
||||||
@ -15,8 +16,6 @@ from invokeai.app.services.images.images_common import ImageDTO
|
|||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.invoker import Invoker
|
||||||
from invokeai.app.util.misc import uuid_string
|
from invokeai.app.util.misc import uuid_string
|
||||||
|
|
||||||
from .bulk_download_base import BulkDownloadBase
|
|
||||||
|
|
||||||
|
|
||||||
class BulkDownloadService(BulkDownloadBase):
|
class BulkDownloadService(BulkDownloadBase):
|
||||||
def start(self, invoker: Invoker) -> None:
|
def start(self, invoker: Invoker) -> None:
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
"""Init file for InvokeAI configure package."""
|
"""Init file for InvokeAI configure package."""
|
||||||
|
|
||||||
from invokeai.app.services.config.config_common import PagingArgumentParser
|
from invokeai.app.services.config.config_common import PagingArgumentParser
|
||||||
|
from invokeai.app.services.config.config_default import InvokeAIAppConfig, get_config
|
||||||
from .config_default import InvokeAIAppConfig, get_config
|
|
||||||
|
|
||||||
__all__ = ["InvokeAIAppConfig", "get_config", "PagingArgumentParser"]
|
__all__ = ["InvokeAIAppConfig", "get_config", "PagingArgumentParser"]
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
"""Init file for download queue."""
|
"""Init file for download queue."""
|
||||||
|
|
||||||
from .download_base import (
|
from invokeai.app.services.download.download_base import (
|
||||||
DownloadJob,
|
DownloadJob,
|
||||||
DownloadJobStatus,
|
DownloadJobStatus,
|
||||||
DownloadQueueServiceBase,
|
DownloadQueueServiceBase,
|
||||||
MultiFileDownloadJob,
|
MultiFileDownloadJob,
|
||||||
UnknownJobIDException,
|
UnknownJobIDException,
|
||||||
)
|
)
|
||||||
from .download_default import DownloadQueueService, TqdmProgress
|
from invokeai.app.services.download.download_default import DownloadQueueService, TqdmProgress
|
||||||
|
|
||||||
__all__ = [
|
__all__ = [
|
||||||
"DownloadJob",
|
"DownloadJob",
|
||||||
|
@ -16,12 +16,7 @@ from requests import HTTPError
|
|||||||
from tqdm import tqdm
|
from tqdm import tqdm
|
||||||
|
|
||||||
from invokeai.app.services.config import InvokeAIAppConfig, get_config
|
from invokeai.app.services.config import InvokeAIAppConfig, get_config
|
||||||
from invokeai.app.services.events.events_base import EventServiceBase
|
from invokeai.app.services.download.download_base import (
|
||||||
from invokeai.app.util.misc import get_iso_timestamp
|
|
||||||
from invokeai.backend.model_manager.metadata import RemoteModelFile
|
|
||||||
from invokeai.backend.util.logging import InvokeAILogger
|
|
||||||
|
|
||||||
from .download_base import (
|
|
||||||
DownloadEventHandler,
|
DownloadEventHandler,
|
||||||
DownloadExceptionHandler,
|
DownloadExceptionHandler,
|
||||||
DownloadJob,
|
DownloadJob,
|
||||||
@ -33,6 +28,10 @@ from .download_base import (
|
|||||||
ServiceInactiveException,
|
ServiceInactiveException,
|
||||||
UnknownJobIDException,
|
UnknownJobIDException,
|
||||||
)
|
)
|
||||||
|
from invokeai.app.services.events.events_base import EventServiceBase
|
||||||
|
from invokeai.app.util.misc import get_iso_timestamp
|
||||||
|
from invokeai.backend.model_manager.metadata import RemoteModelFile
|
||||||
|
from invokeai.backend.util.logging import InvokeAILogger
|
||||||
|
|
||||||
# Maximum number of bytes to download during each call to requests.iter_content()
|
# Maximum number of bytes to download during each call to requests.iter_content()
|
||||||
DOWNLOAD_CHUNK_SIZE = 100000
|
DOWNLOAD_CHUNK_SIZE = 100000
|
||||||
@ -185,7 +184,7 @@ class DownloadQueueService(DownloadQueueServiceBase):
|
|||||||
job = DownloadJob(
|
job = DownloadJob(
|
||||||
source=url,
|
source=url,
|
||||||
dest=path,
|
dest=path,
|
||||||
access_token=access_token,
|
access_token=access_token or self._lookup_access_token(url),
|
||||||
)
|
)
|
||||||
mfdj.download_parts.add(job)
|
mfdj.download_parts.add(job)
|
||||||
self._download_part2parent[job.source] = mfdj
|
self._download_part2parent[job.source] = mfdj
|
||||||
|
@ -6,12 +6,11 @@ from queue import Empty, Queue
|
|||||||
|
|
||||||
from fastapi_events.dispatcher import dispatch
|
from fastapi_events.dispatcher import dispatch
|
||||||
|
|
||||||
|
from invokeai.app.services.events.events_base import EventServiceBase
|
||||||
from invokeai.app.services.events.events_common import (
|
from invokeai.app.services.events.events_common import (
|
||||||
EventBase,
|
EventBase,
|
||||||
)
|
)
|
||||||
|
|
||||||
from .events_base import EventServiceBase
|
|
||||||
|
|
||||||
|
|
||||||
class FastAPIEventService(EventServiceBase):
|
class FastAPIEventService(EventServiceBase):
|
||||||
def __init__(self, event_handler_id: int) -> None:
|
def __init__(self, event_handler_id: int) -> None:
|
||||||
|
@ -7,12 +7,15 @@ from PIL import Image, PngImagePlugin
|
|||||||
from PIL.Image import Image as PILImageType
|
from PIL.Image import Image as PILImageType
|
||||||
from send2trash import send2trash
|
from send2trash import send2trash
|
||||||
|
|
||||||
|
from invokeai.app.services.image_files.image_files_base import ImageFileStorageBase
|
||||||
|
from invokeai.app.services.image_files.image_files_common import (
|
||||||
|
ImageFileDeleteException,
|
||||||
|
ImageFileNotFoundException,
|
||||||
|
ImageFileSaveException,
|
||||||
|
)
|
||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.invoker import Invoker
|
||||||
from invokeai.app.util.thumbnails import get_thumbnail_name, make_thumbnail
|
from invokeai.app.util.thumbnails import get_thumbnail_name, make_thumbnail
|
||||||
|
|
||||||
from .image_files_base import ImageFileStorageBase
|
|
||||||
from .image_files_common import ImageFileDeleteException, ImageFileNotFoundException, ImageFileSaveException
|
|
||||||
|
|
||||||
|
|
||||||
class DiskImageFileStorage(ImageFileStorageBase):
|
class DiskImageFileStorage(ImageFileStorageBase):
|
||||||
"""Stores images on disk"""
|
"""Stores images on disk"""
|
||||||
|
@ -3,11 +3,15 @@ from datetime import datetime
|
|||||||
from typing import Optional
|
from typing import Optional
|
||||||
|
|
||||||
from invokeai.app.invocations.fields import MetadataField
|
from invokeai.app.invocations.fields import MetadataField
|
||||||
|
from invokeai.app.services.image_records.image_records_common import (
|
||||||
|
ImageCategory,
|
||||||
|
ImageRecord,
|
||||||
|
ImageRecordChanges,
|
||||||
|
ResourceOrigin,
|
||||||
|
)
|
||||||
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
||||||
from invokeai.app.services.shared.sqlite.sqlite_common import SQLiteDirection
|
from invokeai.app.services.shared.sqlite.sqlite_common import SQLiteDirection
|
||||||
|
|
||||||
from .image_records_common import ImageCategory, ImageRecord, ImageRecordChanges, ResourceOrigin
|
|
||||||
|
|
||||||
|
|
||||||
class ImageRecordStorageBase(ABC):
|
class ImageRecordStorageBase(ABC):
|
||||||
"""Low-level service responsible for interfacing with the image record store."""
|
"""Low-level service responsible for interfacing with the image record store."""
|
||||||
|
@ -4,12 +4,8 @@ from datetime import datetime
|
|||||||
from typing import Optional, Union, cast
|
from typing import Optional, Union, cast
|
||||||
|
|
||||||
from invokeai.app.invocations.fields import MetadataField, MetadataFieldValidator
|
from invokeai.app.invocations.fields import MetadataField, MetadataFieldValidator
|
||||||
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
from invokeai.app.services.image_records.image_records_base import ImageRecordStorageBase
|
||||||
from invokeai.app.services.shared.sqlite.sqlite_common import SQLiteDirection
|
from invokeai.app.services.image_records.image_records_common import (
|
||||||
from invokeai.app.services.shared.sqlite.sqlite_database import SqliteDatabase
|
|
||||||
|
|
||||||
from .image_records_base import ImageRecordStorageBase
|
|
||||||
from .image_records_common import (
|
|
||||||
IMAGE_DTO_COLS,
|
IMAGE_DTO_COLS,
|
||||||
ImageCategory,
|
ImageCategory,
|
||||||
ImageRecord,
|
ImageRecord,
|
||||||
@ -20,6 +16,9 @@ from .image_records_common import (
|
|||||||
ResourceOrigin,
|
ResourceOrigin,
|
||||||
deserialize_image_record,
|
deserialize_image_record,
|
||||||
)
|
)
|
||||||
|
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
||||||
|
from invokeai.app.services.shared.sqlite.sqlite_common import SQLiteDirection
|
||||||
|
from invokeai.app.services.shared.sqlite.sqlite_database import SqliteDatabase
|
||||||
|
|
||||||
|
|
||||||
class SqliteImageRecordStorage(ImageRecordStorageBase):
|
class SqliteImageRecordStorage(ImageRecordStorageBase):
|
||||||
|
@ -3,16 +3,12 @@ from typing import Optional
|
|||||||
from PIL.Image import Image as PILImageType
|
from PIL.Image import Image as PILImageType
|
||||||
|
|
||||||
from invokeai.app.invocations.fields import MetadataField
|
from invokeai.app.invocations.fields import MetadataField
|
||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.image_files.image_files_common import (
|
||||||
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
|
||||||
from invokeai.app.services.shared.sqlite.sqlite_common import SQLiteDirection
|
|
||||||
|
|
||||||
from ..image_files.image_files_common import (
|
|
||||||
ImageFileDeleteException,
|
ImageFileDeleteException,
|
||||||
ImageFileNotFoundException,
|
ImageFileNotFoundException,
|
||||||
ImageFileSaveException,
|
ImageFileSaveException,
|
||||||
)
|
)
|
||||||
from ..image_records.image_records_common import (
|
from invokeai.app.services.image_records.image_records_common import (
|
||||||
ImageCategory,
|
ImageCategory,
|
||||||
ImageRecord,
|
ImageRecord,
|
||||||
ImageRecordChanges,
|
ImageRecordChanges,
|
||||||
@ -23,8 +19,11 @@ from ..image_records.image_records_common import (
|
|||||||
InvalidOriginException,
|
InvalidOriginException,
|
||||||
ResourceOrigin,
|
ResourceOrigin,
|
||||||
)
|
)
|
||||||
from .images_base import ImageServiceABC
|
from invokeai.app.services.images.images_base import ImageServiceABC
|
||||||
from .images_common import ImageDTO, image_record_to_dto
|
from invokeai.app.services.images.images_common import ImageDTO, image_record_to_dto
|
||||||
|
from invokeai.app.services.invoker import Invoker
|
||||||
|
from invokeai.app.services.shared.pagination import OffsetPaginatedResults
|
||||||
|
from invokeai.app.services.shared.sqlite.sqlite_common import SQLiteDirection
|
||||||
|
|
||||||
|
|
||||||
class ImageService(ImageServiceABC):
|
class ImageService(ImageServiceABC):
|
||||||
|
@ -10,29 +10,28 @@ if TYPE_CHECKING:
|
|||||||
|
|
||||||
import torch
|
import torch
|
||||||
|
|
||||||
|
from invokeai.app.services.board_image_records.board_image_records_base import BoardImageRecordStorageBase
|
||||||
|
from invokeai.app.services.board_images.board_images_base import BoardImagesServiceABC
|
||||||
|
from invokeai.app.services.board_records.board_records_base import BoardRecordStorageBase
|
||||||
|
from invokeai.app.services.boards.boards_base import BoardServiceABC
|
||||||
|
from invokeai.app.services.bulk_download.bulk_download_base import BulkDownloadBase
|
||||||
|
from invokeai.app.services.config import InvokeAIAppConfig
|
||||||
|
from invokeai.app.services.download import DownloadQueueServiceBase
|
||||||
|
from invokeai.app.services.events.events_base import EventServiceBase
|
||||||
|
from invokeai.app.services.image_files.image_files_base import ImageFileStorageBase
|
||||||
|
from invokeai.app.services.image_records.image_records_base import ImageRecordStorageBase
|
||||||
|
from invokeai.app.services.images.images_base import ImageServiceABC
|
||||||
|
from invokeai.app.services.invocation_cache.invocation_cache_base import InvocationCacheBase
|
||||||
|
from invokeai.app.services.invocation_stats.invocation_stats_base import InvocationStatsServiceBase
|
||||||
|
from invokeai.app.services.model_images.model_images_base import ModelImageFileStorageBase
|
||||||
|
from invokeai.app.services.model_manager.model_manager_base import ModelManagerServiceBase
|
||||||
|
from invokeai.app.services.names.names_base import NameServiceBase
|
||||||
|
from invokeai.app.services.session_processor.session_processor_base import SessionProcessorBase
|
||||||
|
from invokeai.app.services.session_queue.session_queue_base import SessionQueueBase
|
||||||
|
from invokeai.app.services.urls.urls_base import UrlServiceBase
|
||||||
|
from invokeai.app.services.workflow_records.workflow_records_base import WorkflowRecordsStorageBase
|
||||||
from invokeai.backend.stable_diffusion.diffusion.conditioning_data import ConditioningFieldData
|
from invokeai.backend.stable_diffusion.diffusion.conditioning_data import ConditioningFieldData
|
||||||
|
|
||||||
from .board_image_records.board_image_records_base import BoardImageRecordStorageBase
|
|
||||||
from .board_images.board_images_base import BoardImagesServiceABC
|
|
||||||
from .board_records.board_records_base import BoardRecordStorageBase
|
|
||||||
from .boards.boards_base import BoardServiceABC
|
|
||||||
from .bulk_download.bulk_download_base import BulkDownloadBase
|
|
||||||
from .config import InvokeAIAppConfig
|
|
||||||
from .download import DownloadQueueServiceBase
|
|
||||||
from .events.events_base import EventServiceBase
|
|
||||||
from .image_files.image_files_base import ImageFileStorageBase
|
|
||||||
from .image_records.image_records_base import ImageRecordStorageBase
|
|
||||||
from .images.images_base import ImageServiceABC
|
|
||||||
from .invocation_cache.invocation_cache_base import InvocationCacheBase
|
|
||||||
from .invocation_stats.invocation_stats_base import InvocationStatsServiceBase
|
|
||||||
from .model_images.model_images_base import ModelImageFileStorageBase
|
|
||||||
from .model_manager.model_manager_base import ModelManagerServiceBase
|
|
||||||
from .names.names_base import NameServiceBase
|
|
||||||
from .session_processor.session_processor_base import SessionProcessorBase
|
|
||||||
from .session_queue.session_queue_base import SessionQueueBase
|
|
||||||
from .urls.urls_base import UrlServiceBase
|
|
||||||
from .workflow_records.workflow_records_base import WorkflowRecordsStorageBase
|
|
||||||
|
|
||||||
|
|
||||||
class InvocationServices:
|
class InvocationServices:
|
||||||
"""Services that can be used by invocations"""
|
"""Services that can be used by invocations"""
|
||||||
|
@ -9,11 +9,8 @@ import torch
|
|||||||
|
|
||||||
import invokeai.backend.util.logging as logger
|
import invokeai.backend.util.logging as logger
|
||||||
from invokeai.app.invocations.baseinvocation import BaseInvocation
|
from invokeai.app.invocations.baseinvocation import BaseInvocation
|
||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.invocation_stats.invocation_stats_base import InvocationStatsServiceBase
|
||||||
from invokeai.backend.model_manager.load.model_cache import CacheStats
|
from invokeai.app.services.invocation_stats.invocation_stats_common import (
|
||||||
|
|
||||||
from .invocation_stats_base import InvocationStatsServiceBase
|
|
||||||
from .invocation_stats_common import (
|
|
||||||
GESStatsNotFoundError,
|
GESStatsNotFoundError,
|
||||||
GraphExecutionStats,
|
GraphExecutionStats,
|
||||||
GraphExecutionStatsSummary,
|
GraphExecutionStatsSummary,
|
||||||
@ -22,6 +19,8 @@ from .invocation_stats_common import (
|
|||||||
NodeExecutionStats,
|
NodeExecutionStats,
|
||||||
NodeExecutionStatsSummary,
|
NodeExecutionStatsSummary,
|
||||||
)
|
)
|
||||||
|
from invokeai.app.services.invoker import Invoker
|
||||||
|
from invokeai.backend.model_manager.load.model_cache import CacheStats
|
||||||
|
|
||||||
# Size of 1GB in bytes.
|
# Size of 1GB in bytes.
|
||||||
GB = 2**30
|
GB = 2**30
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# Copyright (c) 2022 Kyle Schouviller (https://github.com/kyle0654)
|
# Copyright (c) 2022 Kyle Schouviller (https://github.com/kyle0654)
|
||||||
|
|
||||||
|
|
||||||
from .invocation_services import InvocationServices
|
from invokeai.app.services.invocation_services import InvocationServices
|
||||||
|
|
||||||
|
|
||||||
class Invoker:
|
class Invoker:
|
||||||
|
@ -5,15 +5,14 @@ from PIL.Image import Image as PILImageType
|
|||||||
from send2trash import send2trash
|
from send2trash import send2trash
|
||||||
|
|
||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.invoker import Invoker
|
||||||
from invokeai.app.util.misc import uuid_string
|
from invokeai.app.services.model_images.model_images_base import ModelImageFileStorageBase
|
||||||
from invokeai.app.util.thumbnails import make_thumbnail
|
from invokeai.app.services.model_images.model_images_common import (
|
||||||
|
|
||||||
from .model_images_base import ModelImageFileStorageBase
|
|
||||||
from .model_images_common import (
|
|
||||||
ModelImageFileDeleteException,
|
ModelImageFileDeleteException,
|
||||||
ModelImageFileNotFoundException,
|
ModelImageFileNotFoundException,
|
||||||
ModelImageFileSaveException,
|
ModelImageFileSaveException,
|
||||||
)
|
)
|
||||||
|
from invokeai.app.util.misc import uuid_string
|
||||||
|
from invokeai.app.util.thumbnails import make_thumbnail
|
||||||
|
|
||||||
|
|
||||||
class ModelImageFileStorageDisk(ModelImageFileStorageBase):
|
class ModelImageFileStorageDisk(ModelImageFileStorageBase):
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
"""Initialization file for model install service package."""
|
"""Initialization file for model install service package."""
|
||||||
|
|
||||||
from .model_install_base import (
|
from invokeai.app.services.model_install.model_install_base import ModelInstallServiceBase
|
||||||
ModelInstallServiceBase,
|
from invokeai.app.services.model_install.model_install_common import (
|
||||||
)
|
|
||||||
from .model_install_common import (
|
|
||||||
HFModelSource,
|
HFModelSource,
|
||||||
InstallStatus,
|
InstallStatus,
|
||||||
LocalModelSource,
|
LocalModelSource,
|
||||||
@ -12,7 +10,7 @@ from .model_install_common import (
|
|||||||
UnknownInstallJobException,
|
UnknownInstallJobException,
|
||||||
URLModelSource,
|
URLModelSource,
|
||||||
)
|
)
|
||||||
from .model_install_default import ModelInstallService
|
from invokeai.app.services.model_install.model_install_default import ModelInstallService
|
||||||
|
|
||||||
__all__ = [
|
__all__ = [
|
||||||
"ModelInstallServiceBase",
|
"ModelInstallServiceBase",
|
||||||
|
@ -23,6 +23,16 @@ from invokeai.app.services.download import DownloadQueueServiceBase, MultiFileDo
|
|||||||
from invokeai.app.services.events.events_base import EventServiceBase
|
from invokeai.app.services.events.events_base import EventServiceBase
|
||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.invoker import Invoker
|
||||||
from invokeai.app.services.model_install.model_install_base import ModelInstallServiceBase
|
from invokeai.app.services.model_install.model_install_base import ModelInstallServiceBase
|
||||||
|
from invokeai.app.services.model_install.model_install_common import (
|
||||||
|
MODEL_SOURCE_TO_TYPE_MAP,
|
||||||
|
HFModelSource,
|
||||||
|
InstallStatus,
|
||||||
|
LocalModelSource,
|
||||||
|
ModelInstallJob,
|
||||||
|
ModelSource,
|
||||||
|
StringLikeSource,
|
||||||
|
URLModelSource,
|
||||||
|
)
|
||||||
from invokeai.app.services.model_records import DuplicateModelException, ModelRecordServiceBase
|
from invokeai.app.services.model_records import DuplicateModelException, ModelRecordServiceBase
|
||||||
from invokeai.app.services.model_records.model_records_base import ModelRecordChanges
|
from invokeai.app.services.model_records.model_records_base import ModelRecordChanges
|
||||||
from invokeai.backend.model_manager.config import (
|
from invokeai.backend.model_manager.config import (
|
||||||
@ -47,17 +57,6 @@ from invokeai.backend.util.catch_sigint import catch_sigint
|
|||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
from invokeai.backend.util.util import slugify
|
from invokeai.backend.util.util import slugify
|
||||||
|
|
||||||
from .model_install_common import (
|
|
||||||
MODEL_SOURCE_TO_TYPE_MAP,
|
|
||||||
HFModelSource,
|
|
||||||
InstallStatus,
|
|
||||||
LocalModelSource,
|
|
||||||
ModelInstallJob,
|
|
||||||
ModelSource,
|
|
||||||
StringLikeSource,
|
|
||||||
URLModelSource,
|
|
||||||
)
|
|
||||||
|
|
||||||
TMPDIR_PREFIX = "tmpinstall_"
|
TMPDIR_PREFIX = "tmpinstall_"
|
||||||
|
|
||||||
|
|
||||||
@ -848,7 +847,7 @@ class ModelInstallService(ModelInstallServiceBase):
|
|||||||
with self._lock:
|
with self._lock:
|
||||||
if install_job := self._download_cache.pop(download_job.id, None):
|
if install_job := self._download_cache.pop(download_job.id, None):
|
||||||
assert excp is not None
|
assert excp is not None
|
||||||
install_job.set_error(excp)
|
self._set_error(install_job, excp)
|
||||||
self._download_queue.cancel_job(download_job)
|
self._download_queue.cancel_job(download_job)
|
||||||
|
|
||||||
# Let other threads know that the number of downloads has changed
|
# Let other threads know that the number of downloads has changed
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
"""Initialization file for model load service module."""
|
"""Initialization file for model load service module."""
|
||||||
|
|
||||||
from .model_load_base import ModelLoadServiceBase
|
from invokeai.app.services.model_load.model_load_base import ModelLoadServiceBase
|
||||||
from .model_load_default import ModelLoadService
|
from invokeai.app.services.model_load.model_load_default import ModelLoadService
|
||||||
|
|
||||||
__all__ = ["ModelLoadServiceBase", "ModelLoadService"]
|
__all__ = ["ModelLoadServiceBase", "ModelLoadService"]
|
||||||
|
@ -10,6 +10,7 @@ from torch import load as torch_load
|
|||||||
|
|
||||||
from invokeai.app.services.config import InvokeAIAppConfig
|
from invokeai.app.services.config import InvokeAIAppConfig
|
||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.invoker import Invoker
|
||||||
|
from invokeai.app.services.model_load.model_load_base import ModelLoadServiceBase
|
||||||
from invokeai.backend.model_manager import AnyModel, AnyModelConfig, SubModelType
|
from invokeai.backend.model_manager import AnyModel, AnyModelConfig, SubModelType
|
||||||
from invokeai.backend.model_manager.load import (
|
from invokeai.backend.model_manager.load import (
|
||||||
LoadedModel,
|
LoadedModel,
|
||||||
@ -22,8 +23,6 @@ from invokeai.backend.model_manager.load.model_loaders.generic_diffusers import
|
|||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
from invokeai.backend.util.logging import InvokeAILogger
|
from invokeai.backend.util.logging import InvokeAILogger
|
||||||
|
|
||||||
from .model_load_base import ModelLoadServiceBase
|
|
||||||
|
|
||||||
|
|
||||||
class ModelLoadService(ModelLoadServiceBase):
|
class ModelLoadService(ModelLoadServiceBase):
|
||||||
"""Wrapper around ModelLoaderRegistry."""
|
"""Wrapper around ModelLoaderRegistry."""
|
||||||
|
@ -1,10 +1,9 @@
|
|||||||
"""Initialization file for model manager service."""
|
"""Initialization file for model manager service."""
|
||||||
|
|
||||||
|
from invokeai.app.services.model_manager.model_manager_default import ModelManagerService, ModelManagerServiceBase
|
||||||
from invokeai.backend.model_manager import AnyModel, AnyModelConfig, BaseModelType, ModelType, SubModelType
|
from invokeai.backend.model_manager import AnyModel, AnyModelConfig, BaseModelType, ModelType, SubModelType
|
||||||
from invokeai.backend.model_manager.load import LoadedModel
|
from invokeai.backend.model_manager.load import LoadedModel
|
||||||
|
|
||||||
from .model_manager_default import ModelManagerService, ModelManagerServiceBase
|
|
||||||
|
|
||||||
__all__ = [
|
__all__ = [
|
||||||
"ModelManagerServiceBase",
|
"ModelManagerServiceBase",
|
||||||
"ModelManagerService",
|
"ModelManagerService",
|
||||||
|
@ -5,14 +5,13 @@ from abc import ABC, abstractmethod
|
|||||||
import torch
|
import torch
|
||||||
from typing_extensions import Self
|
from typing_extensions import Self
|
||||||
|
|
||||||
|
from invokeai.app.services.config.config_default import InvokeAIAppConfig
|
||||||
|
from invokeai.app.services.download.download_base import DownloadQueueServiceBase
|
||||||
|
from invokeai.app.services.events.events_base import EventServiceBase
|
||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.invoker import Invoker
|
||||||
|
from invokeai.app.services.model_install.model_install_base import ModelInstallServiceBase
|
||||||
from ..config import InvokeAIAppConfig
|
from invokeai.app.services.model_load.model_load_base import ModelLoadServiceBase
|
||||||
from ..download import DownloadQueueServiceBase
|
from invokeai.app.services.model_records.model_records_base import ModelRecordServiceBase
|
||||||
from ..events.events_base import EventServiceBase
|
|
||||||
from ..model_install import ModelInstallServiceBase
|
|
||||||
from ..model_load import ModelLoadServiceBase
|
|
||||||
from ..model_records import ModelRecordServiceBase
|
|
||||||
|
|
||||||
|
|
||||||
class ModelManagerServiceBase(ABC):
|
class ModelManagerServiceBase(ABC):
|
||||||
|
@ -6,19 +6,20 @@ from typing import Optional
|
|||||||
import torch
|
import torch
|
||||||
from typing_extensions import Self
|
from typing_extensions import Self
|
||||||
|
|
||||||
|
from invokeai.app.services.config.config_default import InvokeAIAppConfig
|
||||||
|
from invokeai.app.services.download.download_base import DownloadQueueServiceBase
|
||||||
|
from invokeai.app.services.events.events_base import EventServiceBase
|
||||||
from invokeai.app.services.invoker import Invoker
|
from invokeai.app.services.invoker import Invoker
|
||||||
|
from invokeai.app.services.model_install.model_install_base import ModelInstallServiceBase
|
||||||
|
from invokeai.app.services.model_install.model_install_default import ModelInstallService
|
||||||
|
from invokeai.app.services.model_load.model_load_base import ModelLoadServiceBase
|
||||||
|
from invokeai.app.services.model_load.model_load_default import ModelLoadService
|
||||||
|
from invokeai.app.services.model_manager.model_manager_base import ModelManagerServiceBase
|
||||||
|
from invokeai.app.services.model_records.model_records_base import ModelRecordServiceBase
|
||||||
from invokeai.backend.model_manager.load import ModelCache, ModelLoaderRegistry
|
from invokeai.backend.model_manager.load import ModelCache, ModelLoaderRegistry
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
from invokeai.backend.util.logging import InvokeAILogger
|
from invokeai.backend.util.logging import InvokeAILogger
|
||||||
|
|
||||||
from ..config import InvokeAIAppConfig
|
|
||||||
from ..download import DownloadQueueServiceBase
|
|
||||||
from ..events.events_base import EventServiceBase
|
|
||||||
from ..model_install import ModelInstallService, ModelInstallServiceBase
|
|
||||||
from ..model_load import ModelLoadService, ModelLoadServiceBase
|
|
||||||
from ..model_records import ModelRecordServiceBase
|
|
||||||
from .model_manager_base import ModelManagerServiceBase
|
|
||||||
|
|
||||||
|
|
||||||
class ModelManagerService(ModelManagerServiceBase):
|
class ModelManagerService(ModelManagerServiceBase):
|
||||||
"""
|
"""
|
||||||
|
@ -45,17 +45,7 @@ from math import ceil
|
|||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
from typing import List, Optional, Union
|
from typing import List, Optional, Union
|
||||||
|
|
||||||
from invokeai.app.services.shared.pagination import PaginatedResults
|
from invokeai.app.services.model_records.model_records_base import (
|
||||||
from invokeai.backend.model_manager.config import (
|
|
||||||
AnyModelConfig,
|
|
||||||
BaseModelType,
|
|
||||||
ModelConfigFactory,
|
|
||||||
ModelFormat,
|
|
||||||
ModelType,
|
|
||||||
)
|
|
||||||
|
|
||||||
from ..shared.sqlite.sqlite_database import SqliteDatabase
|
|
||||||
from .model_records_base import (
|
|
||||||
DuplicateModelException,
|
DuplicateModelException,
|
||||||
ModelRecordChanges,
|
ModelRecordChanges,
|
||||||
ModelRecordOrderBy,
|
ModelRecordOrderBy,
|
||||||
@ -63,6 +53,15 @@ from .model_records_base import (
|
|||||||
ModelSummary,
|
ModelSummary,
|
||||||
UnknownModelException,
|
UnknownModelException,
|
||||||
)
|
)
|
||||||
|
from invokeai.app.services.shared.pagination import PaginatedResults
|
||||||
|
from invokeai.app.services.shared.sqlite.sqlite_database import SqliteDatabase
|
||||||
|
from invokeai.backend.model_manager.config import (
|
||||||
|
AnyModelConfig,
|
||||||
|
BaseModelType,
|
||||||
|
ModelConfigFactory,
|
||||||
|
ModelFormat,
|
||||||
|
ModelType,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class ModelRecordServiceSQL(ModelRecordServiceBase):
|
class ModelRecordServiceSQL(ModelRecordServiceBase):
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
|
from invokeai.app.services.names.names_base import NameServiceBase
|
||||||
from invokeai.app.util.misc import uuid_string
|
from invokeai.app.util.misc import uuid_string
|
||||||
|
|
||||||
from .names_base import NameServiceBase
|
|
||||||
|
|
||||||
|
|
||||||
class SimpleNameService(NameServiceBase):
|
class SimpleNameService(NameServiceBase):
|
||||||
"""Creates image names from UUIDs."""
|
"""Creates image names from UUIDs."""
|
||||||
|
@ -13,24 +13,24 @@ from invokeai.app.services.events.events_common import (
|
|||||||
register_events,
|
register_events,
|
||||||
)
|
)
|
||||||
from invokeai.app.services.invocation_stats.invocation_stats_common import GESStatsNotFoundError
|
from invokeai.app.services.invocation_stats.invocation_stats_common import GESStatsNotFoundError
|
||||||
|
from invokeai.app.services.invoker import Invoker
|
||||||
from invokeai.app.services.session_processor.session_processor_base import (
|
from invokeai.app.services.session_processor.session_processor_base import (
|
||||||
|
InvocationServices,
|
||||||
OnAfterRunNode,
|
OnAfterRunNode,
|
||||||
OnAfterRunSession,
|
OnAfterRunSession,
|
||||||
OnBeforeRunNode,
|
OnBeforeRunNode,
|
||||||
OnBeforeRunSession,
|
OnBeforeRunSession,
|
||||||
OnNodeError,
|
OnNodeError,
|
||||||
OnNonFatalProcessorError,
|
OnNonFatalProcessorError,
|
||||||
|
SessionProcessorBase,
|
||||||
|
SessionRunnerBase,
|
||||||
)
|
)
|
||||||
from invokeai.app.services.session_processor.session_processor_common import CanceledException
|
from invokeai.app.services.session_processor.session_processor_common import CanceledException, SessionProcessorStatus
|
||||||
from invokeai.app.services.session_queue.session_queue_common import SessionQueueItem, SessionQueueItemNotFoundError
|
from invokeai.app.services.session_queue.session_queue_common import SessionQueueItem, SessionQueueItemNotFoundError
|
||||||
from invokeai.app.services.shared.graph import NodeInputError
|
from invokeai.app.services.shared.graph import NodeInputError
|
||||||
from invokeai.app.services.shared.invocation_context import InvocationContextData, build_invocation_context
|
from invokeai.app.services.shared.invocation_context import InvocationContextData, build_invocation_context
|
||||||
from invokeai.app.util.profiler import Profiler
|
from invokeai.app.util.profiler import Profiler
|
||||||
|
|
||||||
from ..invoker import Invoker
|
|
||||||
from .session_processor_base import InvocationServices, SessionProcessorBase, SessionRunnerBase
|
|
||||||
from .session_processor_common import SessionProcessorStatus
|
|
||||||
|
|
||||||
|
|
||||||
class DefaultSessionRunner(SessionRunnerBase):
|
class DefaultSessionRunner(SessionRunnerBase):
|
||||||
"""Processes a single session's invocations."""
|
"""Processes a single session's invocations."""
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import os
|
import os
|
||||||
|
|
||||||
from .urls_base import UrlServiceBase
|
from invokeai.app.services.urls.urls_base import UrlServiceBase
|
||||||
|
|
||||||
|
|
||||||
class LocalUrlService(UrlServiceBase):
|
class LocalUrlService(UrlServiceBase):
|
||||||
|
@ -5,9 +5,8 @@ from PIL import Image
|
|||||||
|
|
||||||
from invokeai.app.services.session_processor.session_processor_common import CanceledException, ProgressImage
|
from invokeai.app.services.session_processor.session_processor_common import CanceledException, ProgressImage
|
||||||
from invokeai.backend.model_manager.config import BaseModelType
|
from invokeai.backend.model_manager.config import BaseModelType
|
||||||
|
from invokeai.backend.stable_diffusion.diffusers_pipeline import PipelineIntermediateState
|
||||||
from ...backend.stable_diffusion import PipelineIntermediateState
|
from invokeai.backend.util.util import image_to_dataURL
|
||||||
from ...backend.util.util import image_to_dataURL
|
|
||||||
|
|
||||||
if TYPE_CHECKING:
|
if TYPE_CHECKING:
|
||||||
from invokeai.app.services.events.events_base import EventServiceBase
|
from invokeai.app.services.events.events_base import EventServiceBase
|
||||||
|
@ -2,6 +2,11 @@
|
|||||||
Initialization file for invokeai.backend.image_util methods.
|
Initialization file for invokeai.backend.image_util methods.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from .infill_methods.patchmatch import PatchMatch # noqa: F401
|
from invokeai.backend.image_util.infill_methods.patchmatch import PatchMatch # noqa: F401
|
||||||
from .pngwriter import PngWriter, PromptFormatter, retrieve_metadata, write_metadata # noqa: F401
|
from invokeai.backend.image_util.pngwriter import ( # noqa: F401
|
||||||
from .util import InitImageResizer, make_grid # noqa: F401
|
PngWriter,
|
||||||
|
PromptFormatter,
|
||||||
|
retrieve_metadata,
|
||||||
|
write_metadata,
|
||||||
|
)
|
||||||
|
from invokeai.backend.image_util.util import InitImageResizer, make_grid # noqa: F401
|
||||||
|
@ -2,7 +2,7 @@ import torch
|
|||||||
from torch import nn as nn
|
from torch import nn as nn
|
||||||
from torch.nn import functional as F
|
from torch.nn import functional as F
|
||||||
|
|
||||||
from .arch_util import default_init_weights, make_layer, pixel_unshuffle
|
from invokeai.backend.image_util.basicsr.arch_util import default_init_weights, make_layer, pixel_unshuffle
|
||||||
|
|
||||||
|
|
||||||
class ResidualDenseBlock(nn.Module):
|
class ResidualDenseBlock(nn.Module):
|
||||||
|
@ -4,7 +4,7 @@ import torch
|
|||||||
import torch.nn as nn
|
import torch.nn as nn
|
||||||
import torch.nn.functional as F
|
import torch.nn.functional as F
|
||||||
|
|
||||||
from .blocks import FeatureFusionBlock, _make_scratch
|
from invokeai.backend.image_util.depth_anything.model.blocks import FeatureFusionBlock, _make_scratch
|
||||||
|
|
||||||
torchhub_path = Path(__file__).parent.parent / "torchhub"
|
torchhub_path = Path(__file__).parent.parent / "torchhub"
|
||||||
|
|
||||||
|
@ -8,11 +8,10 @@ import numpy as np
|
|||||||
import onnxruntime as ort
|
import onnxruntime as ort
|
||||||
|
|
||||||
from invokeai.app.services.config.config_default import get_config
|
from invokeai.app.services.config.config_default import get_config
|
||||||
|
from invokeai.backend.image_util.dw_openpose.onnxdet import inference_detector
|
||||||
|
from invokeai.backend.image_util.dw_openpose.onnxpose import inference_pose
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
|
|
||||||
from .onnxdet import inference_detector
|
|
||||||
from .onnxpose import inference_pose
|
|
||||||
|
|
||||||
config = get_config()
|
config = get_config()
|
||||||
|
|
||||||
|
|
||||||
|
@ -11,9 +11,8 @@ from PIL import Image
|
|||||||
from transformers import CLIPImageProcessor, CLIPVisionModelWithProjection
|
from transformers import CLIPImageProcessor, CLIPVisionModelWithProjection
|
||||||
|
|
||||||
from invokeai.backend.ip_adapter.ip_attention_weights import IPAttentionWeights
|
from invokeai.backend.ip_adapter.ip_attention_weights import IPAttentionWeights
|
||||||
|
from invokeai.backend.ip_adapter.resampler import Resampler
|
||||||
from ..raw_model import RawModel
|
from invokeai.backend.raw_model import RawModel
|
||||||
from .resampler import Resampler
|
|
||||||
|
|
||||||
|
|
||||||
class IPAdapterStateDict(TypedDict):
|
class IPAdapterStateDict(TypedDict):
|
||||||
@ -136,11 +135,11 @@ class IPAdapter(RawModel):
|
|||||||
self._image_proj_model.to(device=self.device, dtype=self.dtype, non_blocking=non_blocking)
|
self._image_proj_model.to(device=self.device, dtype=self.dtype, non_blocking=non_blocking)
|
||||||
self.attn_weights.to(device=self.device, dtype=self.dtype, non_blocking=non_blocking)
|
self.attn_weights.to(device=self.device, dtype=self.dtype, non_blocking=non_blocking)
|
||||||
|
|
||||||
def calc_size(self):
|
def calc_size(self) -> int:
|
||||||
# workaround for circular import
|
# HACK(ryand): Fix this issue with circular imports.
|
||||||
from invokeai.backend.model_manager.load.model_util import calc_model_size_by_data
|
from invokeai.backend.model_manager.load.model_util import calc_module_size
|
||||||
|
|
||||||
return calc_model_size_by_data(self._image_proj_model) + calc_model_size_by_data(self.attn_weights)
|
return calc_module_size(self._image_proj_model) + calc_module_size(self.attn_weights)
|
||||||
|
|
||||||
def _init_image_proj_model(
|
def _init_image_proj_model(
|
||||||
self, state_dict: dict[str, torch.Tensor]
|
self, state_dict: dict[str, torch.Tensor]
|
||||||
|
@ -10,10 +10,9 @@ from safetensors.torch import load_file
|
|||||||
from typing_extensions import Self
|
from typing_extensions import Self
|
||||||
|
|
||||||
from invokeai.backend.model_manager import BaseModelType
|
from invokeai.backend.model_manager import BaseModelType
|
||||||
|
from invokeai.backend.raw_model import RawModel
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
|
|
||||||
from .raw_model import RawModel
|
|
||||||
|
|
||||||
|
|
||||||
class LoRALayerBase:
|
class LoRALayerBase:
|
||||||
# rank: Optional[int]
|
# rank: Optional[int]
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
"""Re-export frequently-used symbols from the Model Manager backend."""
|
"""Re-export frequently-used symbols from the Model Manager backend."""
|
||||||
|
|
||||||
from .config import (
|
from invokeai.backend.model_manager.config import (
|
||||||
AnyModel,
|
AnyModel,
|
||||||
AnyModelConfig,
|
AnyModelConfig,
|
||||||
BaseModelType,
|
BaseModelType,
|
||||||
@ -13,9 +13,9 @@ from .config import (
|
|||||||
SchedulerPredictionType,
|
SchedulerPredictionType,
|
||||||
SubModelType,
|
SubModelType,
|
||||||
)
|
)
|
||||||
from .load import LoadedModel
|
from invokeai.backend.model_manager.load import LoadedModel
|
||||||
from .probe import ModelProbe
|
from invokeai.backend.model_manager.probe import ModelProbe
|
||||||
from .search import ModelSearch
|
from invokeai.backend.model_manager.search import ModelSearch
|
||||||
|
|
||||||
__all__ = [
|
__all__ = [
|
||||||
"AnyModel",
|
"AnyModel",
|
||||||
|
@ -30,11 +30,10 @@ from diffusers.models.modeling_utils import ModelMixin
|
|||||||
from pydantic import BaseModel, ConfigDict, Discriminator, Field, Tag, TypeAdapter
|
from pydantic import BaseModel, ConfigDict, Discriminator, Field, Tag, TypeAdapter
|
||||||
from typing_extensions import Annotated, Any, Dict
|
from typing_extensions import Annotated, Any, Dict
|
||||||
|
|
||||||
from invokeai.app.invocations.constants import SCHEDULER_NAME_VALUES
|
|
||||||
from invokeai.app.util.misc import uuid_string
|
from invokeai.app.util.misc import uuid_string
|
||||||
from invokeai.backend.model_hash.hash_validator import validate_hash
|
from invokeai.backend.model_hash.hash_validator import validate_hash
|
||||||
|
from invokeai.backend.raw_model import RawModel
|
||||||
from ..raw_model import RawModel
|
from invokeai.backend.stable_diffusion.schedulers.schedulers import SCHEDULER_NAME_VALUES
|
||||||
|
|
||||||
# ModelMixin is the base class for all diffusers and transformers models
|
# ModelMixin is the base class for all diffusers and transformers models
|
||||||
# RawModel is the InvokeAI wrapper class for ip_adapters, loras, textual_inversion and onnx runtime
|
# RawModel is the InvokeAI wrapper class for ip_adapters, loras, textual_inversion and onnx runtime
|
||||||
|
@ -1,75 +0,0 @@
|
|||||||
import ctypes
|
|
||||||
|
|
||||||
|
|
||||||
class Struct_mallinfo2(ctypes.Structure):
|
|
||||||
"""A ctypes Structure that matches the libc mallinfo2 struct.
|
|
||||||
|
|
||||||
Docs:
|
|
||||||
- https://man7.org/linux/man-pages/man3/mallinfo.3.html
|
|
||||||
- https://www.gnu.org/software/libc/manual/html_node/Statistics-of-Malloc.html
|
|
||||||
|
|
||||||
struct mallinfo2 {
|
|
||||||
size_t arena; /* Non-mmapped space allocated (bytes) */
|
|
||||||
size_t ordblks; /* Number of free chunks */
|
|
||||||
size_t smblks; /* Number of free fastbin blocks */
|
|
||||||
size_t hblks; /* Number of mmapped regions */
|
|
||||||
size_t hblkhd; /* Space allocated in mmapped regions (bytes) */
|
|
||||||
size_t usmblks; /* See below */
|
|
||||||
size_t fsmblks; /* Space in freed fastbin blocks (bytes) */
|
|
||||||
size_t uordblks; /* Total allocated space (bytes) */
|
|
||||||
size_t fordblks; /* Total free space (bytes) */
|
|
||||||
size_t keepcost; /* Top-most, releasable space (bytes) */
|
|
||||||
};
|
|
||||||
"""
|
|
||||||
|
|
||||||
_fields_ = [
|
|
||||||
("arena", ctypes.c_size_t),
|
|
||||||
("ordblks", ctypes.c_size_t),
|
|
||||||
("smblks", ctypes.c_size_t),
|
|
||||||
("hblks", ctypes.c_size_t),
|
|
||||||
("hblkhd", ctypes.c_size_t),
|
|
||||||
("usmblks", ctypes.c_size_t),
|
|
||||||
("fsmblks", ctypes.c_size_t),
|
|
||||||
("uordblks", ctypes.c_size_t),
|
|
||||||
("fordblks", ctypes.c_size_t),
|
|
||||||
("keepcost", ctypes.c_size_t),
|
|
||||||
]
|
|
||||||
|
|
||||||
def __str__(self):
|
|
||||||
s = ""
|
|
||||||
s += f"{'arena': <10}= {(self.arena/2**30):15.5f} # Non-mmapped space allocated (GB) (uordblks + fordblks)\n"
|
|
||||||
s += f"{'ordblks': <10}= {(self.ordblks): >15} # Number of free chunks\n"
|
|
||||||
s += f"{'smblks': <10}= {(self.smblks): >15} # Number of free fastbin blocks \n"
|
|
||||||
s += f"{'hblks': <10}= {(self.hblks): >15} # Number of mmapped regions \n"
|
|
||||||
s += f"{'hblkhd': <10}= {(self.hblkhd/2**30):15.5f} # Space allocated in mmapped regions (GB)\n"
|
|
||||||
s += f"{'usmblks': <10}= {(self.usmblks): >15} # Unused\n"
|
|
||||||
s += f"{'fsmblks': <10}= {(self.fsmblks/2**30):15.5f} # Space in freed fastbin blocks (GB)\n"
|
|
||||||
s += (
|
|
||||||
f"{'uordblks': <10}= {(self.uordblks/2**30):15.5f} # Space used by in-use allocations (non-mmapped)"
|
|
||||||
" (GB)\n"
|
|
||||||
)
|
|
||||||
s += f"{'fordblks': <10}= {(self.fordblks/2**30):15.5f} # Space in free blocks (non-mmapped) (GB)\n"
|
|
||||||
s += f"{'keepcost': <10}= {(self.keepcost/2**30):15.5f} # Top-most, releasable space (GB)\n"
|
|
||||||
return s
|
|
||||||
|
|
||||||
|
|
||||||
class LibcUtil:
|
|
||||||
"""A utility class for interacting with the C Standard Library (`libc`) via ctypes.
|
|
||||||
|
|
||||||
Note that this class will raise on __init__() if 'libc.so.6' can't be found. Take care to handle environments where
|
|
||||||
this shared library is not available.
|
|
||||||
|
|
||||||
TODO: Improve cross-OS compatibility of this class.
|
|
||||||
"""
|
|
||||||
|
|
||||||
def __init__(self):
|
|
||||||
self._libc = ctypes.cdll.LoadLibrary("libc.so.6")
|
|
||||||
|
|
||||||
def mallinfo2(self) -> Struct_mallinfo2:
|
|
||||||
"""Calls `libc` `mallinfo2`.
|
|
||||||
|
|
||||||
Docs: https://man7.org/linux/man-pages/man3/mallinfo.3.html
|
|
||||||
"""
|
|
||||||
mallinfo2 = self._libc.mallinfo2
|
|
||||||
mallinfo2.restype = Struct_mallinfo2
|
|
||||||
return mallinfo2()
|
|
@ -6,10 +6,10 @@ Init file for the model loader.
|
|||||||
from importlib import import_module
|
from importlib import import_module
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
|
||||||
from .load_base import LoadedModel, LoadedModelWithoutConfig, ModelLoaderBase
|
from invokeai.backend.model_manager.load.load_base import LoadedModel, LoadedModelWithoutConfig, ModelLoaderBase
|
||||||
from .load_default import ModelLoader
|
from invokeai.backend.model_manager.load.load_default import ModelLoader
|
||||||
from .model_cache.model_cache_default import ModelCache
|
from invokeai.backend.model_manager.load.model_cache.model_cache_default import ModelCache
|
||||||
from .model_loader_registry import ModelLoaderRegistry, ModelLoaderRegistryBase
|
from invokeai.backend.model_manager.load.model_loader_registry import ModelLoaderRegistry, ModelLoaderRegistryBase
|
||||||
|
|
||||||
# This registers the subclasses that implement loaders of specific model types
|
# This registers the subclasses that implement loaders of specific model types
|
||||||
loaders = [x.stem for x in Path(Path(__file__).parent, "model_loaders").glob("*.py") if x.stem != "__init__"]
|
loaders = [x.stem for x in Path(Path(__file__).parent, "model_loaders").glob("*.py") if x.stem != "__init__"]
|
||||||
|
@ -5,7 +5,7 @@ import psutil
|
|||||||
import torch
|
import torch
|
||||||
from typing_extensions import Self
|
from typing_extensions import Self
|
||||||
|
|
||||||
from ..util.libc_util import LibcUtil, Struct_mallinfo2
|
from invokeai.backend.model_manager.util.libc_util import LibcUtil, Struct_mallinfo2
|
||||||
|
|
||||||
GB = 2**30 # 1 GB
|
GB = 2**30 # 1 GB
|
||||||
|
|
||||||
|
@ -29,13 +29,17 @@ import torch
|
|||||||
|
|
||||||
from invokeai.backend.model_manager import AnyModel, SubModelType
|
from invokeai.backend.model_manager import AnyModel, SubModelType
|
||||||
from invokeai.backend.model_manager.load.memory_snapshot import MemorySnapshot, get_pretty_snapshot_diff
|
from invokeai.backend.model_manager.load.memory_snapshot import MemorySnapshot, get_pretty_snapshot_diff
|
||||||
|
from invokeai.backend.model_manager.load.model_cache.model_cache_base import (
|
||||||
|
CacheRecord,
|
||||||
|
CacheStats,
|
||||||
|
ModelCacheBase,
|
||||||
|
ModelLockerBase,
|
||||||
|
)
|
||||||
|
from invokeai.backend.model_manager.load.model_cache.model_locker import ModelLocker
|
||||||
from invokeai.backend.model_manager.load.model_util import calc_model_size_by_data
|
from invokeai.backend.model_manager.load.model_util import calc_model_size_by_data
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
from invokeai.backend.util.logging import InvokeAILogger
|
from invokeai.backend.util.logging import InvokeAILogger
|
||||||
|
|
||||||
from .model_cache_base import CacheRecord, CacheStats, ModelCacheBase, ModelLockerBase
|
|
||||||
from .model_locker import ModelLocker
|
|
||||||
|
|
||||||
# Maximum size of the cache, in gigs
|
# Maximum size of the cache, in gigs
|
||||||
# Default is roughly enough to hold three fp16 diffusers models in RAM simultaneously
|
# Default is roughly enough to hold three fp16 diffusers models in RAM simultaneously
|
||||||
DEFAULT_MAX_CACHE_SIZE = 6.0
|
DEFAULT_MAX_CACHE_SIZE = 6.0
|
||||||
@ -160,7 +164,7 @@ class ModelCache(ModelCacheBase[AnyModel]):
|
|||||||
key = self._make_cache_key(key, submodel_type)
|
key = self._make_cache_key(key, submodel_type)
|
||||||
if key in self._cached_models:
|
if key in self._cached_models:
|
||||||
return
|
return
|
||||||
size = calc_model_size_by_data(model)
|
size = calc_model_size_by_data(self.logger, model)
|
||||||
self.make_room(size)
|
self.make_room(size)
|
||||||
|
|
||||||
state_dict = model.state_dict() if isinstance(model, torch.nn.Module) else None
|
state_dict = model.state_dict() if isinstance(model, torch.nn.Module) else None
|
||||||
|
@ -7,8 +7,11 @@ from typing import Dict, Optional
|
|||||||
import torch
|
import torch
|
||||||
|
|
||||||
from invokeai.backend.model_manager import AnyModel
|
from invokeai.backend.model_manager import AnyModel
|
||||||
|
from invokeai.backend.model_manager.load.model_cache.model_cache_base import (
|
||||||
from .model_cache_base import CacheRecord, ModelCacheBase, ModelLockerBase
|
CacheRecord,
|
||||||
|
ModelCacheBase,
|
||||||
|
ModelLockerBase,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class ModelLocker(ModelLockerBase):
|
class ModelLocker(ModelLockerBase):
|
||||||
|
@ -18,7 +18,7 @@ Use like this:
|
|||||||
from abc import ABC, abstractmethod
|
from abc import ABC, abstractmethod
|
||||||
from typing import Callable, Dict, Optional, Tuple, Type, TypeVar
|
from typing import Callable, Dict, Optional, Tuple, Type, TypeVar
|
||||||
|
|
||||||
from ..config import (
|
from invokeai.backend.model_manager.config import (
|
||||||
AnyModelConfig,
|
AnyModelConfig,
|
||||||
BaseModelType,
|
BaseModelType,
|
||||||
ModelConfigBase,
|
ModelConfigBase,
|
||||||
@ -26,7 +26,7 @@ from ..config import (
|
|||||||
ModelType,
|
ModelType,
|
||||||
SubModelType,
|
SubModelType,
|
||||||
)
|
)
|
||||||
from . import ModelLoaderBase
|
from invokeai.backend.model_manager.load import ModelLoaderBase
|
||||||
|
|
||||||
|
|
||||||
class ModelLoaderRegistryBase(ABC):
|
class ModelLoaderRegistryBase(ABC):
|
||||||
|
@ -13,9 +13,8 @@ from invokeai.backend.model_manager import (
|
|||||||
ModelType,
|
ModelType,
|
||||||
)
|
)
|
||||||
from invokeai.backend.model_manager.config import ControlNetCheckpointConfig, SubModelType
|
from invokeai.backend.model_manager.config import ControlNetCheckpointConfig, SubModelType
|
||||||
|
from invokeai.backend.model_manager.load.model_loader_registry import ModelLoaderRegistry
|
||||||
from .. import ModelLoaderRegistry
|
from invokeai.backend.model_manager.load.model_loaders.generic_diffusers import GenericDiffusersLoader
|
||||||
from .generic_diffusers import GenericDiffusersLoader
|
|
||||||
|
|
||||||
|
|
||||||
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.ControlNet, format=ModelFormat.Diffusers)
|
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.ControlNet, format=ModelFormat.Diffusers)
|
||||||
|
@ -18,8 +18,8 @@ from invokeai.backend.model_manager import (
|
|||||||
SubModelType,
|
SubModelType,
|
||||||
)
|
)
|
||||||
from invokeai.backend.model_manager.config import DiffusersConfigBase
|
from invokeai.backend.model_manager.config import DiffusersConfigBase
|
||||||
|
from invokeai.backend.model_manager.load.load_default import ModelLoader
|
||||||
from .. import ModelLoader, ModelLoaderRegistry
|
from invokeai.backend.model_manager.load.model_loader_registry import ModelLoaderRegistry
|
||||||
|
|
||||||
|
|
||||||
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.CLIPVision, format=ModelFormat.Diffusers)
|
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.CLIPVision, format=ModelFormat.Diffusers)
|
||||||
|
@ -15,9 +15,9 @@ from invokeai.backend.model_manager import (
|
|||||||
ModelType,
|
ModelType,
|
||||||
SubModelType,
|
SubModelType,
|
||||||
)
|
)
|
||||||
|
from invokeai.backend.model_manager.load.load_default import ModelLoader
|
||||||
from invokeai.backend.model_manager.load.model_cache.model_cache_base import ModelCacheBase
|
from invokeai.backend.model_manager.load.model_cache.model_cache_base import ModelCacheBase
|
||||||
|
from invokeai.backend.model_manager.load.model_loader_registry import ModelLoaderRegistry
|
||||||
from .. import ModelLoader, ModelLoaderRegistry
|
|
||||||
|
|
||||||
|
|
||||||
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.LoRA, format=ModelFormat.Diffusers)
|
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.LoRA, format=ModelFormat.Diffusers)
|
||||||
|
@ -13,9 +13,8 @@ from invokeai.backend.model_manager import (
|
|||||||
ModelType,
|
ModelType,
|
||||||
SubModelType,
|
SubModelType,
|
||||||
)
|
)
|
||||||
|
from invokeai.backend.model_manager.load.model_loader_registry import ModelLoaderRegistry
|
||||||
from .. import ModelLoaderRegistry
|
from invokeai.backend.model_manager.load.model_loaders.generic_diffusers import GenericDiffusersLoader
|
||||||
from .generic_diffusers import GenericDiffusersLoader
|
|
||||||
|
|
||||||
|
|
||||||
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.ONNX, format=ModelFormat.ONNX)
|
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.ONNX, format=ModelFormat.ONNX)
|
||||||
|
@ -25,11 +25,10 @@ from invokeai.backend.model_manager.config import (
|
|||||||
DiffusersConfigBase,
|
DiffusersConfigBase,
|
||||||
MainCheckpointConfig,
|
MainCheckpointConfig,
|
||||||
)
|
)
|
||||||
|
from invokeai.backend.model_manager.load.model_loader_registry import ModelLoaderRegistry
|
||||||
|
from invokeai.backend.model_manager.load.model_loaders.generic_diffusers import GenericDiffusersLoader
|
||||||
from invokeai.backend.util.silence_warnings import SilenceWarnings
|
from invokeai.backend.util.silence_warnings import SilenceWarnings
|
||||||
|
|
||||||
from .. import ModelLoaderRegistry
|
|
||||||
from .generic_diffusers import GenericDiffusersLoader
|
|
||||||
|
|
||||||
VARIANT_TO_IN_CHANNEL_MAP = {
|
VARIANT_TO_IN_CHANNEL_MAP = {
|
||||||
ModelVariantType.Normal: 4,
|
ModelVariantType.Normal: 4,
|
||||||
ModelVariantType.Depth: 5,
|
ModelVariantType.Depth: 5,
|
||||||
|
@ -12,10 +12,10 @@ from invokeai.backend.model_manager import (
|
|||||||
ModelType,
|
ModelType,
|
||||||
SubModelType,
|
SubModelType,
|
||||||
)
|
)
|
||||||
|
from invokeai.backend.model_manager.load.load_default import ModelLoader
|
||||||
|
from invokeai.backend.model_manager.load.model_loader_registry import ModelLoaderRegistry
|
||||||
from invokeai.backend.textual_inversion import TextualInversionModelRaw
|
from invokeai.backend.textual_inversion import TextualInversionModelRaw
|
||||||
|
|
||||||
from .. import ModelLoader, ModelLoaderRegistry
|
|
||||||
|
|
||||||
|
|
||||||
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.TextualInversion, format=ModelFormat.EmbeddingFile)
|
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.TextualInversion, format=ModelFormat.EmbeddingFile)
|
||||||
@ModelLoaderRegistry.register(
|
@ModelLoaderRegistry.register(
|
||||||
|
@ -12,9 +12,8 @@ from invokeai.backend.model_manager import (
|
|||||||
ModelType,
|
ModelType,
|
||||||
)
|
)
|
||||||
from invokeai.backend.model_manager.config import AnyModel, SubModelType, VAECheckpointConfig
|
from invokeai.backend.model_manager.config import AnyModel, SubModelType, VAECheckpointConfig
|
||||||
|
from invokeai.backend.model_manager.load.model_loader_registry import ModelLoaderRegistry
|
||||||
from .. import ModelLoaderRegistry
|
from invokeai.backend.model_manager.load.model_loaders.generic_diffusers import GenericDiffusersLoader
|
||||||
from .generic_diffusers import GenericDiffusersLoader
|
|
||||||
|
|
||||||
|
|
||||||
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.VAE, format=ModelFormat.Diffusers)
|
@ModelLoaderRegistry.register(base=BaseModelType.Any, type=ModelType.VAE, format=ModelFormat.Diffusers)
|
||||||
|
@ -2,25 +2,46 @@
|
|||||||
"""Various utility functions needed by the loader and caching system."""
|
"""Various utility functions needed by the loader and caching system."""
|
||||||
|
|
||||||
import json
|
import json
|
||||||
|
import logging
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
from typing import Optional
|
from typing import Optional
|
||||||
|
|
||||||
import torch
|
import torch
|
||||||
from diffusers import DiffusionPipeline
|
from diffusers.pipelines.pipeline_utils import DiffusionPipeline
|
||||||
|
from diffusers.schedulers.scheduling_utils import SchedulerMixin
|
||||||
|
from transformers import CLIPTokenizer
|
||||||
|
|
||||||
|
from invokeai.backend.ip_adapter.ip_adapter import IPAdapter
|
||||||
|
from invokeai.backend.lora import LoRAModelRaw
|
||||||
from invokeai.backend.model_manager.config import AnyModel
|
from invokeai.backend.model_manager.config import AnyModel
|
||||||
from invokeai.backend.onnx.onnx_runtime import IAIOnnxRuntimeModel
|
from invokeai.backend.onnx.onnx_runtime import IAIOnnxRuntimeModel
|
||||||
|
from invokeai.backend.textual_inversion import TextualInversionModelRaw
|
||||||
|
|
||||||
|
|
||||||
def calc_model_size_by_data(model: AnyModel) -> int:
|
def calc_model_size_by_data(logger: logging.Logger, model: AnyModel) -> int:
|
||||||
"""Get size of a model in memory in bytes."""
|
"""Get size of a model in memory in bytes."""
|
||||||
|
# TODO(ryand): We should create a CacheableModel interface for all models, and move the size calculations down to
|
||||||
|
# the models themselves.
|
||||||
if isinstance(model, DiffusionPipeline):
|
if isinstance(model, DiffusionPipeline):
|
||||||
return _calc_pipeline_by_data(model)
|
return _calc_pipeline_by_data(model)
|
||||||
elif isinstance(model, torch.nn.Module):
|
elif isinstance(model, torch.nn.Module):
|
||||||
return _calc_model_by_data(model)
|
return calc_module_size(model)
|
||||||
elif isinstance(model, IAIOnnxRuntimeModel):
|
elif isinstance(model, IAIOnnxRuntimeModel):
|
||||||
return _calc_onnx_model_by_data(model)
|
return _calc_onnx_model_by_data(model)
|
||||||
|
elif isinstance(model, SchedulerMixin):
|
||||||
|
return 0
|
||||||
|
elif isinstance(model, CLIPTokenizer):
|
||||||
|
# TODO(ryand): Accurately calculate the tokenizer's size. It's small enough that it shouldn't matter for now.
|
||||||
|
return 0
|
||||||
|
elif isinstance(model, (TextualInversionModelRaw, IPAdapter, LoRAModelRaw)):
|
||||||
|
return model.calc_size()
|
||||||
else:
|
else:
|
||||||
|
# TODO(ryand): Promote this from a log to an exception once we are confident that we are handling all of the
|
||||||
|
# supported model types.
|
||||||
|
logger.error(
|
||||||
|
f"Failed to calculate model size for unexpected model type: {type(model)}. The model will be treated as "
|
||||||
|
"having size 0."
|
||||||
|
)
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
|
|
||||||
@ -30,11 +51,12 @@ def _calc_pipeline_by_data(pipeline: DiffusionPipeline) -> int:
|
|||||||
for submodel_key in pipeline.components.keys():
|
for submodel_key in pipeline.components.keys():
|
||||||
submodel = getattr(pipeline, submodel_key)
|
submodel = getattr(pipeline, submodel_key)
|
||||||
if submodel is not None and isinstance(submodel, torch.nn.Module):
|
if submodel is not None and isinstance(submodel, torch.nn.Module):
|
||||||
res += _calc_model_by_data(submodel)
|
res += calc_module_size(submodel)
|
||||||
return res
|
return res
|
||||||
|
|
||||||
|
|
||||||
def _calc_model_by_data(model: torch.nn.Module) -> int:
|
def calc_module_size(model: torch.nn.Module) -> int:
|
||||||
|
"""Calculate the size (in bytes) of a torch.nn.Module."""
|
||||||
mem_params = sum([param.nelement() * param.element_size() for param in model.parameters()])
|
mem_params = sum([param.nelement() * param.element_size() for param in model.parameters()])
|
||||||
mem_bufs = sum([buf.nelement() * buf.element_size() for buf in model.buffers()])
|
mem_bufs = sum([buf.nelement() * buf.element_size() for buf in model.buffers()])
|
||||||
mem: int = mem_params + mem_bufs # in bytes
|
mem: int = mem_params + mem_bufs # in bytes
|
||||||
|
@ -17,16 +17,10 @@ from diffusers.utils import logging as dlogging
|
|||||||
|
|
||||||
from invokeai.app.services.model_install import ModelInstallServiceBase
|
from invokeai.app.services.model_install import ModelInstallServiceBase
|
||||||
from invokeai.app.services.model_records.model_records_base import ModelRecordChanges
|
from invokeai.app.services.model_records.model_records_base import ModelRecordChanges
|
||||||
|
from invokeai.backend.model_manager import AnyModelConfig, BaseModelType, ModelType, ModelVariantType
|
||||||
|
from invokeai.backend.model_manager.config import MainDiffusersConfig
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
|
|
||||||
from . import (
|
|
||||||
AnyModelConfig,
|
|
||||||
BaseModelType,
|
|
||||||
ModelType,
|
|
||||||
ModelVariantType,
|
|
||||||
)
|
|
||||||
from .config import MainDiffusersConfig
|
|
||||||
|
|
||||||
|
|
||||||
class MergeInterpolationMethod(str, Enum):
|
class MergeInterpolationMethod(str, Enum):
|
||||||
WeightedSum = "weighted_sum"
|
WeightedSum = "weighted_sum"
|
||||||
|
@ -16,8 +16,8 @@ data = HuggingFaceMetadataFetch().from_id("<REPO_ID>")
|
|||||||
assert isinstance(data, HuggingFaceMetadata)
|
assert isinstance(data, HuggingFaceMetadata)
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from .fetch import HuggingFaceMetadataFetch, ModelMetadataFetchBase
|
from invokeai.backend.model_manager.metadata.fetch import HuggingFaceMetadataFetch, ModelMetadataFetchBase
|
||||||
from .metadata_base import (
|
from invokeai.backend.model_manager.metadata.metadata_base import (
|
||||||
AnyModelRepoMetadata,
|
AnyModelRepoMetadata,
|
||||||
AnyModelRepoMetadataValidator,
|
AnyModelRepoMetadataValidator,
|
||||||
BaseMetadata,
|
BaseMetadata,
|
||||||
|
@ -10,7 +10,7 @@ data = HuggingFaceMetadataFetch().from_id("<repo_id>")
|
|||||||
assert isinstance(data, HuggingFaceMetadata)
|
assert isinstance(data, HuggingFaceMetadata)
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from .fetch_base import ModelMetadataFetchBase
|
from invokeai.backend.model_manager.metadata.fetch.fetch_base import ModelMetadataFetchBase
|
||||||
from .huggingface import HuggingFaceMetadataFetch
|
from invokeai.backend.model_manager.metadata.fetch.huggingface import HuggingFaceMetadataFetch
|
||||||
|
|
||||||
__all__ = ["ModelMetadataFetchBase", "HuggingFaceMetadataFetch"]
|
__all__ = ["ModelMetadataFetchBase", "HuggingFaceMetadataFetch"]
|
||||||
|
@ -18,8 +18,11 @@ from pydantic.networks import AnyHttpUrl
|
|||||||
from requests.sessions import Session
|
from requests.sessions import Session
|
||||||
|
|
||||||
from invokeai.backend.model_manager import ModelRepoVariant
|
from invokeai.backend.model_manager import ModelRepoVariant
|
||||||
|
from invokeai.backend.model_manager.metadata.metadata_base import (
|
||||||
from ..metadata_base import AnyModelRepoMetadata, AnyModelRepoMetadataValidator, BaseMetadata
|
AnyModelRepoMetadata,
|
||||||
|
AnyModelRepoMetadataValidator,
|
||||||
|
BaseMetadata,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class ModelMetadataFetchBase(ABC):
|
class ModelMetadataFetchBase(ABC):
|
||||||
|
@ -25,14 +25,13 @@ from pydantic.networks import AnyHttpUrl
|
|||||||
from requests.sessions import Session
|
from requests.sessions import Session
|
||||||
|
|
||||||
from invokeai.backend.model_manager.config import ModelRepoVariant
|
from invokeai.backend.model_manager.config import ModelRepoVariant
|
||||||
|
from invokeai.backend.model_manager.metadata.fetch.fetch_base import ModelMetadataFetchBase
|
||||||
from ..metadata_base import (
|
from invokeai.backend.model_manager.metadata.metadata_base import (
|
||||||
AnyModelRepoMetadata,
|
AnyModelRepoMetadata,
|
||||||
HuggingFaceMetadata,
|
HuggingFaceMetadata,
|
||||||
RemoteModelFile,
|
RemoteModelFile,
|
||||||
UnknownMetadataException,
|
UnknownMetadataException,
|
||||||
)
|
)
|
||||||
from .fetch_base import ModelMetadataFetchBase
|
|
||||||
|
|
||||||
HF_MODEL_RE = r"https?://huggingface.co/([\w\-.]+/[\w\-.]+)"
|
HF_MODEL_RE = r"https?://huggingface.co/([\w\-.]+/[\w\-.]+)"
|
||||||
|
|
||||||
|
@ -24,8 +24,7 @@ from requests.sessions import Session
|
|||||||
from typing_extensions import Annotated
|
from typing_extensions import Annotated
|
||||||
|
|
||||||
from invokeai.backend.model_manager import ModelRepoVariant
|
from invokeai.backend.model_manager import ModelRepoVariant
|
||||||
|
from invokeai.backend.model_manager.util.select_hf_files import filter_files
|
||||||
from ..util import select_hf_files
|
|
||||||
|
|
||||||
|
|
||||||
class UnknownMetadataException(Exception):
|
class UnknownMetadataException(Exception):
|
||||||
@ -112,9 +111,7 @@ class HuggingFaceMetadata(ModelMetadataWithFiles):
|
|||||||
session = session or Session()
|
session = session or Session()
|
||||||
configure_http_backend(backend_factory=lambda: session) # used in testing
|
configure_http_backend(backend_factory=lambda: session) # used in testing
|
||||||
|
|
||||||
paths = select_hf_files.filter_files(
|
paths = filter_files([x.path for x in self.files], variant, subfolder) # all files in the model
|
||||||
[x.path for x in self.files], variant, subfolder
|
|
||||||
) # all files in the model
|
|
||||||
prefix = f"{subfolder}/" if subfolder else ""
|
prefix = f"{subfolder}/" if subfolder else ""
|
||||||
# the next step reads model_index.json to determine which subdirectories belong
|
# the next step reads model_index.json to determine which subdirectories belong
|
||||||
# to the model
|
# to the model
|
||||||
|
@ -10,9 +10,7 @@ from picklescan.scanner import scan_file_path
|
|||||||
import invokeai.backend.util.logging as logger
|
import invokeai.backend.util.logging as logger
|
||||||
from invokeai.app.util.misc import uuid_string
|
from invokeai.app.util.misc import uuid_string
|
||||||
from invokeai.backend.model_hash.model_hash import HASHING_ALGORITHMS, ModelHash
|
from invokeai.backend.model_hash.model_hash import HASHING_ALGORITHMS, ModelHash
|
||||||
from invokeai.backend.util.silence_warnings import SilenceWarnings
|
from invokeai.backend.model_manager.config import (
|
||||||
|
|
||||||
from .config import (
|
|
||||||
AnyModelConfig,
|
AnyModelConfig,
|
||||||
BaseModelType,
|
BaseModelType,
|
||||||
ControlAdapterDefaultSettings,
|
ControlAdapterDefaultSettings,
|
||||||
@ -26,7 +24,8 @@ from .config import (
|
|||||||
ModelVariantType,
|
ModelVariantType,
|
||||||
SchedulerPredictionType,
|
SchedulerPredictionType,
|
||||||
)
|
)
|
||||||
from .util.model_util import lora_token_vector_length, read_checkpoint_meta
|
from invokeai.backend.model_manager.util.model_util import lora_token_vector_length, read_checkpoint_meta
|
||||||
|
from invokeai.backend.util.silence_warnings import SilenceWarnings
|
||||||
|
|
||||||
CkptType = Dict[str | int, Any]
|
CkptType = Dict[str | int, Any]
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ from dataclasses import dataclass
|
|||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
from typing import Dict, List, Optional, Set
|
from typing import Dict, List, Optional, Set
|
||||||
|
|
||||||
from ..config import ModelRepoVariant
|
from invokeai.backend.model_manager.config import ModelRepoVariant
|
||||||
|
|
||||||
|
|
||||||
def filter_files(
|
def filter_files(
|
||||||
|
@ -13,14 +13,13 @@ from diffusers import OnnxRuntimeModel, UNet2DConditionModel
|
|||||||
from transformers import CLIPTextModel, CLIPTextModelWithProjection, CLIPTokenizer
|
from transformers import CLIPTextModel, CLIPTextModelWithProjection, CLIPTokenizer
|
||||||
|
|
||||||
from invokeai.app.shared.models import FreeUConfig
|
from invokeai.app.shared.models import FreeUConfig
|
||||||
|
from invokeai.backend.lora import LoRAModelRaw
|
||||||
from invokeai.backend.model_manager import AnyModel
|
from invokeai.backend.model_manager import AnyModel
|
||||||
from invokeai.backend.model_manager.load.optimizations import skip_torch_weight_init
|
from invokeai.backend.model_manager.load.optimizations import skip_torch_weight_init
|
||||||
from invokeai.backend.onnx.onnx_runtime import IAIOnnxRuntimeModel
|
from invokeai.backend.onnx.onnx_runtime import IAIOnnxRuntimeModel
|
||||||
|
from invokeai.backend.textual_inversion import TextualInversionManager, TextualInversionModelRaw
|
||||||
from invokeai.backend.util.devices import TorchDevice
|
from invokeai.backend.util.devices import TorchDevice
|
||||||
|
|
||||||
from .lora import LoRAModelRaw
|
|
||||||
from .textual_inversion import TextualInversionManager, TextualInversionModelRaw
|
|
||||||
|
|
||||||
"""
|
"""
|
||||||
loras = [
|
loras = [
|
||||||
(lora_model1, 0.7),
|
(lora_model1, 0.7),
|
||||||
@ -338,7 +337,7 @@ class ONNXModelPatcher:
|
|||||||
loras: List[Tuple[LoRAModelRaw, float]],
|
loras: List[Tuple[LoRAModelRaw, float]],
|
||||||
prefix: str,
|
prefix: str,
|
||||||
) -> None:
|
) -> None:
|
||||||
from .models.base import IAIOnnxRuntimeModel
|
from invokeai.backend.models.base import IAIOnnxRuntimeModel
|
||||||
|
|
||||||
if not isinstance(model, IAIOnnxRuntimeModel):
|
if not isinstance(model, IAIOnnxRuntimeModel):
|
||||||
raise Exception("Only IAIOnnxRuntimeModel models supported")
|
raise Exception("Only IAIOnnxRuntimeModel models supported")
|
||||||
@ -425,7 +424,7 @@ class ONNXModelPatcher:
|
|||||||
text_encoder: IAIOnnxRuntimeModel,
|
text_encoder: IAIOnnxRuntimeModel,
|
||||||
ti_list: List[Tuple[str, Any]],
|
ti_list: List[Tuple[str, Any]],
|
||||||
) -> Iterator[Tuple[CLIPTokenizer, TextualInversionManager]]:
|
) -> Iterator[Tuple[CLIPTokenizer, TextualInversionManager]]:
|
||||||
from .models.base import IAIOnnxRuntimeModel
|
from invokeai.backend.models.base import IAIOnnxRuntimeModel
|
||||||
|
|
||||||
if not isinstance(text_encoder, IAIOnnxRuntimeModel):
|
if not isinstance(text_encoder, IAIOnnxRuntimeModel):
|
||||||
raise Exception("Only IAIOnnxRuntimeModel models supported")
|
raise Exception("Only IAIOnnxRuntimeModel models supported")
|
||||||
|
@ -10,7 +10,7 @@ import torch
|
|||||||
from onnx import numpy_helper
|
from onnx import numpy_helper
|
||||||
from onnxruntime import InferenceSession, SessionOptions, get_available_providers
|
from onnxruntime import InferenceSession, SessionOptions, get_available_providers
|
||||||
|
|
||||||
from ..raw_model import RawModel
|
from invokeai.backend.raw_model import RawModel
|
||||||
|
|
||||||
ONNX_WEIGHTS_NAME = "model.onnx"
|
ONNX_WEIGHTS_NAME = "model.onnx"
|
||||||
|
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user