From 72c19987d5f74c01f57994a9c3f337933cec6fbd Mon Sep 17 00:00:00 2001 From: Lincoln Stein Date: Wed, 19 Jul 2023 11:41:45 -0400 Subject: [PATCH] discuss issues with adding controlnet models --- docs/features/CONTROLNET.md | 49 ++++++++++++++++++++++++++++++++++--- docs/features/index.md | 24 +++++++++++------- docs/index.md | 1 + 3 files changed, 61 insertions(+), 13 deletions(-) diff --git a/docs/features/CONTROLNET.md b/docs/features/CONTROLNET.md index a0f6d7d23a..ba66c26054 100644 --- a/docs/features/CONTROLNET.md +++ b/docs/features/CONTROLNET.md @@ -8,20 +8,61 @@ title: ControlNet ControlNet -ControlNet is a powerful set of features developed by the open-source community (notably, Stanford researcher [**@ilyasviel**](https://github.com/lllyasviel)) that allows you to apply a secondary neural network model to your image generation process in Invoke. +ControlNet is a powerful set of features developed by the open-source +community (notably, Stanford researcher +[**@ilyasviel**](https://github.com/lllyasviel)) that allows you to +apply a secondary neural network model to your image generation +process in Invoke. -With ControlNet, you can get more control over the output of your image generation, providing you with a way to direct the network towards generating images that better fit your desired style or outcome. +With ControlNet, you can get more control over the output of your +image generation, providing you with a way to direct the network +towards generating images that better fit your desired style or +outcome. ### How it works -ControlNet works by analyzing an input image, pre-processing that image to identify relevant information that can be interpreted by each specific ControlNet model, and then inserting that control information into the generation process. This can be used to adjust the style, composition, or other aspects of the image to better achieve a specific result. +ControlNet works by analyzing an input image, pre-processing that +image to identify relevant information that can be interpreted by each +specific ControlNet model, and then inserting that control information +into the generation process. This can be used to adjust the style, +composition, or other aspects of the image to better achieve a +specific result. ### Models -As part of the model installation, ControlNet models can be selected including a variety of pre-trained models that have been added to achieve different effects or styles in your generated images. Further ControlNet models may require additional code functionality to also be incorporated into Invoke's Invocations folder. You should expect to follow any installation instructions for ControlNet models loaded outside the default models provided by Invoke. The default models include: +InvokeAI provides access to a series of ControlNet models that provide +different effects or styles in your generated images. Currently +InvokeAI only supports "diffuser" style ControlNet models. These are +directories that contain the files `config.json` and either +`diffusion_pytorch_model.safetensors` or +`diffusion_pytorch_model.fp16.safetensors`. The name of the directory +is the same as the name of the model. ***We do not support +checkpoint-format ControlNets, which come in a single file with the +extension `.safetensors`.*** +Diffuser-style ControlNet models are available at HuggingFace +(http://huggingface.co) and accessed via their repo IDs (identifiers +in the format "author/modelname"). The easiest way to install them is +to use the InvokeAI model installer application. If you use the +`invoke.sh`/`invoke.bat` launcher, select item [5] and navigate to the +CONTROLNETS section. From the command line, the model installer can be +started with `invokeai-model-install`. + +You can select as many ControlNet models from the checkbox list as you +like, or enter additional HuggingFace repo_ids in the "Additional +models" textbox: + +![Model Installer - Controlnetl](../assets/installing-models/model-installer-controlnet.png){:width="640px"} + +_Be aware that some ControlNet models require additional code +functionality in order to work properly, so just installing a +third-party ControlNet model may not have the desired effect._ Please +read and follow the documentation for installing a third party model +not currently included among InvokeAI's default list. + +The models currently supported include: **Canny**: diff --git a/docs/features/index.md b/docs/features/index.md index b690d0b158..ffc663dd64 100644 --- a/docs/features/index.md +++ b/docs/features/index.md @@ -17,8 +17,12 @@ a single convenient digital artist-optimized user interface. ### * [Prompt Engineering](PROMPTS.md) Get the images you want with the InvokeAI prompt engineering language. -## * The [Concepts Library](CONCEPTS.md) -Add custom subjects and styles using HuggingFace's repository of embeddings. +### * The [LoRA, LyCORIS and Textual Inversion Models](CONCEPTS.md) +Add custom subjects and styles using a variety of fine-tuned models. + +### * [ControlNet](CONTROLNET.md) +Learn how to install and use ControlNet models for fine control over +image output. ### * [Image-to-Image Guide](IMG2IMG.md) Use a seed image to build new creations in the CLI. @@ -29,26 +33,28 @@ are the ticket. ## Model Management -## * [Model Installation](../installation/050_INSTALLING_MODELS.md) +### * [Model Installation](../installation/050_INSTALLING_MODELS.md) Learn how to import third-party models and switch among them. This guide also covers optimizing models to load quickly. -## * [Merging Models](MODEL_MERGING.md) +### * [Merging Models](MODEL_MERGING.md) Teach an old model new tricks. Merge 2-3 models together to create a new model that combines characteristics of the originals. -## * [Textual Inversion](TRAINING.md) +### * [Textual Inversion](TRAINING.md) Personalize models by adding your own style or subjects. -# Other Features +## Other Features -## * [The NSFW Checker](NSFW.md) +### * [The NSFW Checker](NSFW.md) Prevent InvokeAI from displaying unwanted racy images. -## * [Controlling Logging](LOGGING.md) +### * [Controlling Logging](LOGGING.md) Control how InvokeAI logs status messages. -## * [Miscellaneous](OTHER.md) + diff --git a/docs/index.md b/docs/index.md index 229cb6cf05..8bfaa02287 100644 --- a/docs/index.md +++ b/docs/index.md @@ -145,6 +145,7 @@ This method is recommended for those familiar with running Docker containers ### Model Management - [Installing](installation/050_INSTALLING_MODELS.md) - [Model Merging](features/MODEL_MERGING.md) +- [ControlNet Models](features/CONTROLNET.md) - [Style/Subject Concepts and Embeddings](features/CONCEPTS.md) - [Not Safe for Work (NSFW) Checker](features/NSFW.md)