首页 > Ai资讯 > Ai知识库 > Stable Diffusion基础:ControlNet之身份标识

Stable Diffusion基础:ControlNet之身份标识

发布时间:2024年10月26日

本文给大家分享一个新的ControlNet类型:Instant ID,翻译为身份标识,核心能力是由国内的小红书团队开发的。这个ControlNet可以提取人的面部信息,然后在生成的人物图片中使用此面部。实测效果完全可以代替Lora模型,也就是我们不用再费劲吧啦的训练人物形象Lora了,只需要人物的一张正面照片,就可以直接出图了。

效果演示

下图是官方的演示效果,左边是使用 Instant ID 生成的图片,右边是参考图片。

这个
ControlNet
相比 Roop 等换脸模型,也有更好的效果。

原理

先看左侧上部:Instant
ID
通过 IP-Adapter 技术提取参考图片中的面部特征信息,然后通过交叉注意力(Cross Atttention)将面部特征信息传递给 UNet,用于在反向扩散过程中影响人脸的生成。

再看左侧下部:这是
Instant ID
在描述自己的模型训练过程,它会使用大量的人脸特征进行训练,最终训练好的模型会应用到图片生成中。

最后看右侧:通常情况下,提供给 UNet 的交叉注意力来源是文本提示词,但是文本很难精确的表达一个人的面部特征,所以才搞出来 Instant ID的方案。

使用方法

有多种使用方法,这里介绍两种:

·

独立使用

·

HuggingFace上有示例代码:https://huggingface.co/InstantX/InstantID

你也可以直接在线体验:https://huggingface.co/spaces/InstantX/InstantID
,使用方法如下图所示:

不过这个在线体验有额度限制,如果触发额度限制,可以换个本地的外网IP再试下。

·

Stable
Diffusion WebUI
中使用

·

WebUI 中可以方便的集成更多能力,不过安装起来有些麻烦,感兴趣的同学可以继续阅读本文后续部分。

WebUI中安装Instant ID

使用AutoDL镜像

我已经在 AutoDL
的镜像中添加了这个 ControlNet,创建 WebUI 实例的时候选择下边这个镜像就行了。

IMG_260

AutoDL访问地址:https://www.autodl.com/

手动安装

升级ControlNet到最新版本

Stable Diffusion WebUI ControlNet 插件地址:https://github.com/Mikubill/sd-webui-controlnet,下载最新版本,然后更新到 WebUI 的插件目录 extensions 中。

安装成功后,重启
WebUI
,在 ControlNet 单元的 Control
Type
中就可以看到这个新类型了,Instant ID自带两个预处理器,不过模型还需要自行下载安装。如下图所示:

安装模型

首先需要下载两个
ControlNet
模型,然后把这两个模型放到 ControlNet 的模型目录,默认是:stable-diffusion-webui/extensions/sd-webui-controlnet/models

抱脸下载地址:https://huggingface.co/Aitrepreneur/InstantiDA1111/tree/main

网盘下载地址:https://pan.baidu.com/s/1nSYabIpMSE0AZHpOwAfwAw?pwd=eip5
内含多个ControlNet模型,本文只需要下图中的两个。

这个
ControlNet
还会用到 InsightFace,我们也需要把相关模型安装起来,默认放到这里:stable-diffusion-webui/extensions/sd-webui-controlnet/annotator/downloads/insightface/models/antelopev2

抱脸下载地址:https://huggingface.co/Aitrepreneur/InstantID-Controlnet/tree/main/models/antelopev2

网盘下载地址:
https://pan.baidu.com/s/123o_DzLtNY1bFhOtbcVtJQ?pwd=s7y4

WebUI中使用Instant ID

Instant ID 目前只支持SDXL,所以大模型必须选择XL模型,提示词和反向提示词简单写写就行了。

根据Github上的讨论,宽度和高度不要使用1024,否则会出现难以消除的水印文字。

有用户提出采样步数不要设置的太高,如果出图效果不好,可以调低点试试。

提示词引导系数要设置的小一点,这个没有固定值,可能不同模型的选择不一样,建议3-5吧。

InstantID 需要使用两个ControlNet单元,第一个单元用于提取面部特征,需要上传一张人脸参考图,预处理选择 instant_id_face_embedding,模型选择
ip-adpater_instant_id-sdxl

2ControlNet单元,还是Instant ID类型的,用于提取脸部姿态,可以上传一张不同的人脸照片,生成的图片会参考这张图片中人脸的位置,但是不会复刻人物的姿势,这和InstantX的演示有差距。这里我们使用同一张图,预处理器选择
instant_id_face_keypoints
, 模型选择 control_instant_id_sdxl。注意控制模式选择“以ControlNet为主”,否则生成的图片笔触会比较粗。

我们还可以选择不同的风格模版,这里选择一个线稿风格,最终生成效果如下图所示:

关于这个ControlNet的更多信息可以看关于它的官方讨论:

https://github.com/Mikubill/sd-webui-controlnet/discussions/2589

出自:https://mp.weixin.qq.com/s/HjkPV3KBEyrNgOVWGAuKUQ

如果你想要了解关于智能工具类的内容,可以查看 智汇宝库,这是一个提供智能工具的网站。
在这你可以找到各种智能工具的相关信息,了解智能工具的用法以及最新动态。