2023-03-11 15:56:53 +00:00
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
import torch
|
|
|
|
from argparse import Namespace
|
2023-03-11 16:32:57 +00:00
|
|
|
from invokeai.backend import Args
|
2023-03-11 15:56:53 +00:00
|
|
|
from omegaconf import OmegaConf
|
|
|
|
from pathlib import Path
|
2023-04-29 14:48:50 +00:00
|
|
|
from typing import types
|
2023-03-11 15:56:53 +00:00
|
|
|
|
|
|
|
import invokeai.version
|
2023-05-04 02:30:30 +00:00
|
|
|
from .config import InvokeAISettings
|
2023-03-11 15:56:53 +00:00
|
|
|
from ...backend import ModelManager
|
|
|
|
from ...backend.util import choose_precision, choose_torch_device
|
|
|
|
|
2023-03-11 23:08:45 +00:00
|
|
|
# TODO: Replace with an abstract class base ModelManagerBase
|
2023-04-29 14:48:50 +00:00
|
|
|
def get_model_manager(config: Args, logger: types.ModuleType) -> ModelManager:
|
2023-05-04 02:30:30 +00:00
|
|
|
model_config = config.model_conf_path
|
|
|
|
if not model_config.exists():
|
|
|
|
report_model_error(
|
|
|
|
config, FileNotFoundError(f"The file {model_config} could not be found."), logger
|
|
|
|
)
|
2023-03-11 15:56:53 +00:00
|
|
|
|
2023-04-29 13:43:40 +00:00
|
|
|
logger.info(f"{invokeai.version.__app_name__}, version {invokeai.version.__version__}")
|
2023-05-04 02:30:30 +00:00
|
|
|
logger.info(f'InvokeAI runtime directory is "{config.root}"')
|
2023-03-11 15:56:53 +00:00
|
|
|
|
|
|
|
# these two lines prevent a horrible warning message from appearing
|
|
|
|
# when the frozen CLIP tokenizer is imported
|
|
|
|
import transformers # type: ignore
|
|
|
|
|
|
|
|
transformers.logging.set_verbosity_error()
|
|
|
|
import diffusers
|
|
|
|
|
|
|
|
diffusers.logging.set_verbosity_error()
|
2023-05-04 02:30:30 +00:00
|
|
|
embedding_path = config.embedding_path
|
2023-03-11 15:56:53 +00:00
|
|
|
|
|
|
|
# migrate legacy models
|
|
|
|
ModelManager.migrate_models()
|
|
|
|
|
|
|
|
# creating the model manager
|
|
|
|
try:
|
|
|
|
device = torch.device(choose_torch_device())
|
2023-03-11 16:32:57 +00:00
|
|
|
precision = 'float16' if config.precision=='float16' \
|
|
|
|
else 'float32' if config.precision=='float32' \
|
2023-03-11 15:56:53 +00:00
|
|
|
else choose_precision(device)
|
|
|
|
|
|
|
|
model_manager = ModelManager(
|
2023-03-11 16:32:57 +00:00
|
|
|
OmegaConf.load(config.conf),
|
2023-03-11 15:56:53 +00:00
|
|
|
precision=precision,
|
|
|
|
device_type=device,
|
2023-03-11 16:32:57 +00:00
|
|
|
max_loaded_models=config.max_loaded_models,
|
2023-05-04 02:30:30 +00:00
|
|
|
embedding_path = embedding_path,
|
2023-04-29 14:48:50 +00:00
|
|
|
logger = logger,
|
2023-03-11 15:56:53 +00:00
|
|
|
)
|
|
|
|
except (FileNotFoundError, TypeError, AssertionError) as e:
|
2023-04-29 14:48:50 +00:00
|
|
|
report_model_error(config, e, logger)
|
2023-03-11 15:56:53 +00:00
|
|
|
except (IOError, KeyError) as e:
|
2023-04-29 13:43:40 +00:00
|
|
|
logger.error(f"{e}. Aborting.")
|
2023-03-11 15:56:53 +00:00
|
|
|
sys.exit(-1)
|
|
|
|
|
|
|
|
# try to autoconvert new models
|
|
|
|
# autoimport new .ckpt files
|
2023-05-04 02:30:30 +00:00
|
|
|
if config.autoconvert_path:
|
|
|
|
model_manager.heuristic_import(
|
|
|
|
config.autoconvert_path,
|
2023-03-11 15:56:53 +00:00
|
|
|
)
|
|
|
|
return model_manager
|
|
|
|
|
2023-04-29 14:48:50 +00:00
|
|
|
def report_model_error(opt: Namespace, e: Exception, logger: types.ModuleType):
|
2023-04-29 13:43:40 +00:00
|
|
|
logger.error(f'An error occurred while attempting to initialize the model: "{str(e)}"')
|
|
|
|
logger.error(
|
2023-04-19 00:49:00 +00:00
|
|
|
"This can be caused by a missing or corrupted models file, and can sometimes be fixed by (re)installing the models."
|
2023-03-11 15:56:53 +00:00
|
|
|
)
|
|
|
|
yes_to_all = os.environ.get("INVOKE_MODEL_RECONFIGURE")
|
|
|
|
if yes_to_all:
|
2023-04-29 14:48:50 +00:00
|
|
|
logger.warning(
|
2023-04-19 00:49:00 +00:00
|
|
|
"Reconfiguration is being forced by environment variable INVOKE_MODEL_RECONFIGURE"
|
2023-03-11 15:56:53 +00:00
|
|
|
)
|
|
|
|
else:
|
|
|
|
response = input(
|
|
|
|
"Do you want to run invokeai-configure script to select and/or reinstall models? [y] "
|
|
|
|
)
|
|
|
|
if response.startswith(("n", "N")):
|
|
|
|
return
|
|
|
|
|
2023-04-29 13:43:40 +00:00
|
|
|
logger.info("invokeai-configure is launching....\n")
|
2023-03-11 15:56:53 +00:00
|
|
|
|
|
|
|
# Match arguments that were set on the CLI
|
|
|
|
# only the arguments accepted by the configuration script are parsed
|
|
|
|
root_dir = ["--root", opt.root_dir] if opt.root_dir is not None else []
|
|
|
|
config = ["--config", opt.conf] if opt.conf is not None else []
|
|
|
|
sys.argv = ["invokeai-configure"]
|
|
|
|
sys.argv.extend(root_dir)
|
2023-03-11 16:32:57 +00:00
|
|
|
sys.argv.extend(config.to_dict())
|
2023-03-11 15:56:53 +00:00
|
|
|
if yes_to_all is not None:
|
|
|
|
for arg in yes_to_all.split():
|
|
|
|
sys.argv.append(arg)
|
|
|
|
|
|
|
|
from invokeai.frontend.install import invokeai_configure
|
|
|
|
|
|
|
|
invokeai_configure()
|
|
|
|
# TODO: Figure out how to restart
|
|
|
|
# print('** InvokeAI will now restart')
|
|
|
|
# sys.argv = previous_args
|
|
|
|
# main() # would rather do a os.exec(), but doesn't exist?
|
|
|
|
# sys.exit(0)
|