RES 新的数据集 Advancing Referring Expression Segmentation Beyond Single Image 论文笔记

news2025/1/10 3:08:16

RES 新的数据集 Advancing Referring Expression Segmentation Beyond Single Image 论文笔记

  • 一、Abstract
  • 二、引言
  • 三、相关工作
    • 3.1 Referring Expression Segmentation (RES)
    • 3.2 CoSalient Object Detection (CoSOD)
  • 四、提出的方法
    • 4.1 概述
      • 文本 & 图像编码器
      • TQM & Heatmap Hierarchizer
      • Mask 预测器
    • 4.2 Triphasic Query Module (TQM)
    • 4.3 Heatmap Hierarchizer
    • 4.4 训练目标
      • 负样本训练
      • 三重阈值损失
      • 镜像训练策略
      • 目标函数
  • 五、提出的数据集
    • 5.1 数据集亮点
    • 5.2 构建步骤
    • 5.3 数据统计
  • 六、实验
    • 6.1 数据和指标
    • 6.2 实施细节
    • 6.3 与 SOTA 方法的比较
      • 在 GRES 设置上的结果
      • 在 RES 设置上的结果
      • 在 Co-SOD 设置上的结果
    • 6.4 消融实验
      • Triphasic Query Module (TQM)
      • Heatmap Hierarchizer (HMapHier)
      • Mirror Training (MirrorT)
      • Triplet Margin Loss (TriLoss)
  • 七、结论

写在前面

  最近一直在看 Arxiv,好像已经没有多少关于实例分割框架了。目前以跨模态,多模态的 Zero-shot 居多,这也是个发展趋势,大家都在整大模型了。这次的论文笔记是挑选一篇这两天放出来的 Arxiv 文章,关于参考表达式分割。

  • 论文地址:Advancing Referring Expression Segmentation Beyond Single Image
  • 代码地址:https://github.com/yixuan730/group-res,暂未放出完整版
  • 预计投稿于某个顶会
  • PS:2023 年每周一篇博文,主页更多干货,欢迎关注吖,4千粉丝期待有你的参与呦👉

一、Abstract

  首先表明 Referring Expression Segmentation (RES) 的定义,指出现有的缺陷:现实世界场景中,无法确定语言描述的目标是否真实存在于当前的图像内。于是本文提出 Group-wise Referring Expression Segmentation (GRES),即分组参考图像分割:将 RES 拓展到一组相关图像中,同时表达式只描述这组子集图像内的目标。相应地,引入一个新数据集 Grouped Referring Dataset (GRD),包含输入表达式对应目标的完整标注。同时提出一个 Baseline 方法 Grouped Referring Segmenter (GRSer)。

二、引言

在这里插入图片描述
  如上图所示,在一堆搜集好的图像中分割用语言描述的目标是个基本需求但是被忽视的能力。Referring Expression Segmentation (RES) 有解决这个问题的潜力,但其设置过于理想化。因为 RES 旨在分割单个图像中描述的目标物,而目前需要在一堆图像中分割出表达式所指代的目标。
  本文引入一种新的设置,Group-wise Referring Expression Segmentation (GRES):从一组相关图像中分割出语言表达式所描述的目标。从两个方面建立 GRES:Grouped Referring Segmenter (GRSer) 模型;Group Referring Dataset (GRD) 数据集。
  GRSer 同时处理多个输入图像,也能同时产生所有被描述目标的分割 mask。其中 Triphasic Query Module (TQM) 通过语言特征和组内视觉特征来检索目标。在提出的热力图分层器上,通过组内视觉检索出来的热力图并基于其置信度来打分,之后对其排序从而来预测分割 mask。此外,提出一种镜像训练策略和三元组损失来学习反表达式特征,使得 GRSer 能够理解图像背景和负样本。
  引入的 GRD 数据集,部分例子如下图所示:

在这里插入图片描述
GRD 数据集总共包含 16480 个正样本目标-表达式对,41231 个可信的负样本图像-表达式对,另外的一些负样本在每个组别中都不存在。

本文贡献如下:

  • 在 RES 任务上引入了一种 Group-wise Referring Expression Segmentation (GRES) 设置,提高了特定用户的目标分割体验,以朝着现实应用推进;
  • 提出了一个 GRD 数据集;
  • 大量实验充分表明了 GRSer 的泛化性和有效性,同时在 GRES、Co-Salient Object Detection、RES 任务上表现很好。

三、相关工作

3.1 Referring Expression Segmentation (RES)

  RES 旨在根据输入的语言表达式从对应的图像中分割出相应的目标 mask。
  一般的方法采用先提取视觉和语言特征然后融合的办法。早期的融合方法是简单的拼接这两种模态的特征,最近开始用 Transformer 以及注意力机制来实现更好的融合。另外有一些方法采用相关的任务来解决 RES,例如视觉定位、zero/one-shot 分割、交互分割、统一分割、参考表达式生成等。
  数据集:Ref-Clef、RefCOCO、RefCOCO+、RefCOCOg(G-Ref)、PhraseCut。

3.2 CoSalient Object Detection (CoSOD)

  CoSOD 是最近的研究热点,旨在发现一组相关图像中的共同语义目标。
  利用获得的公共目标的共同表示来引导分割,方法有:特征拼接、线性求和、通道变换、图神将网络、迭代进化;使用成对的相似度图、动态卷积、组仿射变换、transformers;数据增强、训练策略、对抗攻击等。
  数据集:iCoseg、MSRC、CoSal2015、CoSOD3k、CoCA。

四、提出的方法

4.1 概述

  

  输入为一组图像和一个指向特定目标的表达式,输出为对应目标的像素 mask。对于负样本来说,输出 mask 为 0 mask。GRSer 包含四个模块:多模态编码器、三相 query 模块、热力图分层器、mask 预测器。

文本 & 图像编码器

  BERT 为文本编码器,将表达式编码为语言特征 L ∈ R C l \mathbf {L}\in\mathbb{R}^{C_l} LRCl,其中 C l {C_l} Cl 为语言特征的通道数量。同时在表达式前增加一个前缀 <no> 为反表达式,编码为反特征 L a n t i ∈ R C l \mathbf {L}^{anti}\in\mathbb{R}^{C_l} LantiRCl。采用 LAVT 中的视觉编码器来编码组内每个图像 x n , n = 1 , … , N x_n, n=1,\ldots,N xn,n=1,,N 的图像特征 V n ∈ R C v × H × W \mathbf {V}_n\in\mathbb{R}^{C_v\times H\times W} VnRCv×H×W,其中 N N N 为每个组中的图像数量, C v , H , W C_v,H,W Cv,H,W 分别为图像的通道数目、高、宽。

TQM & Heatmap Hierarchizer

  TQM 旨在捕捉语言-视觉和组内视觉-视觉语义关联,并产生热力图,这反应了语言和组内视觉特征的空间联系。这些热力图在热力图分层器中根据表达式响应的重要性被重排列。

Mask 预测器

  排序好的热力图和视觉特征 V n \mathbf{V}_n Vn 拼接在一起来获得三相特征 z n \text {z}_n zn,用于区分正负样本并预测分割 mask。在推理阶段,计算正距离 d p o s = d ( z n , L ) d^{p o s}=\text{d}(\text {z}_n,\mathbf L) dpos=d(zn,L) 和负距离 d n e g = d ( z n , L a n t i ) d^{neg}=\text{d}(\text {z}_n,\mathbf L^{anti}) dneg=d(zn,Lanti),其中 d ( ⋅ ) \text{d}(\cdot) d() 为欧式距离计算公式。当 d p o s + m < d n e g d^{p o s}+m<d^{n e g} dpos+m<dneg 时,图像 x n x_n xn 为正样本,其中 m m m 为阈值,然后将 z n \text {z}_n zn 送入解码器输出分割 mask;反之为负样本,赋值 0 mask。

4.2 Triphasic Query Module (TQM)

  图 3 右上角:首先生成一个语言激活图 M n l ∈ R H × W \mathbf{M}_n^l\in\mathbb{R}^{H\times W} MnlRH×W。具体来说:计算视觉特征 V n ∈ R C v × H W \mathbf{V}_n\in\mathbb{R}^{C_v\times HW} VnRCv×HW 和语言特征 L ′ = ω l ( L ) ∈ R C v \mathbf{L}'=\omega_l(\mathbf{L})\in\mathbb{R}^{C_v} L=ωl(L)RCv 间的余弦相似度,其中 ω l \omega_l ωl 1 × 1 1\times1 1×1 卷积层, C v C_v Cv 为输出通道数量。用公式表示为:
M n l = V n T ⋅ L ′ ∥ V n ∥ ∥ L ′ ∥ \mathbf{M}_n^l=\frac{\mathbf{V}_n^T\cdot\mathbf{L}'}{\|\mathbf{V}_n\|\|\mathbf{L}'\|} Mnl=Vn∥∥LVnTL
  将 M n l \mathbf{M}_n^l Mnl V n \mathbf{V}_n Vn 做逐元素乘法,输出的特征再沿着空间维度( H × W H\times W H×W) 做 mask 平均池化生成对应于图像 x n x_n xn 的原型 p n ∈ R C v p_{n}\in\mathbb{R}^{C_{v}} pnRCv,记为:
p n = avg ( M n l ⊙ V n ) p_n=\text{avg}(\mathrm{M}_n^l\odot\mathbf{V}_n) pn=avg(MnlVn)其中 M n l \mathrm{M}_n^l Mnl 广播到 V n \mathbf{V}_n Vn 相同尺寸, ⊙ \odot 为逐元素乘法。于是以这种方式产生一组原型: { p i } i = 1 N \left\{p_{i}\right\}_{i=1}^{N} {pi}i=1N,其中每个元素对应一组图像中的一幅照片。
  接下来,在当前图像 x n x_n xn 和组内原型中执行组内检索,这些原型作为专家来提供定位热力图:通过一对一的方式产生 N N N 个视觉激活热力图 M n v = { M n i v } i = 1 N \mathbf M_{n}^{v} =\{\mathbf{M}_{ni}^v\}_{i=1}^N Mnv={Mniv}i=1N
M n i v = V n T ⋅ p i ∥ V n ∥ ∥ p i ∥ \mathrm M_{ni}^v=\frac{\mathrm V_n^T\cdot p_i}{\|\mathrm V_n\|\|p_i\|} Mniv=Vn∥∥piVnTpi其中 n n n 为组内图像的索引, i i i 为组内原型的索引。

4.3 Heatmap Hierarchizer

  由于 TQM 生成的视觉激活热力图包含很多的负样本,且质量不太行,于是提出基于评估策略置信度的热力图分层器对热力图进行重排列。如下图所示:

在这里插入图片描述

  基于多模态的距离表示来定义评分标准:计算组内每个原型 { p i } i = 1 N \left\{p_{i}\right\}_{i=1}^{N} {pi}i=1N 和语言特征 L \mathbf L L 的欧式距离来得到正分数 { s i p o s } i = 1 N \{s_i^{pos}\}_{i=1}^N {sipos}i=1N 与 范语言特征的负分数 { s i n e g } i = 1 N \{s_i^{neg}\}_{i=1}^N {sineg}i=1N。于是,最小的 s i p o s s_i^{pos} sipos 表示原型 p i p_i pi 最接近目标,这意味着对应的热力图 M n i v \mathbf{M}_{ni}^v Mniv 最可靠,而最小的 s i n e g s_i^{neg} sineg 表示原型 p i p_i pi 最符合背景。然后分别根据相应的正负分数 s i p o s s_i^{pos} sipos s i n e g s_i^{neg} sineg 得到 N N N 个视觉主动激活图的正排行 R p o s R^{pos} Rpos 和负排行 R n e g R^{neg} Rneg。最后对 R p o s R^{pos} Rpos R n e g R^{neg} Rneg 求和得到最终的排行,并对 M n \mathbf{M}_n Mn 进行重排列:
M ‾ n v = rearrange ( M n v ∣ R p o s + R n e g ) \overline{\mathbf{M}}_n^v=\text{rearrange}\left(\mathbf{M}_n^v|R^{pos}+R^{neg}\right) Mnv=rearrange(MnvRpos+Rneg)其中 rearrange ( ⋅ ) \text{rearrange}(\cdot) rearrange() 表示逐元素或逐通道堆叠热力图。最后,这些热力图和视觉特征 V n \mathbf{V}_n Vn 拼接后得到三相特征 z n \mathbf{z}_n zn 用于 mask 的预测。

4.4 训练目标

负样本训练

  每组中设置正样本 x p o s x^{pos} xpos、负样本 x n e g x^{neg} xneg,比例为 1 : 1 1:1 1:1,训练目标有两项:三重阈值损失来强化模型识别负样本的能力;Cross-entropy 损失来优化模型的分割性能。

三重阈值损失

  三重阈值损失旨在使得锚框与正样本更加接近,与负样本更加远离。对于正样本 x p o s x^{pos} xpos 来说,三相特征 z n \text z_n zn 视为 anchor,语言特征 L \mathbf L L L a n t i \mathbf L^{anti} Lanti 被视为正样本和负样本。而对于负样本 x n e g x^{neg} xneg 来说, L a n t i \mathbf L^{anti} Lanti L \mathbf L L 分别被视为正样本和负样本。于是三重阈值损失构建如下:
L t r i = { max ⁡ ( d ( z n , L ) − d ( z n , L a p t i ) + m , 0 ) for x p o s max ⁡ ( d ( z n , L a n t i ) − d ( z n , L ) + m , 0 ) for x n e g g \mathcal{L}_{tri}=\begin{cases}\max\big(\mathrm{d}(\mathrm{z}_n,\mathrm{L})-\mathrm{d}(\mathrm{z}_n,\mathrm{L}^{apti})+m,0\big)&\text{for}x^{pos}\\ \max\big(\mathrm{d}(\mathrm{z}_n,\mathrm{L}^{anti})-\mathrm{d}(\mathrm{z}_n,\mathrm{L})+m,0\big)&\text{for}x^{negg}\end{cases} Ltri={max(d(zn,L)d(zn,Lapti)+m,0)max(d(zn,Lanti)d(zn,L)+m,0)forxposforxnegg

镜像训练策略

  在训练阶段,增加一组 L \mathbf L L L a n t i \mathbf L^{anti} Lanti 的映射,相应的 Ground truth(GT) 替代为背景 1 − Y 1-\mathbf Y 1Y Y \mathbf Y Y。Cross-entropy 损失应用在镜像训练上,用 L c e m i r r \mathcal{L}_{ce}^{mirr} Lcemirr 表示。

目标函数

  仅有正样本 x p o s x^{pos} xpos 用于计算 Cross-entropy 损失,而所有的正负样本都要用于计算三重阈值损失,于是总损失如下:
L = L c e ( Y ^ , Y ) + λ L c e m i r r ( Y ^ a n t i , 1 − Y ) + t T L t r i \mathcal{L}=\mathcal{L}_{ce}(\hat{\mathbf{Y}},\mathbf{Y})+\lambda\mathcal{L}^{mirr}_{ce}(\hat{\mathbf{Y}}^{anti},1-\mathbf{Y})+\frac{t}{T}\mathcal{L}_{tri} L=Lce(Y^,Y)+λLcemirr(Y^anti,1Y)+TtLtri其中 t t t T T T 为当前训练和总共训练的 epochs 数量; λ \lambda λ 为平衡镜像训练策略重要性的权重超参数, Y ^ \hat{\mathbf{Y}} Y^ 为表达式预测的 mask, Y ^ a n t i \hat{\mathbf{Y}}^{anti} Y^anti 为镜像训练策略中反表达式所指向的预测 mask。

五、提出的数据集

5.1 数据集亮点

  
在这里插入图片描述

5.2 构建步骤

  一方面从 Flickr 数据集中收集图像;另一方面,将目标关键词与场景词汇结合来输入到搜索引擎中爬取相关图像。之后对于每一个分组的图像,根据相关表达式进行标注。每个标注大概 3 分钟。

5.3 数据统计

  GRD 数据集包含图像:10578,106 个场景(组),每个组 100 张图像及 3 个表达式。总计316 个表达式,平均 5.9 个单词,31524 个正样本或负样本图像-文本对。

六、实验

6.1 数据和指标

  GRD、Co-SOD、RefCOCO、RefCOCO+、RefCOCOg。考虑到不同图像可能对应相同的句子,于是重构数据模式为:“one sentence vs. a group of referred images”,即 G-RefC, G-RefC+, and G-RefCg,都是随机从其他组的负样本中进行采样得到。重建后的数据集有 8717、8020、2451 个图像组,训练推理时的正负样本比例均为 1 : 1 1:1 1:1
  指标:mean intersection-over-union (mIoU)、mean absolute error (MAE)、maximum F-measure( F m a x F_{max} Fmax)、S-measure( S α S_{\alpha} Sα)、mean E-measur( S ξ S_{\xi} Sξ)。

6.2 实施细节

  Transformer 视觉编码器 Swin Transformer 初始化在 ImageNet-22K 预训练权重上,12 层的语言编码器 BERT,特征维度 C l = 768 C_l=768 Cl=768 C v = 512 C_v=512 Cv=512,AdamW 优化器,权重衰减 0.01,初始学习率 0.00005,80 epochs,batch_size=4,输入图像尺寸 416 × 416 416\times416 416×416,无数据增强,输入图像的组数 N = 8 N=8 N=8,三重阈值损失中的阈值 m = 1 m=1 m=1

6.3 与 SOTA 方法的比较

在 GRES 设置上的结果

在这里插入图片描述

在 RES 设置上的结果

  同上表 2。

在 Co-SOD 设置上的结果

在这里插入图片描述

6.4 消融实验

Triphasic Query Module (TQM)

在这里插入图片描述

Heatmap Hierarchizer (HMapHier)

在这里插入图片描述

Mirror Training (MirrorT)

  上表 5。

Triplet Margin Loss (TriLoss)

  上表 5。

七、结论

  本文提出基于 RES 的设置 Group-wise Referring Expression Segmentation (GRES),将 RES 拓展到一组关联图像上,引入了 GRD 数据集,提出了 Baseline 模型 GRSer,大量的实验表明文本提出的方法在 GRES、RES、Co-SOD 数据集上实现了 SOTA 的性能。

写在后面

  这篇文章并未落入之前的 RES 内,而是开拓了一种更加实用的数据集,就看中稿之后能不能推广开来了~

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

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

相关文章

OpenStreetMap实战

介绍 OpenStreetMap&#xff08;OSM&#xff09;是一个由志愿者创建并维护的免费和开源的地图数据库。其目的是为全球任何人提供可自由使用、编辑和分发的地图数据。OpenStreetMap数据库中的地理要素包括道路、建筑、河流、森林、山脉、公共设施等。由于OpenStreetMap是开放的…

数据结构初阶 —— 二叉树链式结构

目录 一&#xff0c;二叉树链式结构 二&#xff0c;二叉树的遍历&#xff08;四种&#xff09; 前序遍历 中序遍历 后序遍历 层序遍历 三&#xff0c;二叉树接口 四&#xff0c;试题 一&#xff0c;二叉树链式结构 普通二叉树的增删查改&#xff0c;意义不大&#xff1b…

JavaScript基础扫盲

博主简介&#xff1a;想进大厂的打工人博主主页&#xff1a;xyk:所属专栏: JavaEE初阶 本篇文章为大家带来JavaScript的学习&#xff0c;一图胜千言~~~ 目录 文章目录 1.1 JavaScript (简称 JS) 1.2 JavaScript发展历史 1.3 JavaScript运行过程 二、JavaScript的基础语法 2.1 …

Linux内核源码分析-进程调度(五)-组调度

出现的背景 总结来说是希望不同分组的任务在高负载下能分配可控比例的CPU资源。为什么会有这个需求呢&#xff0c;假设多用户计算机系统每个用户的所有任务划分到一个分组中&#xff0c;A用户90个任务&#xff0c;而B用户只有10个任务&#xff08;这100个任务假设都是优先级一…

物联网手势控制小车所遇问题与解决方案

LCD1602无法显示问题 问题描述&#xff1a;按照开源社区教程完成LCD1602驱动显示程序的编写&#xff0c;成功点亮屏幕&#xff0c;开启背光&#xff0c;但无法观察到显示数据。 分析过程与解决方案&#xff1a; 1.是否IIC地址不对 使用以下代码扫描IIC总线上的设备&#xf…

Go学习圣经:队列削峰+批量写入 超高并发原理和实操

说在前面&#xff1a; 本文是《Go学习圣经》 的第二部分。 第一部分请参见&#xff1a;Go学习圣经&#xff1a;0基础精通GO开发与高并发架构&#xff08;1&#xff09; 现在拿到offer超级难&#xff0c;甚至连面试电话&#xff0c;一个都搞不到。 尼恩的技术社群中&#xf…

K近邻算法实现红酒数据集分类

目录 1. 作者介绍2. K近邻算法介绍2.1 K基本原理2.2 算法优缺点 3. KNN红酒数据集分类实验3.1 获取红酒数据集3.2 KNN算法3.3 完整代码 4. 问题分析参考链接&#xff08;可供参考的链接和引用文献&#xff09; 1. 作者介绍 路治东&#xff0c;男&#xff0c;西安工程大学电子信…

面试问题汇总

最近面试了几家公司&#xff0c;对问到的问题汇总一下。 Unity 是左手坐标系还是右手坐标系? 这个题靠记忆答的答错了&#xff0c;是左手坐标系。 大拇指指的方向是X轴&#xff0c;食指指的方向是Y轴方向&#xff0c;中指指的方向Z轴方向。 场景中游戏物体Activity为false,G…

C语言字符串函数和内存函数的介绍与模拟实现

0.前言 C语言中对字符和字符串的处理很是频繁&#xff0c;但是C语言本身是没有字符串类型的&#xff0c;字符串通常放在 常量字符串 中或者 字符数组 中。 字符串常量 适用于那些对它不做修改的字符串函数. 1.字符串函数介绍与模拟实现 C语言本身就带有一些库函数&#xff0c;所…

研发工程师玩转Kubernetes——CPU配额

在一个Pod中&#xff0c;可以有多个容器&#xff0c;比如一个主要业务容器和若干辅助业务容器。如果辅助业务容器内程序有问题&#xff0c;导致占用了大量的CPU资源&#xff0c;进而影响了主要业务容器的执行效率&#xff0c;那就需要进行干涉了。本节我们将使用“资源配额”来…

Edgedetect

边缘检测&#xff0c;检测上升沿 对于 8 位矢量中的每个位&#xff0c;检测输入信号何时从一个时钟周期中的 0 变为下一个时钟周期的 1&#xff08;类似于正边沿检测&#xff09;。输出位应在发生 0 到 1 转换后设置周期。 以下是一些示例。为清楚起见&#xff0c;in[1] 和 pe…

Jenkins+GitLab+Docker搭建前端自动化构建镜像容器部署(无本地证书,映射版本)

前言 &#x1f680; 需提前安装环境及知识点&#xff1a; 1、Docker搭建及基础操作 2、DockerFile文件描述 3、Jenkins搭建及基础点 &#x1f680; 目的&#xff1a; 将我们的前端项目打包成一个镜像容器并自动发布部署&#xff0c;可供随时pull访问 一、手动部署镜像及容器 1…

【Linux】线程分离 | 线程库 | C++调用线程 | 线程局部存储

文章目录 1. 线程分离1. 为什么要线程分离&#xff1f;2. 具体使用3. 为什么有时候分离在调用join 会正常运行&#xff1f; 2. 如何理解线程库&#xff1f;如何理解 先描述 在组织&#xff1f; 3. C中使用多线程4. 线程局部存储局部变量全局变量 1. 线程分离 1. 为什么要线程分…

服务器虚拟化部署

服务器虚拟化部署 1、背景2、目的3、环境4、部署4.1、部署VMware ESXi4.1.1、准备工作4.1.2、部署ESXi4.1.3、配置ESXi4.1.4 、部署虚拟机 1、背景 项目上利旧9台服务器&#xff0c;项目需要使用15台服务器&#xff0c;外购已经没有项目硬件采购预算&#xff0c;只能从目前的…

自定义HikariCP连接池

文章目录 一、简介1、概述2、地址 二、配置参数1、Hikari原生参数2、Springboot中参数 三、springboot中使用四、自定义数据源1、各模块2、完整代码3、多数据源 五、多数据源dynamic中使用1、简介2、引入依赖3、参数配置 六、XMind整理 一、简介 1、概述 官方解释&#xff1a…

zabbix 自动发现与自动注册、部署 zabbix 代理服务器及部署 Zabbix 高可用集群

目录 一、zabbix 自动发现二、zabbix 自动注册&#xff08;对于 agent2 是主动模式&#xff09;三、部署 zabbix 代理服务器四、部署 Zabbix 高可用集群五、Zabbix 监控 Windows 系统六、Zabbix 监控 java 应用七、Zabbix 监控 SNMP 一、zabbix 自动发现 zabbix 自动发现&…

Nautilus Chain开启全球行,普及Layer3概念加速其采用

在去年&#xff0c;在 2022 年&#xff0c;Vitalik 进一步提出了 Layer3 的概念与早期形态&#xff0c;期盼弥补目前链体系存在的不足&#xff0c;并为 Layer3 提出了三大目标&#xff0c;即Layer2 用于扩展&#xff0c;Layer3 用于定制功能&#xff0c;如隐私&#xff1b;Laye…

【C++】哈希表特性总结及unordered_map和unordered_set的模拟实现

✍作者&#xff1a;阿润菜菜 &#x1f4d6;专栏&#xff1a;C 文章目录 前言一、哈希表的特性 - 哈希函数和哈希冲突1 哈希函数2. 哈希冲突 二、闭散列的实现 -- 开放地址法1. 定义数据结构2.insert()3.Find()4. Erase()5.仿函数处理key值不能取模无法映射 --- BKDRHash 三、开…

【Linux系列P4】Linux需要什么?编辑器?软件包?一文帮你了解掌握 [yum][vim]———基础开发工具篇

前言 大家好&#xff0c;这里是YY的Linux系列part4&#xff1b;本章主要内容面向接触过Linux的老铁&#xff0c;主要内容含【学习yum工具&#xff0c;进行软件安装】【拓展yum源安装】【掌握vim编辑器使用&#xff0c;基本命令】【命令集】【懒人配置文件安装教程】 在下一章节…

Java高并发编程—可见性与有序性原理

原子性、可见性和有序性是并发编程所面临的三大问题。 Java通过CAS操作已解决了并发编程中的原子性问题&#xff0c;本章为大家介绍Java如何解决剩余的另外两个问题——可见性和有序性。 CPU物理缓存结构 由于CPU的运算速度比主存&#xff08;物理内存&#xff09;的存取速度…