Bugfix/checkpoint conversion (#4010)

## What type of PR is this? (check all applicable)

- [ ] Refactor
- [ ] Feature
- [x ] Bug Fix
- [ ] Optimization
- [ ] Documentation Update
- [ ] Community Node Submission


## Have you discussed this change with the InvokeAI team?
- [ ] Yes
- [ x] No, because there was no time!

      
## Have you updated all relevant documentation?
- [ ] Yes
- [X ] No


## Description

Hotfix for issue of SD1 and SD2 legacy safetensors models not converting
in 3.0.1rc1.
This commit is contained in:
Lincoln Stein 2023-07-26 15:21:16 -04:00 committed by GitHub
commit 6a3a776f4e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 9 additions and 3 deletions

View File

@ -767,7 +767,7 @@ def main():
if migrate_if_needed(opt, config.root_path): if migrate_if_needed(opt, config.root_path):
sys.exit(0) sys.exit(0)
if not config.model_conf_path.exists(): # run this unconditionally in case new directories need to be added
initialize_rootdir(config.root_path, opt.yes_to_all) initialize_rootdir(config.root_path, opt.yes_to_all)
models_to_download = default_user_selections(opt) models_to_download = default_user_selections(opt)

View File

@ -14,6 +14,7 @@ from .base import (
read_checkpoint_meta, read_checkpoint_meta,
classproperty, classproperty,
InvalidModelException, InvalidModelException,
ModelNotFoundException,
) )
from .sdxl import StableDiffusionXLModel from .sdxl import StableDiffusionXLModel
import invokeai.backend.util.logging as logger import invokeai.backend.util.logging as logger
@ -269,11 +270,16 @@ def _convert_ckpt_and_cache(
from ..convert_ckpt_to_diffusers import convert_ckpt_to_diffusers from ..convert_ckpt_to_diffusers import convert_ckpt_to_diffusers
from ...util.devices import choose_torch_device, torch_dtype from ...util.devices import choose_torch_device, torch_dtype
model_base_to_model_type = {BaseModelType.StableDiffusion1: 'FrozenCLIPEmbedder',
BaseModelType.StableDiffusion2: 'FrozenOpenCLIPEmbedder',
}
logger.info(f'Converting {weights} to diffusers format') logger.info(f'Converting {weights} to diffusers format')
with SilenceWarnings(): with SilenceWarnings():
convert_ckpt_to_diffusers( convert_ckpt_to_diffusers(
weights, weights,
output_path, output_path,
model_type=model_base_to_model_type[version],
model_version=version, model_version=version,
model_variant=model_config.variant, model_variant=model_config.variant,
original_config_file=config_file, original_config_file=config_file,