After Detailer让图像自动修复

news2024/9/28 7:16:37

After Detailer(简称adetailer)是一个Stable Diffusion的自动Web-UI扩展,它能够自动化修复图像中的不完整部分,例如模糊的人脸等常见问题。在这篇文章中,你将了解它的工作原理、如何使用它,以及一些常见的使用场景。

软件

当然前提是你需要一个SD的软件,你可以用本地的SD webUI或者云端的SD环境,全都是可以的。

安装After Detailer扩展

  1. 正常启动AUTOMATIC1111 Web-UI。

  2. 导航到扩展页面。

  3. 点击从URL安装标签。

  4. 扩展的git仓库URL字段中输入以下URL。

https://github.com/Bing-su/adetailer

  1. 等待安装完成的确认消息。

  2. 重启Web-UI。

image-20240702151334743

怎么修复人脸

After Detailer的主要作用是做人脸修复,那么在没有After Detailer之前,我们是怎么做人脸修复的呢?

生成小尺寸人脸的问题

假设你生成了一个人的全身像。这里假设你使用的是v1模型,不应该设置过高的分辨率(超过512像素太多)。否则,你会得到重复的人像。

模型:majicmixRealistic_v7

提示:

anime style, 2d, fantasy anime detailed illustration, Grindhouse,  1girl, she is very Ghostly and Macho, with copper skin, she is dressed in Sweatpants, she has [Croatian|Punks] hair, at Sunset, 

尺寸:512×768

你会得到下面的图片:

image-20240702183001873

由于人脸小且分辨率低,覆盖人脸的像素不多。VAE没有足够的像素生成一个好的人脸。所以人脸是模糊的。

你通常会使用Send to inpaint按钮将图像发送到Inpainting。

image-20240702183119840

Inpaint标签中,围绕模糊的人脸画一个遮罩。

使用以下设置:

  • 遮罩模式:Inpaint masked

  • 遮罩内容:Original

  • Inpaint区域:Only masked

  • 去噪强度:0.5

点击Generate

image-20240702183344778

你会看到人脸被很好地修复了。inpaint area选择 only masked选项特别重要,因为它使用整个分辨率(512×768)重新生成遮罩区域。实际上,它以更高的分辨率重新生成了人脸,然后将其缩放回原始分辨率。这就是为什么人脸现在看起来好多了。

使用After Detailer自动Inpaint

After Detailer自动化了这个过程以及更多。它使用面部识别模型检测人脸自动创建Inpaint遮罩

然后扩展执行Inpaint,只处理遮罩区域,就像你手动处理一样。

所以它本质上是一个节省时间的扩展。

使用After Detailer

在Txt2img中使用

要在txt2img中使用After Detailer,请展开ADetailer。

选择Enable ADetailer

ADetailer model下拉菜单中选择face_yolo8n.pt模型。

image-20240702201412632

现在你就可以使用aDetailer的基本功能了。

点击Generate。你会得到以下图像。

image-20240702201612675

可能你得到的人脸图片和手动Inpaint不完全一样,那是因为绘制的遮罩区域是不同的。

在img2img中使用

你还可以在使用图像到图像转换时使用After Detailer。这样做的好处是你可以同时恢复人脸并为整个图像添加细节

在txt2img页面上,把之前的图片使用Send to img2img按钮将图像发送到img2img页面。

将img2img的去噪强度设置为一个较低的值,这样我们可以保持一个较低的重绘幅度。

ADetailer部分启用After Detailer。

点击Generate。生成图片。

我们可以对比一下两张图片的效果,可以看到重绘后的图片添加了更多的细节。

image-20240702202812881

当然,你也可以通过调整去噪强度来控制添加的细节级别。

同样的,你还可以在inpaint标签中使用ADetailer。

ADetailer参数解释

现在你知道了aDetailer的基本功能,现在让我们看一下,Adetailer的一些额外参数。

检测模型

在ADetailer模型下拉菜单中选择检测模型。可以看到下面几个模型,模型分为几个不同的组:

image-20240702203123933

Face_xxxx:检测并重绘人脸

Hand_xxxx:检测并重绘手

Person_xxxx:检测并重绘整个人

Mediapipe_face_xxxxx:检测并重绘人脸

最有用的模型是face_yolo和person_yolo模型

YOLO的全称是(You Only Look Once)模型擅长检测人脸和物体,在Inpaint中工作得很好。

然而,因为需要更多的像素来Inpaint整个人,所以使用人脸模型时人脸的细节并没有那么多。

通常不建议Inpaint一个大区域。如果你有像这样的图像,你最好手动一个接一个地Inpaint脚、裙子等。

Mediapipe_face有时有效有时无效。所以不太建议使用他们。

手模型用于重绘手。但不要对此抱太大希望,因为Stable Diffusion仍然不擅长绘制手,无论它重绘多少次。

最后,你可能会想知道YOLO 8n和8s模型之间的区别。8n模型更快,但比8s模型小约3倍(因此功能较弱)。8n模型的效果不错。但是如果After Detailer难以检测到人脸,请切换到8s模型。

最后,每次你可以使用多达两个检测模型。只需切换到2nd标签并选择一个额外的模型。

image-20240702205550611

因为我们同时选择了人脸和手部模型,所以现在它会检测到人脸,然后是手。然后它依次修复两者。

使用Inpaint提示

在inpaint中使用prompt可以通过prompt来改变检测到的人脸部分。具体的提示部分如下所示:

image-20240702210226366

这里我们使用了之前讲到的prompt的技巧,我们想让脸呈现的是Joe biden和川建国同志的混合面孔,所以我们的prompt可以这样写:

[Joe biden: donald trump: 0.5]

通过调整Inpaint去噪强度来调整效果。现在你得到了新的混合外观!

image-20240702210421795

要注意的是,这里的提示词还可以包含LoRA。如果你想要某些特定的face,那么可以尝试使用lora来实现。

Detection

一般来说,我们不需要改变detection的值。因为默认的值已经工作的很好了。

image-20240702210734923

检测模型置信度阈值:如果你注意的话,在检测人脸的过程中,会呈现一个数字。这个数字叫做置信度分数

0.8意味着模型有80%的信心认为这是一个人脸。阈值是所需的最低置信度分数。如果你设置为0.9,置信度分数为0.8的人脸将不被视为人脸。保持在0.3的低值。如果你有检测人脸的问题,请降低它。如果检测到太多,请增加它。

遮罩最小/最大区域比率:允许的检测遮罩的最小和最大区域。例如,如果你将最小区域比率设置为0.1,Adetailer将拒绝遮罩小于图像大小10%的检测。如果你检测到不需要的小物体,请增加最小值。

遮罩预处理

image-20240702210933969

这些值通常不需要更改。

这些是在Inpaint之前移动和调整遮罩大小的。为了获得最佳结果,你可以在设置 > ADetailer中启用“保存遮罩预览”,每个检测都会保存一个遮罩预览图像。这样我们可以通过保存下来的遮罩预览图像来了解遮罩是如何改变的。

遮罩x/y偏移:以像素为单位在x/y方向上移动遮罩。

遮罩腐蚀(-) / 膨胀(+):减小/扩大遮罩。

遮罩合并模式:分别Inpaint每个遮罩。合并:合并遮罩然后Inpaint。合并并反转:Inpaint未遮罩的区域。

Inpainting

image-20240702211254397

Inpainting部分中最重要的设置是Inpaint去噪强度。它控制自动Inpaint中使用的去噪强度。增加以进行更多更改。减少以进行较小的更改。

Inpaint only masked 表示是否只inpaint mask部分。

你可以修改Inpaint中的图像宽度高度CFG比例和采样步数。但默认值就可以了。

使用ControlNet与ADetailer

ControlNet是一个不可或缺的工具,可以精确控制图像生成。如果你不熟悉controlNet,请参考我之前写的controlnet的文章。要在ADetailer中使用ControlNet,你必须首先在AUTOMATIC1111上安装ControlNet。

然后,你可以在最后一部分中选择ControlNet模型。

image-20240702213232926

ControlNet Openpose

使用ControlNet Openpose模型可以用相同的姿势Inpaint人物。

例如,如果没有启用任何ControlNet并且去噪强度很高的时候,姿势可能会以与整体图像不一致的方式改变。

启用ControlNet Openpose后,女孩的姿势在Inpaint后保持不变。

ControlNet Tile

启用ControlNet Tile可以使Inpaint更好地遵循原始图像。

如果你想让Inpaint更好的贴合原始图像,请启用ControlNet Tile。

ControlNet inpaint

ControlNet inpaint模型(control_xxxx_inpaint)与global_inpaint_harmonious预处理器可以提高Inpaint区域与图像其余部分之间的一致性

当你想将Inpaint去噪强度设置得很高时,请使用global_inpaint_harmonious。稍微调整值或更改种子以获得不同的生成。

ControlNet Line art

ControlNet line art让Inpaint过程遵循原始图像的一般轮廓。

如果你想让Inpaint的图像遵循原始内容的轮廓,请使用ControlNet line art。

何时使用ADetailer

ADetailer中没有什么是你不能手动完成的。ADetailer只是下面一些步骤的自动化:

  • 将图像发送到Inpaint

  • 创建Inpaint遮罩

  • 设置ControlNet(可选)

  • 生成Inpaint

使用此扩展的最有价值的方面是自动化,以便你可以使用相同的设置创建多个图像。这在手动工作流程中是繁琐的。

技巧

当使用ADetailer与img2img时,有两个去噪强度需要设置。

img2img的去噪强度为整个图像设置值。

ADetailer中的Inpaint去噪强度为Inpaint设置去噪强度。

你还可以在设置> ADetailer中选择保存检测模型的结果。它将保存一个额外的图像,其中包含检测区域和置信度分数。

点我查看更多精彩内容:www.flydean.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1914208.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

@RequestPart 与 @RequestBody、@RequestParam 注解的异同点

前言 RequestPart 注解是我们在JavaEE 开发中,比较常见的一个注解。它经常会与 RequestBody 、RequestParam 注解进行比较,这篇博文我们以案例和源码相结合,分析这几个注解的异同点。 案例演示 创建实体类 User Data NoArgsConstructor A…

图片海报怎么做成二维码展示?二维码分享图片的制作技巧

怎么把图片的宣传海报做成二维码呢?在做活动或者产品宣传时,都会制作精美的图片海报,除了打印传单或者制作展板的方式来展示外,将海报图片生成二维码,通过分享二维码来实现图片海报的快速传播,能够有效提升…

[数据结构] 基于插入的排序 插入排序希尔排序

标题:[数据结构] 排序#插入排序&希尔排序 水墨不写bug 目录 (一)插入排序 实现思路: 插入排序实现: (二)希尔排序 希尔排序的基本思想: 希尔排序的实现: 正…

【转】-java多线程读写锁ReadWriteLock

Java多线程中读写锁ReadWriteLock的使用 该博客转载自​**lavimer​的​Java多线程中读写锁ReadWriteLock的使用** 1. 概念 读写锁分为读锁和写锁,多个读锁之间是不需要互斥的(读操作不会改变数据,如果上了锁,反而会影响效率),…

IPXProxy海外代理IP在MultiLogin指纹浏览器中的配置教程

Multilogin指纹浏览器是一款付费浏览器,它为用户提供了拥有多个虚拟浏览器配置文件的机会。作为最好的指纹浏览器之一,它常常被用来创建或管理多个账户,当然在这个过程,代理IP是不可或缺的一部分。下面给大家代理在MultiLogin指纹…

【企业级监控】Docker部署Zabbix与监控主机

基于Docker部署Zabbix6.2 文章目录 基于Docker部署Zabbix6.2资源列表基础环境一、首先安装Docker1.1、部署Docker1.2、配置Docker加速器 二、部署Zabbix组件介绍三、部署Zabbix3.1、安装数据库容器3.2、安装zabbix-java-gateway3.3、安装zabbix-server3.4、安装zabbix-web界面3…

大数据下的用户研究:深度洞察与精准决策的引擎

文章目录 一、大数据时代的用户研究新机遇二、大数据用户研究的流程与关键技术三、大数据用户研究的实践案例四、大数据用户研究的挑战与展望《用户研究方法:卓越产品和服务的用户研究技巧》内容及特色读者对象 在当今这个数据爆炸的时代,大数据已成为推…

microblaze时钟更改出现时序问题

在使用microblaze时,我给的时钟是200MHz的时钟,但会在跑布线的时候出现时序上的问题,一开始是没有任何的头绪,知道我尝试更改时钟的频率才发现问题的所在。 当我把200MHz的时钟改为100MHz的时钟时,就不会出现时序上的…

Defensor 4.5:构建数据资产为中心的安全运营体系

5月31日“向星力”未来数据技术峰会上,星环科技重磅发布数据安全管理平台 Defensor 4.5版本。新版本引入了以数据资产为中心的数据安全运营体系,通过智能化大模型技术,帮助企业快速、精准地识别核心重要资产;建设全局的数据安全策…

全球数字贸易中心解析_保税区保的是什么税_为什么保税区还要交税

保税区税收机制深度解析:保税免的是什么税?为何仍需缴税? 保税区概述 保税区,作为海关特殊监管区域的重要一环,享有国家高度开放的政策优惠与功能齐全的海关监管服务。它专为保税加工、保税物流和保税服务而设&#…

安防管理平台LntonCVS视频汇聚融合云平台智慧火电厂安全生产管理应用方案

中国的电力产业作为国民经济发展的重要能源支柱,被视为国民经济的基础产业之一。目前,我国主要依赖火力发电,主要燃料包括煤炭、石油和天然气等,通过燃烧转化为动能,再转变为电能输送至全国各地。火力发电量占全国发电…

给你的博客加上评论区

一个网站如果有评论功能,可以更好的和读者互动。VuePress 也有很多评论插件,这里简单介绍下,最后介绍本站所使用的 Twikoo。 大部分评论插件都是使用的 Github 或 Gitee 的 issue 功能,也就是用 issue 去存储评论;而 …

高压线束屏蔽效能测试之管中管法、线注入法

一、引言 上期推文介绍了高压线束屏蔽效能测试方法三同轴法,本篇文章将继续介绍高压线束相关测试方法——管中管法和线注入法。 二、管中管法 1、一般要求 管中管法参照IEC62153-4-7标准对高低压连接器进行零部件级屏蔽效能测试。在测试时,通过金属延长管…

从零开始做题:MP3

题目 给出一个mp3文件 解题 右键->selection->save selection->另存为xxx.png即可 8750d5109208213f E:\逐鹿\MISC\tools\MP3Stego_1_1_19\MP3Stego>.\decode -X cipher.mp3 MP3StegoEncoder 1.1.19 See README file for copyright info Input file cipher.mp3…

必看!微信小程序必备证书!

微信小程序必备SSL证书。在日益增长的数字经济中,微信小程序已成为商家与消费者之间重要的交互平台。由于其便捷性和广泛的用户基础,越来越多的企业选择通过小程序来提供服务。然而,在开发和部署微信小程序时,确保数据安全是一个不…

three-platformize 微信小程序 uniapp 使用截图功能

最近需要将3d场景进行截图,但是网上的各种各样,看的我一团乱麻,因此在解决完后就将这些简单的分享一下; 原理:将3维场景的那个canvas中的像素提取出来,找一个空的canvas二维画布放上去,然后用二…

Conformal low power-1.概述

概述 设计师们越来越期望更长的电池寿命和更高的性能。由于漏电流的增加,使用90纳米及更小工艺节点制造的设备在不使用时的功耗与使用时相同。设计师们可以针对漏电流和动态功耗进行优化,这可以减少能源使用并降低冷却和封装成本。额外的高级低功耗方法…

oracle哪些后台进程不能杀?

oracle 有很多的后台进程,在遇到特殊情况的时候如锁表,如果等待的是一个后台进程,那这时就需要考量是不是能杀掉这个后台进程?杀掉这个后台进程会不会引起实例崩溃?本着实践出真知,本文针对oracle 11g&…

入门PHP就来我这(高级)20 ~ 事务处理

有胆量你就来跟着路老师卷起来! -- 纯干货,技术知识分享 路老师给大家分享PHP语言的知识了,旨在想让大家入门PHP,并深入了解PHP语言。 接着上篇我们来看下PDO数据库的事务处理。 1 PDO中的事务处理 1.1 事务相关概念 事务&#…