2024最新ComfyUI文生图详解教程!

前言

leetcode,16.25. LRU 缓存

设计和构建一个“最近最少使用”缓存,该缓存会删除最近最少使用的项目。
缓存应该从键映射到值(允许你插入和检索特定键对应的值),并在初始化时指定最大容量。当缓存被填满时,它应该删除最近最少使用的项目。
它应该支持以下操作: 获取数据 get 和 写入数据 put 。
获取数据 get(key) - 如果密钥 (key) 存在于缓存中,则获取密钥的值(总是正数),否则返回 -1。
写入数据 put(key, value) - 如果密钥不存在,则写入其数据值。
当缓存容量达到上限时,它应该在写入新数据之前删除最近最少使用的数据值,从而为新的数据值留出空。

public class LRUCache {`    `class DLinkedNode {//定义双向链表节点和构造函数`        `int key;`        `int value;`        `DLinkedNode prev;`        `DLinkedNode next;`        `public DLinkedNode() {}`        `public DLinkedNode(int _key, int _value) {key = _key; value = _value;}`    `}`    `    //使用hash进行快速定位节点`    `private Map<Integer, DLinkedNode> cache = new HashMap<Integer, DLinkedNode>();`    `private int size;`    `private int capacity;`    `private DLinkedNode head, tail;``   `    `//初始化`    `public LRUCache(int capacity) {`        `this.size = 0;`        `this.capacity = capacity;`        `// 使用伪头部和伪尾部节点`        `head = new DLinkedNode();`        `tail = new DLinkedNode();`        `head.next = tail;`        `tail.prev = head;`    `}``   `    `public int get(int key) {`        `DLinkedNode node = cache.get(key);`        `if (node == null) {`            `return -1;`        `}`        `// 如果 key 存在,先通过哈希表定位,再移到头部`        `moveToHead(node);`        `return node.value;`    `}``   `    `public void put(int key, int value) {`        `DLinkedNode node = cache.get(key);`        `if (node == null) {`            `// 如果 key 不存在,创建一个新的节点`            `DLinkedNode newNode = new DLinkedNode(key, value);`            `// 添加进哈希表`            `cache.put(key, newNode);`            `// 添加至双向链表的头部`            `addToHead(newNode);`            `++size;`            `if (size > capacity) {`                `// 如果超出容量,删除双向链表的尾部节点`                `DLinkedNode tail = removeTail();`                `// 删除哈希表中对应的项`                `cache.remove(tail.key);`                `--size;`            `}`        `}`        `else {`            `// 如果 key 存在,先通过哈希表定位,再修改 value,并移到头部`            `node.value = value;`            `moveToHead(node);`        `}`    `}`  `    //伪头节点的作用是为了快速头插`    `private void addToHead(DLinkedNode node) {`        `node.prev = head;`        `node.next = head.next;`        `head.next.prev = node;`        `head.next = node;`    `}``   `    `private void removeNode(DLinkedNode node) {`        `node.prev.next = node.next;`        `node.next.prev = node.prev;`    `}``   `    `private void moveToHead(DLinkedNode node) {`        `removeNode(node);`        `addToHead(node);`    `}``   `    `private DLinkedNode removeTail() {`        `DLinkedNode res = tail.prev;`        `removeNode(res);`        `return res;`    `}``}

在这里插入图片描述

ComfyUI

ComfyUI是鼎鼎大名的Stable Diffusion图像生成模型的使用界面之一。相比于其前辈WebUI,ComfyUI不仅在组织形式上,在性能上也得到了提升:

  • • 以工作流形式面向用户,给用户更高的自由度,直观易用。

  • 功能模块节点化,用户更加清楚功能和数据流转,可根据需求定制化

  • • 性能优化,图片生成速度更快

  • • 内部流程优化,硬件要求更低低显存和CPU也能运行,降低使用门槛

  • • 支持工作流程分享
    ComfyUI 开源地址:https://github.com/comfyanonymous/ComfyUI
    Web UI 开源地址:https://github.com/AUTOMATIC1111/stable-diffusion-webui
    Stable diffusion 开源地址:https://github.com/CompVis/stable-diffusion
    ComfyUI功能强大,包括文生图、图生图、文生视频、图片修复等,这里以文生图来对ComfyUI进行详细的入门介绍。

ComfyUI安装

windows下载安装:

对于windows用户来说只需要上ComfyUI的GitHub开源地址下载压缩包即可,如下图:

解压安装包到合适位置(建议选择磁盘剩余空间大的盘),如下图,

ComfyUI提供了run_cpurun_nvida_gpu两种启动脚本,顾名思义,分别为使用CPU和GPU运算,选择响应的文件双击即启动。

Llinux、mac安装启动

需要按照ComfyUI的GitHub开源地址中说明,依次
克隆项目
git clone https://github.com/comfyanonymous/ComfyUI.git
安装环境
AMD :pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/rocm6.0
NVIDA:pip install torch torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/cu121
安装依赖:
pip install -r requirements.txt
手动运行python main.py 启动。

ComfyUI启动界面如下如:

模型安装

ComfyUI已经启动,但是没有模型来运行,需要我们下载模型到对应的目录中,如图:

提供两个下载模型资源的地址:
抱抱脸:https://huggingface.co/
C站:https://civitai.com/

我在https://huggingface.co/runwayml/stable-diffusion-v1-5 下载v1-5-pruned-emaonly.ckpt模型后,放入checkpoint目录,启动程序,选择好模型,使用默认的提示词、参数、解码器等,运行的效果如图:

模块详解

以默认的文生图流程为例,对ComfyUI的各个流程节点:大模型加载器、正向提示词、反向提示词、采样器、图像宽高、输出输出、VAE解码器等进行介绍。

模型加载器

如下图,模型加载器分为几大类,分别是模型库(checkpoint),插件预训练模型(VAE、LoRA等),放大器(upscale)等。

按照如图选择的路径点击,即可添加大模型的加载器节点,如图所示:

在这里插入图片描述

本地已加载4个大模型供选择,双击即可选择。

正反提示词

提示词在文生图中至关重要,提示词的好坏关系到生成的图的效果。 如果自己运行文生图时,可以借鉴C站相关做作品的提示词模版。 提示词节点如下图方法添加:

一个输入CLIP刚好与大模型的输出CLIP可以相连,一个输出与采样器相连。 你会发现ComfyUI将可以相连的颜色也进行了匹配

图像属性

如图添加图像属性:宽和高,batch_size指一次生产图的数量。仅有一个输出。

采样器

如图,我们添加简单的采样器:

在这里插入图片描述

4个输入:分别对应大模型的model输出、正反提示词和图像属性。
一个输出:流程经过采样器处理完成后,图像在低维度意味着已经生产,所以最后要连接VAE解码器进行解码。

在这里插入图片描述

采样器的7个参数:

  • seed:种子,每张图都有个随机的种子。

  • control_after_generate:每次生产图后下一次种子的产生方式。默认是随机。
    注:当我们要微调当前已生产的图像时,将这个选项设置为固定。这样生成的图像不会相差太大

  • steps:生产图需要去噪的次数,值越大,图像越清晰,当然运行越慢。

  • cfg:提示词在生成中的权重,越小生成的图越与提示词风马牛不相及,一般0.8~0.9.

  • samper_name:ComfyUI提供了多种不同的采样器供选择,每种有不同的效果。感兴趣可以一一对比。

  • scheduler:控制迭代中噪声量大小,也有多种可选。

  • denoise:与steps相关,1表示按照steps设置的步数去降噪。

VAE解码器

如图进行添加。

输入samples与采样器的输入相连。VAE直接与大模型的VAE相连。
我们也可以新建一个VAE加载器与其相连,自定义要用的加载器类型。
输入图像直接与图像现实/保存相连。

保存图像

如图进行添加:

在这里插入图片描述

保存图像也有预览的功能,如果只是想预览图像可以选择添加preview image节点。
保存图像默认的保存路径在ComfyUI安装路径的temp目录下。

生成图像

添加好节点,只需选好要连接的输入输出,拖动就可以连接。 ComfyUI的颜色匹配可以辅助。
点击如下图,控制面板的 Queue Prompt或者按下Ctrl + enter,即可运行。

流程图运行过程中会标识运行的进度,表示正在运行的节点,清晰直观。

运行结束,可以save我们的流程图,以便下次加载或分享给他人

接下就可以自己设置相关变量参数,试试看了。 如下图是我参照C站相关作品的参数,生成流程图:

为了帮助大家更好地掌握 ComfyUI,我在去年花了几个月的时间,撰写并录制了一套ComfyUI的基础教程,共六篇。这套教程详细介绍了选择ComfyUI的理由、其优缺点、下载安装方法、模型与插件的安装、工作流节点和底层逻辑详解、遮罩修改重绘/Inpenting模块以及SDXL工作流手把手搭建。

由于篇幅原因,本文精选几个章节,详细版点击下方卡片免费领取
在这里插入图片描述

一、ComfyUI配置指南

  • 报错指南
  • 环境配置
  • 脚本更新
  • 后记

img

二、ComfyUI基础入门

  • 软件安装篇
  • 插件安装篇

img

三、 ComfyUI工作流节点/底层逻辑详解

  • ComfyUI 基础概念理解
  • Stable diffusion 工作原理
  • 工作流底层逻辑
  • 必备插件补全

img

四、ComfyUI节点技巧进阶/多模型串联

  • 节点进阶详解
  • 提词技巧精通
  • 多模型节点串联

img

五、ComfyUI遮罩修改重绘/Inpenting模块详解

  • 图像分辨率
  • 姿势

img

六、ComfyUI超实用SDXL工作流手把手搭建

  • Refined模型
  • SDXL风格化提示词
  • SDXL工作流搭建

img

由于篇幅原因,本文精选几个章节,详细版点击下方卡片免费领取

在这里插入图片描述

img

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

网络基础:EIGRP

EIGRP&#xff08;Enhanced Interior Gateway Routing Protocol&#xff09;是由思科开发的一种高级距离矢量路由协议&#xff0c;结合了距离矢量和链路状态路由协议的优点&#xff1b;EIGRP具有快速收敛、高效带宽利用、负载均衡等特点&#xff0c;适用于各种规模的网络。EIGR…

基于YOLOv9+pyside的安检仪x光危险物物品检测(有ui)

安全检查在公共场所确保人身安全的关键环节&#xff0c;不可或缺。X光安检机作为必要工具&#xff0c;在此过程中发挥着重要作用。然而&#xff0c;其依赖人工监控和判断成像的特性限制了其应用效能。本文以此为出发点&#xff0c;探索了基于Torch框架的YOLO算法在安检X光图像中…

线性代数笔记

行列式 求高阶行列式 可以划上三角 上三角 余子式 范德蒙行列式 拉普拉斯公式 行列式行列对换值不变 矩阵 矩阵的运算 同型矩阵加减 对应位置相加减 矩阵的乘法 左边第 i 行 一次 相乘求和 右边 第 j 列 eg 中间相等 两边规模 矩阵的幂运算 解题思路 找规律 数学归纳…

智能体实战:开发一个集成国内AI平台的GPTs,自媒体高效智能助手

文章目录 一&#xff0c;什么是GPTs二&#xff0c;开发GPTs1&#xff0c;目标2&#xff0c;开发2.1 打开 GPTS&#xff1a;https://chat.openai.com/gpts2.2 点击 Create 创建一个自己的智能体 2.3 配置GPTs2.4 配置外挂工具2.4.1 配置Authentication-授权2.4.1.1 生成语聚AI的…

人工智能-NLP简单知识汇总01

人工智能-NLP简单知识汇总01 1.1自然语言处理的基本概念 自然语言处理难点&#xff1a; 语音歧义句子切分歧义词义歧义结构歧义代指歧义省略歧义语用歧义 总而言之&#xff1a;&#xff01;&#xff01;语言无处不歧义 1.2自然语言处理的基本范式 1.2.1基于规则的方法 通…

医院挂号系统:基于JSP和MySQL的现代化医疗预约平台

开头语&#xff1a;您好&#xff0c;我是专注于医疗系统开发的IT学长。如果您对医院挂号系统感兴趣&#xff0c;欢迎联系我。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;JSP技术&#xff0c;B/S架构 工具&#xff1a;Eclipse&#xff0c;MyEclips…

前端Bug 修复手册

1.前端长整数精度丢失问题 &#xff08;1&#xff09;问题 在前后端联调时&#xff0c;发现后端有一个接口返回的值和前端页面上展示的值不一致。 后端Java实现的接口如下&#xff0c;返回一个json格式的大整数 123456789123456789&#xff1a; 但是前端请求这个接口后&…

数据结构算法之B树

一、绪论 1.1 数据结构的概念和作用 1.2 B树的起源和应用领域 二、B树的基本原理 2.1 B树的定义和特点 2.2 B树的结构和节点组成 2.3 B树的插入 2.4 B树的删除操作 三、B树的优势和应用 3.1 B树在数据库系统中的应用 3.2 B树在文件系统中的应用 3.3 B树在内存管理中…

【网络】网络基础(一)

网络基础&#xff08;一&#xff09; 文章目录 一、计算机网络背景1.1网络发展1.2认识“协议” 二、网络协议初识2.1OSI七层模型2.2OSI五层模型 三、网络传输基本流程3.1局域网通信3.2网络传输流程不跨子网的网络传输跨子网的网络传输 3.3网络中的地址管理IP地址MAC地址 一、计…

SpringBoot环境集成 sms4j短信聚合

SpringBoot环境集成 sms4j短信聚合 官方文档 前言 在正式使用sms4j短信功能之前&#xff0c;请详细阅读本文档&#xff0c;依照本篇流程进行操作和配给&#xff0c;即可解决大部分问题&#xff0c;如对我们的文档有建议&#xff0c;请联系开发者团队&#xff0c; 我们将根据可…

摸鱼必备!!10个你不知道的 Vue 3 组件库...

大家好,我是CodeQi! 你们有没有过这种经历:正在认真写代码,忽然想看看有啥好玩的新东西,结果一不小心就摸鱼了整整一个下午? 哈哈,我也有过这种体验。不过,这次的摸鱼可不是浪费时间,而是大有收获! 今天,我要分享的是10个你可能还不知道的 Vue 3 组件库,这些库…

SD-WebUI视频重绘:TemporalKit+EbsynthUtility避坑指南

AI视频重绘&#xff0c;在当下大家并不陌生。我们的实现方式大致可以分为三种: 第三方平台和discord上转绘&#xff0c;如DomoAI &#xff0c;GoEnhance AI 等。 优点&#xff1a;效果佳&#xff0c;门槛低。 缺点&#xff1a;需要科学上网&#xff0c;和支付一定的使用费用。…

云原生之容器编排实践-OpenEuler23.09在线安装Kubernetes与KubeSphere

背景 前几篇文章中介绍了如何将 ruoyi-cloud 项目部署到 Kubernetes 集群中&#xff0c;包括网关服务、认证服务和系统服务并且对全部服务采用 YAML 文件的方式来进行部署&#xff0c;这虽然有助于理解 K8S 组织管理资源的风格与底层机制&#xff0c;但是对于团队中不太熟悉命…

黑马头条-数据管理平台

目录 项目准备 验证码登录 验证码登录-流程 token 的介绍 个人信息设置和 axios 请求拦截器 axios 响应拦截器和身份验证失败 优化-axios 响应结果 发布文章-富文本编辑器 项目准备 技术&#xff1a; • 基于 Bootstrap 搭建网站标签和样式 • 集成 wangEditor 插件…

嵌入式Linux系统编程 — 6.3 kill、raise、alarm、pause函数向进程发送信号

目录 1 kill函数 1.1 kill函数介绍 1.2 示例程序 2 raise函数 2.1 raise函数介绍 2.2 示例程序 3 alarm函数 3.1 alarm函数介绍 3.2 示例程序 4 pause函数 4.1 pause函数介绍 4.2 示例程序 与 kill 命令相类似&#xff0c; Linux 系统提供了 kill()系统调用&#…

用MySQL+node+vue做一个学生信息管理系统(一):配置项目

先用npm init -y生成配置文件 在项目下新建src文件夹&#xff0c;app.js文件。src目录用来放静态资源文件&#xff0c;app.js是服务器文件&#xff0c;index.js是vue的入口文件 使用npm install express下载express框架 在app.js文件夹开启node服务&#xff0c;监听的端口为…

可视化作品集(01):工业控制领域的大屏

hello&#xff0c;大家好&#xff0c;我是威斯数据&#xff0c;本期开始按照主题来分享可视化大屏/数字孪生项目作品集&#xff0c;大家想看哪些行业的作品&#xff0c;可以在评论区留言。 可视化大屏在工业控制领域可以帮助企业实现生产过程的实时监控、故障预警、生产调度和…

【Windows】Visual Studio Installer下载缓慢解决办法

【Windows】Visual Studio Installer下载缓慢解决办法 1.背景2.分析3.结果 1.背景 使用visual studio在线安装包进行IDE安装&#xff0c;发现下载几乎停滞&#xff0c;网速几乎为零。 经过排查并不是因为实际网络带宽导致。 这里涉及DNS知识&#xff1b; DNS&#xff08;Dom…

Lua、AB包热更新总结

1.AB包热更新 &#xff08;1&#xff09;AB包是一种特定的压缩文件&#xff0c;可以放模型贴图音效等等 &#xff08;2&#xff09;Resources目录下打包时只读 无法修改&#xff1b;而AB包存储的位置是自定义的&#xff0c;能够动态更新&#xff0c;同时可以决定资源包初始的大…

红酒与舞蹈:舞动的味觉艺术

在艺术的海洋中&#xff0c;红酒与舞蹈总是能激起人们心中较温柔的涟漪。红酒以其深邃的色泽、馥郁的香气&#xff0c;诠释着味觉的艺术&#xff1b;而舞蹈&#xff0c;则以优雅的姿态、灵动的步伐&#xff0c;演绎着视觉的盛宴。当红酒遇上舞蹈&#xff0c;一场别开生面的艺术…