当前位置: 首页 > article >正文

ComfyUI流程图生图原理详解

一、引言

ComfyUI 是一款功能强大的工具,在图像生成等领域有着广泛应用。本文补充一点ComfyUI 的安装与配置过程遇到的问题,并深入剖析图生图过程及相关参数,帮助读者快速入门并深入理解其原理。

二、ComfyUI 的安装与配置中遇到的问题

(一)安装过程中的常见问题及解决方法

  1. Python 与 PyTorch 版本兼容性
    ComfyUI 官网推荐使用 Python 3.12,而 Python 3.12 仅支持 PyTorch 2.X 版本。因此,在安装时务必确保所安装的 PyTorch 版本与 Python 版本相互兼容。
  2. PyTorch CUDA 与服务器 CUDA 版本兼容性
    若服务器的 CUDA 版本较低(如 CUDA 11.2),鉴于 PyTorch 的底层算力逻辑通常具有兼容性,可尝试安装 CUDA 11.8 的 PyTorch 版本。
  3. numpy 版本兼容性
    通常建议安装 numpy<2.0,以避免潜在的兼容性问题。

(二)解决运行时的 CUDA 错误
若在运行python main.py时遭遇 CUDA 错误,可通过以下命令解决:

python main.py --listen 0.0.0.0 --disable-cuda-malloc

(三)ComfyUI 工作流与模型管理

  1. 安装插件
    在 ComfyUI 管理器中,插件安装类似于下载 GitHub 项目。一般情况下,插件会自动通过 pip install requirement.txt 来安装所需依赖。
  2. 解决连接问题
    • 网络检查(Linux 系统):若遇到无法连接到 GitHub 项目的问题,首先检查是否能通过正常网络访问 GitHub。若网络连接问题影响插件下载,可尝试使用国内镜像或通过 VPN 解决。
    • 手动下载插件:若仍无法连接 GitHub,可手动下载插件的压缩包,解压后将其放置到 custom_nodes/ 目录下,然后手动执行 pip install requirement.txt 来安装依赖。

三、图生图原理剖析

(一)图生图基础概念

在图生图过程中,checkpoints 由以下几部分组成:

  • model:扩散模型(作用于潜在空间)
  • CLIP:文本编码器
  • VAE:编码器和解码器

在这里插入图片描述

在潜在空间中,会进行扩散操作(对应 K 采样器)。其基本流程为:encode 将输入的文本、图像编码转化为计算机可识别的向量数据,借助 clip 找到与文本对应图像相似的向量,得到文本和图像组合的潜在空间向量。在此基础上进行扩散,在 latent 里得到扩散后的潜在空间向量,最后通过 Decoder(即 vae)解码,转化为人眼可见的图像

在这里插入图片描述

(二)图生图(Image - to - Image)过程及相关参数解析

  1. CLIP 文本编码的正向和负向条件
    CLIP 的文本编码
    CLIP(Contrastive Language - Image Pretraining)模型旨在将文本和图像映射到同一潜在空间,以便相互检索,主要采用对比学习方法进行训练。

    假设文本输入为 T = { t 1 , t 2 , . . . , t n } T = \{ t_1, t_2,..., t_n \} T={t1,t2,...,tn},其中 t i t_i ti 是文本中的第 i i i 个词汇。CLIP 使用 Transformer 模型对文本进行编码,得到文本的嵌入向量 z T z_T zT,即:
    z T = f T ( T ) z_T = f_T(T) zT=fT(T)
    其中, f T f_T fT 是文本编码器,负责将文本映射到潜在的嵌入空间。

    正向条件 (Positive Condition)
    正向条件用于衡量生成图像与文本描述的相似性,目标是使生成图像符合输入文本描述。在图生图任务中,正向条件通常由文本来引导生成图像的内容。 正向条件公式为:
    L contrastive = − log ⁡ exp ⁡ ( z T T z I / τ ) ∑ i = 1 N exp ⁡ ( z T T z i / τ ) L_{\text{contrastive}} = -\log \frac{\exp(z_T^T z_I / \tau)}{\sum_{i=1}^N \exp(z_T^T z_i / \tau)} Lcontrastive=logi=1Nexp(zTTzi/τ)exp(zTTzI/τ)
    其中, τ \tau τ 是温度参数,用于控制对比学习的难度。生成过程的目标是通过生成的图像 I ′ I' I 和输入文本描述的语义嵌入 z T z_T zT 来最小化对比损失。

    负向条件 (Negative Condition)
    在图像生成过程中,CLIP 模型通过对比学习最大化正向条件和负向条件之间的相似度差异。负向条件通过增加对比损失中的 “负样本” 来实现,这些负样本通常是与目标图像无关或对立的文本描述。 对比损失公式(包含负向条件)为:
    L contrastive = − log ⁡ exp ⁡ ( z T T z I / τ ) ∑ i = 1 N exp ⁡ ( z T T z i / τ ) − log ⁡ exp ⁡ ( z T T z I / τ ) ∑ j = 1 M exp ⁡ ( z T T z j neg / τ ) L_{\text{contrastive}} = -\log \frac{\exp(z_T^T z_I / \tau)}{\sum_{i=1}^N \exp(z_T^T z_i / \tau)} - \log \frac{\exp(z_T^T z_I / \tau)}{\sum_{j=1}^M \exp(z_T^T z_j^{\text{neg}} / \tau)} Lcontrastive=logi=1Nexp(zTTzi/τ)exp(zTTzI/τ)logj=1Mexp(zTTzjneg/τ)exp(zTTzI/τ)
    其中:

    • z T z_T zT 是文本的嵌入向量, z I z_I zI 是图像的嵌入向量。
    • z j neg z_j^{\text{neg}} zjneg 是与文本 T T T 语义不相关的负样本图像的嵌入。
    • τ \tau τ 是温度参数,用于调整正负样本之间的相似度,控制对比学习的难度。
    • M M M是负样本的数量。

负向条件的作用在于,通过 ∑ j = 1 M exp ⁡ ( z T T z j neg / τ ) \sum_{j=1}^M \exp(z_T^T z_j^{\text{neg}} / \tau) j=1Mexp(zTTzjneg/τ) 这部分,增加与目标图像不相关的文本条件,以对比正样本和负样本的相似度。从而使模型在生成图像时,避免生成与负向条件相关的图像表示,确保生成图像与负向文本描述的图像不同。

例如,若输入文本是 “a dog with a hat”(一只戴着帽子的狗),而负向文本是 “a dog without a hat”(一只没有帽子的狗),模型会倾向于生成戴帽子的狗,避免生成没戴帽子的狗,负向条件在此过程中对生成无帽子的狗进行惩罚。

2. K - 采样器与潜在空间的生成

  • K - 采样的过程
    K - 采样器是生成过程的关键部分,负责在潜在空间中从随机噪声开始,逐步调整生成的潜在表示,引导其趋近于目标图像。
    在扩散模型中,K - 采样器控制从潜在空间随机噪声逐步过渡到目标图像的过程,具体包括:

    • 从随机噪声开始:初始时,潜在空间的表示 z z z 接近随机噪声。
    • 逐步去噪:K - 采样器通过控制采样过程中的步数和噪声水平,逐步去除噪声,生成图像。
  • 参数解释
    在 K - 采样器的过程中,以下几个关键参数需要关注:

    • 步数(Steps):步数决定了从噪声到最终图像过渡过程的迭代次数。步数越多,去噪过程越精细,生成图像的细节越丰富。但增加步数也会增加计算开销。
    • 采样器(Sampler):采样器是负责实际去噪过程的算法,常见的有 Euler、Laplacian 等。不同的采样器采用不同的数学策略从噪声中提取图像信息,选择不同的采样器会影响图像生成的速度和质量。
    • 温度参数(Temperature, τ \tau τ:温度参数通常用于控制正向条件与负向条件之间的平衡。增大温度会使模型输出更随机、多样化;减小温度则使输出更稳定,偏向高置信度的内容。
    • 随机种子(Random Seed):随机种子控制生成过程的随机性,确保在相同输入下能够复现生成结果。改变随机种子会导致在相同文本条件下生成不同的图像。
  • K - 采样器公式
    K - 采样器的公式通常涉及生成模型的去噪过程。假设从噪声表示 x T x_T xT 开始,经过 t t t 步去噪生成 x 0 x_0 x0
    p ( x t − 1 ∣ x t ) = N ( x t − 1 ; μ θ ( x t , t ) , σ t 2 ) p(x_{t - 1} | x_t) = N(x_{t - 1}; \mu_{\theta}(x_t, t), \sigma_t^2) p(xt1xt)=N(xt1;μθ(xt,t),σt2) 其中:

    • μ θ \mu_{\theta} μθ 是神经网络模型,用于预测去噪过程的均值。
    • σ t \sigma_t σt 是时间步长 t t t 对应的标准差,表示噪声的强度。

3. VAE 解码器:从潜在空间生成图像
在这里插入图片描述

VAE 解码器公式

VAE 解码器负责将潜在空间中的表示 z z z 映射回图像空间,将潜在空间中的抽象向量转化为可视化图像。
假设潜在空间中的向量为 z z z,VAE 解码器的目标是将 z z z 转换为最终的图像 x x x,公式为:
x = g θ ( z ) x = g_{\theta}(z) x=gθ(z)
其中, g θ g_{\theta} gθ 是解码器网络,将潜在向量 z z z 映射回图像空间。

VAE 损失函数

VAE 的损失函数由两部分组成:

  • 重构误差:用于衡量生成的图像与真实图像之间的差异。
  • KL 散度:用于衡量潜在变量的分布与标准正态分布之间的差异。

VAE 损失函数如下:
L VAE = E q [ log ⁡ p θ ( x ∣ z ) ] − D KL ( q ϕ ( z ∣ x ) ∥ p ( z ) ) L_{\text{VAE}} = \mathbb{E}_q[\log p_{\theta}(x|z)] - D_{\text{KL}}(q_{\phi}(z|x) \| p(z)) LVAE=Eq[logpθ(xz)]DKL(qϕ(zx)p(z))

其中:

  • 第一项是重构误差,反映生成图像与真实图像的相似度。
  • 第二项是 KL 散度,衡量编码器输出的潜在分布与标准正态分布之间的差异。

(三)变分自编码器(VAE)模型的编码与解码过程

  1. 编码过程

    • 神经网络处理:将输入图像 x ( i ) x^{(i)} x(i) 送入作为概率编码器的神经网络(多层感知器 MLP),该网络学习将高维图像数据映射到低维空间,以提取图像的关键特征。
    • 计算分布参数:该神经网络输出近似后验 q ϕ ( z ∣ x ( i ) ) q_{\phi}(z | x^{(i)}) qϕ(zx(i)) 服从的多元高斯分布的均值 μ ( i ) \mu^{(i)} μ(i) 和标准差 σ ( i ) \sigma^{(i)} σ(i),它们是关于数据点 x ( i ) x^{(i)} x(i) 和变分参数 ϕ \phi ϕ 的非线性函数,即: log ⁡ q ϕ ( z ∣ x ( i ) ) = log ⁡ N ( z ; μ ( i ) , σ 2 ( i ) I ) \log q_{\phi}(z | x^{(i)}) = \log \mathcal{N}(z ; \mu^{(i)}, \sigma^{2(i)} I) logqϕ(zx(i))=logN(z;μ(i),σ2(i)I)
    • 重参数化采样:为对采样过程进行梯度计算,采用重参数化技巧。从后验分布中采样 z ( i , l ) z^{(i, l)} z(i,l),公式为: z ( i , l ) = μ ( i ) + σ ( i ) ⊙ ϵ ( l ) z^{(i, l)} = \mu^{(i)} + \sigma^{(i)} \odot \epsilon^{(l)} z(i,l)=μ(i)+σ(i)ϵ(l)
      其中 ϵ ( l ) ∼ N ( 0 , I ) \epsilon^{(l)} \sim \mathcal{N}(0, I) ϵ(l)N(0,I) ⊙ \odot 表示元素 - wise 乘积。通过均值、标准差与随机噪声的运算,将图像 x ( i ) x^{(i)} x(i) 编码为低维的隐变量 z ( i , l ) z^{(i, l)} z(i,l)
  2. 解码过程

    • 确定解码器输出类型:根据数据类型,若为实值数据, p θ ( x ∣ z ) p_{\theta}(x | z) pθ(xz) 假设为多元高斯分布。
    • 解码神经网络运算:解码器同样使用 MLP。其均值 μ \mu μ 和标准差 σ \sigma σ 由 MLP 计算得出,相关公式为:
      log ⁡ p ( x ∣ z ) = log ⁡ N ( x ; μ , σ 2 I ) \log p(x | z)=\log \mathcal{N}(x ; \mu, \sigma^{2} I) logp(xz)=logN(x;μ,σ2I)
      其中:
      μ = W 4 h + b 4 \mu = W_{4} h + b_{4} μ=W4h+b4,
      log ⁡ σ 2 = W 5 h + b 5 \log \sigma^{2} = W_{5} h + b_{5} logσ2=W5h+b5,
      h = tanh ⁡ ( W 3 z + b 3 ) h = \tanh(W_{3} z + b_{3}) h=tanh(W3z+b3),
      θ = { W 3 , W 4 , W 5 , b 3 , b 4 , b 5 } \theta = \{W_{3}, W_{4}, W_{5}, b_{3}, b_{4}, b_{5}\} θ={W3,W4,W5,b3,b4,b5} 是 MLP 的权重和偏置。将编码得到的隐变量 z ( i , l ) z^{(i, l)} z(i,l) 输入到解码器中,经过一系列运算,最终输出重构图像 x ^ ( i ) \hat{x}^{(i)} x^(i)

在这里插入图片描述

  1. 图像展示
    通过以下流程图直观展示 VAE 模型的编码和解码过程:

在这里插入图片描述在该流程图中:

  • 编码过程:输入图像 x x x 进入编码神经网络(MLP),该网络输出均值 μ \mu μ 和标准差 σ \sigma σ。借助从标准正态分布采样得到的噪声 ε \varepsilon ε ε ∼ N ( 0 , I ) \varepsilon \sim \mathcal{N}(0, I) εN(0,I)),通过重参数化技巧计算得到隐变量 z z z,实现将高维图像数据压缩为低维隐变量表示,完成特征提取。
  • 解码过程:得到的隐变量 z z z 被输入到解码神经网络(MLP)。解码过程是编码的逆过程,尝试从低维隐变量中恢复出原始图像的特征,输出尽可能与输入图像相似的重构图像 x ′ x' x

相关文章:

ComfyUI流程图生图原理详解

一、引言 ComfyUI 是一款功能强大的工具&#xff0c;在图像生成等领域有着广泛应用。本文补充一点ComfyUI 的安装与配置过程遇到的问题&#xff0c;并深入剖析图生图过程及相关参数&#xff0c;帮助读者快速入门并深入理解其原理。 二、ComfyUI 的安装与配置中遇到的问题 &a…...

使用右侧值现象来处理一个word导入登记表的需求

需求也简单&#xff0c;导word文件用户登记表&#xff0c;有各部门的十几个版本&#xff08;为什么这么多&#xff1f;不知道&#xff09;。这里说下谈下我的一些代码做法&#xff1a; 需求分析&#xff1a; 如果能解决java字段和各项填的值怎么配对的问题&#xff0c;那么就…...

《open3d pyqt》Alpha重建

《open3d pyqt》Alpha重建 一、效果展示二、qt设置2.1 主界面添加动作2.2 dialog 界面、布局如下:三、核心代码一、效果展示 二、qt设置 2.1 主界面添加动作 2.2 dialog 界面、布局如下: 并生成py文件,参考前述章节 三、核心代码 main.py文件增加 from Su...

深度解析HTTP/HTTPS协议:从原理到实践

深入浅出HTTP/HTTPS协议&#xff1a;从原理到实践 前言 在当今互联网世界中&#xff0c;HTTP和HTTPS协议如同空气般存在于每个网页请求的背后。作为开发者或技术爱好者&#xff0c;理解这些基础协议至关重要。本文将用六大板块&#xff0c;配合原理示意图和实操案例&#xff0…...

数据结构:顺序表(Sequence List)及其实现

什么是顺序表&#xff1f; 顺序表是一种最简单的数据结构&#xff0c;它就像一排连续的小房子&#xff0c;每个房子里都住着一个数据元素。这些房子是按顺序排列的&#xff0c;每个房子都有一个门牌号&#xff08;下标&#xff09;&#xff0c;我们可以通过门牌号快速找到对应…...

小程序canvas2d实现横版全屏和竖版逐字的签名组件(字帖式米字格签名组件)

文章标题 01 功能说明02 效果预览2.1 横版2.2 竖版 03 使用方式04 横向签名组件源码4.1 html 代码4.2 业务 Js4.3 样式 Css 05 竖向签名组件源码5.1 布局 Html5.2 业务 Js5.3 样式 Css 01 功能说明 技术栈&#xff1a;uniapp、vue、canvas 2d 需求&#xff1a; 实现横版的全…...

MoE演变过程

MoE演变过程 1 MoE1.1 BasicMoE1.2 SparseMoE1.2.1 实现 1.3 Shared Expert SparseMoE 1 MoE 参考&#xff1a;https://huggingface.co/blog/zh/moe 1.1 BasicMoE 用router给出各专家的权重&#xff0c;然后让输入过每一个专家&#xff0c;然后做加权求和。 1.2 SparseMoE …...

【Leetcode 热题 100】1287. 有序数组中出现次数超过25%的元素

问题背景 给你一个非递减的 有序 整数数组&#xff0c;已知这个数组中恰好有一个整数&#xff0c;它的出现次数超过数组元素总数的 25 % 25\% 25%。 请你找到并返回这个整数。 数据约束 1 ≤ a r r . l e n g t h ≤ 1 0 4 1 \le arr.length \le 10 ^ 4 1≤arr.length≤104 0…...

ruby 的安装

在51cto搜索的资料 ruby on rails的安装 http://developer.51cto.com/art/200906/129669.htm http://developer.51cto.com/art/200912/169391.htm http://developer.51cto.com/art/200908/147276.htm 史上最完整的ruby&#xff0c;rails环境架设配置&#xff08;Apachefast…...

【java】List<String> fruits = new ArrayList<>(); 这一句是什么

1. 代码分解 java Copy List<String> fruits new ArrayList<>(); List<String>&#xff1a; List 是 Java 中的一个接口&#xff0c;表示一个有序的集合&#xff08;可以重复元素&#xff09;。 <String> 是泛型&#xff0c;表示这个列表中的元素…...

通俗诠释 DeepSeek-V3 模型的 “671B” ,“37B”与 “128K”,用生活比喻帮你理解模型的秘密!

欢迎来到涛涛聊AI。 在DeepSeek-V3模型的参数描述中&#xff0c;你可能会看到类似“671B 37B 128K”这样的标记。这些字母和数字的组合看起来像密码&#xff0c;但其实它们揭示了模型的“大脑容量”和“工作方式”。我们用日常生活的比喻来解释&#xff1a; 一、数字含义&…...

【鸿蒙Next】优秀鸿蒙博客集锦

鸿蒙基础开发&#xff1a;多文件压缩上传及断点续传_鸿蒙 断点续传-CSDN博客...

【实战项目】BP神经网络识别人脸朝向----MATLAB实现

(꒪ꇴ꒪ )&#xff0c;Hello我是祐言QAQ我的博客主页&#xff1a;C/C语言&#xff0c;数据结构&#xff0c;Linux基础&#xff0c;ARM开发板&#xff0c;网络编程等领域UP&#x1f30d;快上&#x1f698;&#xff0c;一起学习&#xff0c;让我们成为一个强大的攻城狮&#xff0…...

C++线程安全函数

在 C 中&#xff0c;线程安全的函数是指在多线程环境下可以安全调用&#xff0c;不会导致数据竞争或其他并发问题的函数。C 标准库提供了许多线程安全的函数&#xff0c;同时也要求开发者在使用自定义函数时确保线程安全。以下是一些常见的线程安全函数和实现线程安全的方法&am…...

Java中的分布式(概念说明)

1. 分布式的基本概念 1.1 什么是分布式系统&#xff1f; 分布式系统&#xff08;Distributed System&#xff09;&#xff1a;由多台服务器&#xff08;或节点&#xff09;协同工作&#xff0c;对外提供一个整体服务。不同节点之间通过网络通信来协同处理请求或共享数据&…...

【1.8w字深入解析】从依赖地狱到依赖天堂:pnpm 如何革新前端包管理?

目录 前言npm 的诞生与发展嵌套依赖模型存在的问题npm3架构与yarnYarn 的诞生与局限Yarn 的诞生背景Yarn 仍然存在的问题 何为幽灵依赖依赖结构的不确定性pnpm王牌登场 -- 网状平铺结构安装包速度快依赖管理软链接 和 硬链接 机制 幽灵依赖产生的根本原因包管理工具的依赖解析机…...

【ISO 14229-1:2023 UDS诊断(ECU复位0x11服务)测试用例CAPL代码全解析⑤】

ISO 14229-1:2023 UDS诊断【ECU复位0x11服务】_TestCase05 作者&#xff1a;车端域控测试工程师 更新日期&#xff1a;2025年02月17日 关键词&#xff1a;UDS诊断协议、ECU复位服务、0x11服务、ISO 14229-1:2023 TC11-005测试用例 用例ID测试场景验证要点参考条款预期结果TC…...

137,【4】 buuctf web [SCTF2019]Flag Shop

进入靶场 都点击看看 发现点击work会增加&#xffe5; 但肯定不能一直点下去 抓包看看 这看起来是一个 JWT&#xff08;JSON Web Token&#xff09;字符串。JWT 通常由三部分组成&#xff0c;通过点&#xff08;.&#xff09;分隔&#xff0c;分别是头部&#xff08;Header&…...

Node.js 异步并发控制:`p-map` 和 `p-limit` 的使用与对比

在 Node.js 中&#xff0c;处理异步任务是开发中非常常见的需求。无论是批量处理数据、调用外部 API&#xff0c;还是操作文件系统&#xff0c;我们经常需要对多个异步任务进行管理。然而&#xff0c;当任务数量较多时&#xff0c;如果不加以控制&#xff0c;并发可能会导致性能…...

【c++】c++内存管理

目录 c和c的内存分布回顾C语言动态管理内存的方式malloccallocreallocfree C动态管理内存的方式new和deleteoperator new和operator delete定位new c和c的内存分布 回顾C语言动态管理内存的方式 malloc void* malloc (size_t size);malloc可以在堆上开辟指定内存的空间&#…...

EtherNet/IP转Modbus TCP:新能源风电监控与分析实用案例

EtherNet/IP转Modbus TCP&#xff1a;新能源风电监控与分析实用案例 一、案例背景 在某新能源汽车电池生产线上&#xff0c;需要将采用EtherNet/IP协议的电池检测设备与采用ProfiNet协议的生产线控制系统进行集成&#xff0c;以实现对电池生产过程的全面监控和数据采集。 二、…...

伪装目标检测(Camouflaged Object Detection, COD)教程

1. 引言 伪装目标检测&#xff08;Camouflaged Object Detection, COD&#xff09;是一项计算机视觉任务&#xff0c;旨在识别和分割背景中难以察觉的目标&#xff0c;如动物伪装、隐形物体检测等。由于伪装目标通常与背景高度相似&#xff0c;这项任务比传统的目标检测更具挑…...

烧烤炉出口亚马逊欧盟站CE认证EN1860安全标准

什么是欧盟CE认证&#xff1a; 在欧盟市场“CE”标志属强制性认证标志&#xff0c;不论是欧盟内部企业生产的产品&#xff0c;还是其他国家生产的产品&#xff0c;要想在欧盟市场上自由流通&#xff0c;就必须加贴“CE”标志&#xff0c;以表明产品符合欧盟《技术协调与标准化新…...

动态DNS神器nip.io使用指南:快速实现域名与IP的动态映射--告别配置本地hosts

动态DNS神器nip.io使用指南&#xff1a;快速实现域名与IP的动态映射--告别配置本地hosts 一、项目简介二、快速入门三、进阶配置四、典型应用场景 本文基于开源项目 v1.2.1版本撰写&#xff0c;适用于开发测试、CI/CD等场景 一、项目简介 nip.io 是由Exentrique Solutions开发…...

人工智能 - 机器学习、深度学习、强化学习是人工智能领域的理论基础和方法论

机器学习、深度学习、强化学习是人工智能领域的三大核心方向,各自具有独特的理论基础和方法论。以下是它们的核心理论知识总结: 一、机器学习(Machine Learning, ML) 1. 基础概念 目标:通过数据驱动的方式,让机器从经验中学习规律,完成预测、分类或决策任务。 核心范式…...

数字电路-基础逻辑门实验

基础逻辑门是数字电路设计的核心元件&#xff0c;它们执行的是基本的逻辑运算。通过这些基本运算&#xff0c;可以构建出更为复杂的逻辑功能。常见的基础逻辑门包括与门&#xff08;AND&#xff09;、或门&#xff08;OR&#xff09;、非门&#xff08;NOT&#xff09;、异或门…...

国产编辑器EverEdit - 如虎添翼的功能:快速选择

1 快速选择 1.1 应用场景 快速选择适用于批量选择和修改的场景&#xff0c;比如&#xff1a;变量改名。 1.2 使用方法 1.2.1 逐项快速选择 将光标放置在单词前或单词中&#xff0c;选择主菜单查找 -> 快速选择 -> 快速选择或使用快捷键Ctrl D 注&#xff1a;光标放…...

国内外网络安全政策动态(2025年1月)

▶︎ 1.国家互联网信息办公室发布《个人信息出境个人信息保护认证办法&#xff08;征求意见稿&#xff09;》 1月3日&#xff0c;国家互联网信息办公室发布《个人信息出境个人信息保护认证办法&#xff08;征求意见稿&#xff09;》。根据《意见稿》&#xff0c;个人信息出境个…...

68页PDF | 数据安全总体解决方案:从数据管理方法论到落地实践的全方位指南(附下载)

一、前言 这份报告旨在应对数字化转型过程中数据安全面临的挑战&#xff0c;并提供全面的管理与技术体系建设框架。报告首先分析了数字化社会的发展背景&#xff0c;强调了数据安全在国家安全层面的重要性&#xff0c;并指出数据安全风险的来源和防护措施。接着&#xff0c;报…...

AI大模型的文本流如何持续吐到前端,实时通信的技术 SSE(Server-Sent Events) 认知

写在前面 没接触过 SSE&#xff08;Server-Sent Events&#xff09;&#xff0c;AI大模型出来之后&#xff0c;一直以为文本流是用 WebSocket 做的偶然看到返回到报文格式是 text/event-stream,所以简单认知&#xff0c;整理笔记博文内容涉及 SSE 认知&#xff0c;以及对应的 D…...