聚类系列 (二)——HDBSCAN算法详解

news2025/1/11 1:52:50

在进行组会汇报的时候,为了引出本研究动机(论文尚未发表,暂不介绍),需要对DBSCAN、OPTICS、和HDBSCAN算法等进行详细介绍。在查询相关资料的时候,发现网络上对于DBSCAN算法的介绍非常多与细致,但是对于OPTICS或者HDBCCAN算法的介绍要么是直接照抄一个在线文档的算法介绍,要么就是未能完整的讲出该算法的原理。为了能够给大家提供一个都能看懂的HDBSCAN算法介绍,于是有了该篇文章。

下面进入关于HDBSCAN算法的正文内容,主要包括:HDBSCAN算法提出的动机、HDBSCAN算法的原理、HDBSCAN算法的优缺点、HDBSCAN算法的优缺点、HDBSCAN算法的实例介绍等。

文章目录

  • 从DBSCAN到HDBSCAN
    • DBSCAN
    • OPTICS
      • OPTICS 算法的优化与原理
  • HDBSCAN
      • HDBSCAN 的引入
    • HDBSCAN 算法的原理与具体步骤
      • 1. 样本点互达距离计算(距离空间变换)
      • 压缩层次聚类树
      • 提取稳定簇(打标签)
    • HDBSCAN算法的优势
    • HDBSCAN算法的不足
  • 总结
  • Reference

从DBSCAN到HDBSCAN

DBSCAN

为了理解HDBSCAN,首先需要理解DBSCAN算法的原理。

DBSCAN(Density-based Spatial Clustering of Applications with Noise)是一种基于密度扩展的聚类算法。顾名思义,从该算法名称中可以发现,该算法的核心思想在于样本密度的定义以及如何基于样本的密度扩展类簇。

DBSCAN算法认为类簇是由一系列被稀疏区域分隔开来的密集区域组成的。

该算法通过两个关键参数:Eps(邻域半径)和MinPts(邻域内包含的最小样本数量),定义样本的密度。

  • 如果一个样本点在用户指定的邻域半径中,包含至少MinPts个样本,那么该样本被定义为一个**核心对象**。核心样本邻域内的其他样本被称为直接可达对象 。如何直接可达对象满足Eps和MinPts参数约束,其也是一个核心对象。核心对象可以用来吸引其他对象加入同一个簇。

  • 对于位于核心对象邻域内、但是不满足核心对象定义的样本,被称为边界对象

  • 既不是核心对象,也不是边界对象的样本则被称为噪声点。通过该定义,可以发现DBSCAN算法能够识别噪声点的原因。

DBSCAN算法的原理就是通过寻找核心对象,并不断扩展加入核心对象邻域内的样本(判断是否为核心对象,然后继续扩展),从而形成一个簇。不在任何核心对象邻域内的样本且无法形成核心对象的样本则被视为异常值,不被分配到任何簇。

DBSCAN算法能够发现任意形状和大小的簇,并且能够识别噪声,对噪声具有很强的鲁棒性。但是同时,由于这两个参数是全局的,导致DBSCAN算法无法发现不同密度(尤其是密度差异较大、并且与密集簇邻近分布)的簇。

此外,这两个参数的设置依赖于对数据集的先验认知(也可以使用网格搜索等方法进行参数优化)。

OPTICS

为了克服DBSCAN算法参数设置的局限性,学者Ankerst等提出了OPTICS(Ordering Points to Identify the Clustering Structure)算法。OPTICS 是 DBSCAN 的一种改进版本,它不再需要通过固定的全局参数(Eps 和 MinPts)来定义密度,而是通过一种排序方式来揭示数据集中的聚类结构,从而解决DBSCAN算法参数设置的困难。

OPTICS 算法的优化与原理

OPTICS 的核心思想是通过记录每个点的 核心距离(Core Distance)和 可达距离(Reachability Distance),以一种可视化的方式展示数据的聚类结构。具体来说:

  1. 核心距离 (Core Distance):

    • 对于一个点,如果其邻域内有足够的点(至少 MinPts 个点),则核心距离定义为该点到其邻域内第 MinPts 个最近点的距离(点到邻域内点的最大距离)。
    • 如果一个点的邻域内不足 MinPts 个点,则核心距离未定义Undefined(表示为无穷大)。
  2. 可达距离 (Reachability Distance):

    • 对于两个点 A 和 B,点 B 相对于点 A 的可达距离是点 A 的核心距离和点 A 到点 B 的欧氏距离之间的较大值。

    • 直观上,可达距离表示一个点从另一个点“被密度连接”的难易程度,量化了两个样本点之间被密集区域所连接的最大距离。可达距离越小,说明两个点之间连线经过的稀疏区域越小,它们之间的密集程度越高。

  1. 数据排序:
  • OPTICS 通过一个类似于 DBSCAN 的过程对数据进行排序,优先处理核心距离较小的点(即更密集区域的点),将点按照密度从高到低进行访问。
  • 每个点在被访问时,会更新其邻域中未访问点的可达距离。
  1. 密度聚类结构:
  • OPTICS 不直接输出聚类结果,而是生成一个可视化的“可达距离图”(Reachability Plot)。通过观察图中呈现的“山谷”(低可达距离的区域),可以识别不同密度的簇。

OPTICS算法的优点包括:不需要提前固定Eps参数,可以通过核心距离和可达距离动态调整密度阈值,能够发现不同密度的簇。其次,与 DBSCAN 类似,OPTICS 也能够识别噪声点(即在可达距离图中位于高可达距离的点)。

然而,OPTICS算法也存在一定的局限性,主要体现在:**复杂度较高(**需要维护可达距离和排序)。其次,簇提取困难(OPTICS输出一个有序的点序列,不显式给出聚类结果,仍需要额外的步骤和方法从序列中提取真正的簇)。参数敏感性(仍然需要指定参数minPts,其选择对最终聚类结果有很大影响,尤其是在处理高维数据或密度分布不均匀的数据集时)。可达距离的局限性(不对称,仅考虑了从一个点到另一个点的距离)

HDBSCAN

HDBSCAN 的引入

为了进一步改进密度聚类算法的灵活性和效率,学者们提出了 HDBSCAN(Hierarchical Density-Based Spatial Clustering of Applications with Noise)算法。HDBSCAN 是 DBSCAN 的一种层次化扩展,结合了密度聚类和层次聚类的思想,其核心在于通过一个密度分层树(Density Hierarchy Tree)来表征数据的聚类结构。

  1. 密度定义的改进:
    • HDBSCAN使用相对密度的概念,而不是固定的绝对密度阈值(如DBSCAN的固定Eps参数)。相对密度考虑了数据点与其核心距离(core distances)的比较,而不是单纯的邻域半径,这使得算法能够自动适应不同区域的密度差异。
    • 通过计算互达距离(Mutual Reachability Distance)来定义点之间的密度连接关系,而不是简单的欧式距离。互达距离更加稳健(保持密集区域的数据点密度不变,降低稀疏区域的数据点的密度),能过更好处理不同密度的区域,从而识别出不同密度的轨迹。(互达距离其实是对OPTICS算法中可达距离的一种改进,同时考虑两个样本点的局部点分布)
  2. 密度层次化聚类:
    • HDBSCAN 通过对密度逐步降低的过程进行跟踪,生成一个密度分层树。
    • 在密度分层树中,叶子节点代表高密度区域的簇,而根节点表示整个数据集。
  3. 自动化簇提取:
    • 与 OPTICS 需要手动观察可达距离图不同,HDBSCAN 提供了一个自动化的簇提取方法,通过定义一个稳定性指标(Stability)来评估每个簇的持久性,并自动选择最稳定的簇作为最终聚类结果。

HDBSCAN 算法的原理与具体步骤

关于HDBSCAN算法的原理与步骤,目前网络上最出名的两个博客分别是:https://www.biaodianfu.com/hdbscan.html和https://hdbscan.readthedocs.io/en/latest/how_hdbscan_works.html,前者其实是后者的中文版。网络上的其他博客大多也会这两个内容的搬运,本文在撰写的过程中也难免会借鉴其中的内容,但是会加上自己对该算法的思考以及更加详细的原理讲解,确保提供一个大家都能看到的HDBSCAN原理介绍博客

1. 样本点互达距离计算(距离空间变换)

在开源的各种聚类算法的代码库中,我们可以发现有一个参数metric,该参数的可取值包括:Euclidean, pre-computed 等。其中pre-computed表示提前计算好样本数据之间的距离,直接输入一个 N ∗ N N*N NN距离矩阵 (其中 N N N是样本数据的数量)。该距离可以是欧式距离,网络距离,曼哈顿距离等。

在HDBSCAN算法中,需要将输入的预先计算好的原始距离矩阵(如欧式距离)进行一个距离空间转换(原始距离空间转换为互达距离(mutual reachability distance)空间)。距离空间转换旨在更好地识别数据中的密集区域和稀疏区域。

距离空间转换需要解决以下两个问题:

  • 密度差异问题:在同一数据集中,可能存在密度相差很大的聚类。简单使用原始距离可能会导致密度较低的聚类被忽略。距离空间转换可以"放大"稀疏区域,使得不同密度的聚类能够被更好地识别。
  • 噪声数据识别问题:噪声数据通常分布较为稀疏,与聚类之间的距离较远。使用原始距离可能难以区分噪声与真实聚类。距离空间转换通过"压缩"密集区域,从而使噪声点与聚类之间的距离差异更加明显,有助于识别噪声数据。

HDBSCAN算法采用了一种称为互达距离(mutual reachability distance)的距离空间转换方式。具体来说,对于任意两个样本点 p p p q q q,首先计算他们各自的核心距离,反应其局部密度:

  • 计算点 p p p到其所有 k k k近邻点的核心距离,取最大值作为 p p p的核心距离 c o r e k ( p ) core_k(p) corek(p)
  • 计算点 q q q到其所有 k k k近邻点的核心距离,取最大值作为 q q q的核心距离 c o r e k ( q ) core_k(q) corek(q)

然后取他们的核心距离和原始距离之间的最大值作为互达距离。可以看出,互达距离“放大了"稀疏区域的距离,同时"压缩"了密集区域内的距离。这种转换能更好地反映数据本身的密度分布特征,有利于后续的聚类分析。
d m r e a c h − k ( p , q ) = m a x { c o r e k ( p ) , c o r e k ( q ) , d ( p , q ) } d_{mreach-k}(p,q)=max\{{core_k(p),core_k(q),d(p,q)}\} dmreachk(p,q)=max{corek(p),corek(q),d(p,q)}

29. 密度聚类方法实现与应用— 动手实战人工智能AI By Doing
### 2. 构建最小生成树(Minimum Spanning Tree,MST)

在新的距离空间中,基于数据点之间的互达距离构建一个最小生成(MST)。每个节点代表一个数据点,边的权重为两个节点之间的互达距离。

数据点之间的互达距离矩阵首先会形成一个加权的完全连通图(图上任意两个节点都是连通的)。为了有效地表示数据点的密度连接关系并降低计算复杂度,需要从完全连通图中提取一个最小生成树(MST)。

最小生成树提供了一种划分数据的自然方式。通过移除MST中权重最大的边,整个图就被分割成了两个连通分量,对应着两个密集的数据簇。重复这个过程,移除下一个最大权重的边,整个图就被进一步分割成更多的连通分量。这个连续的裁剪过程会产生一个分层的簇结构,从而揭示出数据的层次聚类关系。

在具体实现中,可以选择Prime算法构建生成树。Prime算法的原理为:

  • 选择一个任意节点作为起始节点,并将其添加到MST中。

  • 创建一个优先队列Q,用于存储与MST中节点相邻的边,并按照边的权重(互达距离)升序排列。

  • 将起始节点的所有邻边添加到Q中。

  • 重复以下步骤,直到MST中包含 n-1 条边:

    • Q中取出权重最小的边。

    • 如果该边连接的另一个节点不在MST中,则将该边和节点添加到MST中,并将该节点的邻边添加到Q中。

生成的MST包含了所有数据点,并且边的权重总和最小。这棵树保留了数据点之间最重要的密度连接信息,并为后续的层次聚类提供了基础。

注意:MST可能不是唯一的,如果有多个权重相同的最小生成树,算法会返回其中一个。

下图给出了一个简单的构建的最小生成树的示例:[在这里插入图片描述](https://i-

### 构建层次聚类树

基于最小生成树构建层次聚类树(Hierarchy Tree)是HDBSCAN算法的核心步骤。最小生成树的每个节点表示一个数据点,边的权重表示数据点之间的互达距离。为了生成层次聚类树,可以按照如下步骤:

  • 初始化:将 MST 中的每条边按照其权重(即两点之间的可达距离)排序。

  • 构建层次结构:初始化一个森林,每个数据点都是一个独立的簇。然后便利排序后的MST,从权重最小的边开始,逐步添加边到聚类树中。每当添加一条边时,都会有两种可能情况:

    • 该边连接的两个点属于两个不同的簇,则将这两个簇合并为一个新簇;
    • 该边连接的两个点在同一个簇内,则不进行合并操作。

    重复这个过程,直到遍历完所有的边,得到一个包含多层次结构的层次树结构。

    如下的GIF图是基于上述示例的最小生成树构建层次聚类树的动态过程。
    在这里插入图片描述

根据如图所示的层次聚类树,为了得到不同的簇,我们可以直接画一条水平线将层次树切分为不同的簇(其实就是根据一个单一的互达距离的阈值将层次树分为不同的子树,每个子树表示一个簇),如下图所示。

但是这样根据一个全局、单一的互达距离阈值,存在以下问题:

  • 无法处理不同密度的簇。由于使用了全局阈值,在密集区域可能会将不同的簇合并在一起,而在稀疏区域可能会将本应属于同一簇的点分割开来。
  • 噪声点可能会被错误地划分到某个簇中。全局阈值无法很好地区分真正的簇和噪声点。
  • 无法识别层次结构中最稳定的簇 - 某些簇可能在较宽的距离范围内都保持稳定,而另一些簇可能仅在特定距离下才显著。单一阈值无法捕获这种差异。

因此,我们需要一个更加稳健的方法从构建的聚类层次结构中提取簇。

压缩层次聚类树

在层次聚类树构建完成后,需要进行树的压缩,即将一颗大的层次树压缩为多个小的子簇结构。

在压缩树的过程中,HDBSCAN定义了一个参数:minimum cluster size,用于控制层次聚类树的拆分,这是一个自顶向下的过程。具体来说:

  • ① 从层次树的根节点开始,将整个数据集视为一个大簇。
  • ② 对于当前簇,如果其包含的数据点数量小于minimum cluster size,则将其标记为"噪声簇",不予考虑。
  • ③ 如果当前簇的大小大于或等于minimum cluster size,则进一步检查它的子节点(子簇):
    • 如果所有子簇的大小都小于minimum cluster size,则将当前簇标记为一个稳定簇,保留下来。
    • 如果存在子簇的大小大于或等于minimum cluster size,则对这些大的子簇递归执行步骤②和③,继续向下拆分。
  • ④ 重复步骤②和③,直到没有可拆分的大簇为止。
  • 最终,层次树被拆分成多个互不相交的子树,每个子树的根节点都minimum cluster size的约束。

通过这种自顶向下的拆分策略,HDBSCAN逐步将原始的整体层次树压缩为规模较小、互不重叠的子树结构。每个子树代表一个相对稳定、大小合理的簇。同时,噪声簇和过小的簇被剔除。

通过这种方式,HDBSCAN能够自动确定合适的簇数量,而不需要人为指定簇数或其他聚类参数。生成的簇的形状、大小和密度也可以是任意的。

该压缩过程的关键是minimum cluster size参数,它控制着簇被切分或保留的阈值。较大的值会导致更大规模、更扁平的簇,较小的值会产生更多层次细节。因此,可以根据具体应用场景调整该参数来获得理想的聚类粒度。

提取稳定簇(打标签)

虽然通过上述压缩树的方式,我们将一颗大的层次树分解为多个小的子簇(每个子簇满足minimum cluster size约束),但是这样会忽略簇的稳定性与生命周期,因为我们希望所提取的簇不仅能够稳定存在而且具有更长的生命周期,能在较大密度范围内保持簇的稳定性。为了达到这目标,HDBSCAN引入了对簇稳定性与生命周期的考量。

具体来说,HDBSCAN 引入两个重要概念:簇的稳定性和用于度量簇稳定性的指标 λ {λ} λ

λ {λ} λ被定义为数据点之间互达距离的倒数,即 λ = 1 / d i s t a n c e λ=1/distance λ=1/distance。基于 λ {λ} λ,HDBSCAN通过引入 λ b i r t h {λ_{birth}} λbirth λ d e a t h {λ_{death}} λdeath λ p {λ_p} λp 对簇的稳定性和生命周期进行了量化,其中:

  • λ b i r t h {λ_{birth}} λbirth 指使得当前簇作为独立簇存在的最大 λ {λ} λ值。
  • λ d e a t h {λ_{death}} λdeath 指使当前簇不再作为一个独立簇(簇的消失)、开始分裂为更小子簇的λ值,即当前簇失去独立性的密度阈值。这个值表示在该密度水平下,簇不再作为一个独立的实体存在,而是被分解为更小的子簇。
  • λ p {λ_p} λp 则是指簇中数据点 p p p "脱离簇’'时的 λ {λ} λ值。对于簇内的每个点 p p p,其 λ λ λ 值介于 λ b i r t h {λ_{birth}} λbirth λ d e a t h {λ_{death}} λdeath λ p {λ_p} λp实际上反映了点 p p p到所在簇的最小“边缘”距离。如果 p p p接近 λ b i r t h {λ_{birth}} λbirth,说明点 p p p 处于簇的内部,离群倾向较小;如果 λ p {λ_p} λp接近 λ d e a t h {λ_{death}} λdeath,说明点 p p p 处于簇的边缘,离群倾向较大,如果 λ p {λ_p} λp小于 λ d e a t h {λ_{death}} λdeath(密度与距离相反,距离越大,密度相对越小),说明点 p p p 已经不再属于该簇。 λ p {λ_p} λp
    值可以作为评估点 p p p 相对于簇的内外倾向的一个度量标准。HDBSCAN利用了这一度量,在提取稳定簇时,保留 λ p {λ_p} λp值较小的内部点,剔除 λ p {λ_p} λp值较大的边缘噪音点,从而获得相对稳定的簇结构。

因此,簇的稳定性(stability)可以定义为:
s c l u s t e r = ∑ p ∈ c l u s t e r ( λ p − λ b i r t h ) s_{cluster}=\sum_{p∈cluster} (λ_p-λ_{birth}) scluster=pcluster(λpλbirth)
当所有点的 λ p {λ_p} λp都等于 λ d e a t h {λ_{death}} λdeath时, s c l u s t e r = 0 s_{cluster}=0 scluster=0, 表示簇内所有点具有相同的密度水平。否则 s c l u s t e r s_{cluster} scluster小于0,因为 λ d e a t h ≤ λ p {λ_{death}}≤{λ_p} λdeathλp λ b i r t h {λ_{birth}} λbirth,所以 s c l u s t e r ≤ 0 s_{cluster}≤0 scluster0

压缩簇是自顶向下分裂的过程,提取簇则是自底向上合并簇和过程。

具体提取的过程如下:

① 自底向上遍历压缩树

② 对每个节点:

  • 计算该节点的稳定性 s c l u s t e r s_{cluster} scluster;
  • 计算其直接子节点的稳定性总和;
  • 比较这两个值,选择稳定性更大的方案
    • 当遇到“子簇稳定性之和 > 父簇自身稳定性”的情况时 (分裂成两个簇更好) :将保留子簇们作为独立的平坦簇输出,而放弃父簇(不会作为一个独立的簇输出)。
      • 该簇的稳定性被设置为子簇稳定性之和
      • 该簇的所有子簇保留"选定"状态。
    • 当遇到“父簇稳定性 >= 子簇稳定性之和”的情况时 (两个子簇合并为一个簇更好) :将保留父簇作为平坦簇输出,而放弃子簇们(不会被单独输出)。
      • 该簇被"选定";
      • 该簇所有子簇的"选定"状态被取消;

③ 遍历完成后,根节点处的"选定"簇就是要输出的平坦簇集合

这样的策略可以确保输出的每个平坦簇不仅满足最小簇大小,而且具有良好的生命周期和stability,即规模合理、内部紧密且在较大密度范围内保持稳定(稳定持久的簇结构)。同时,它避免了将稳定性较低的簇不适当地保留或合并。每个输出的平坦簇代表一个在全局上相对分离且内部相对紧凑的数据模式。

  • 提取的簇满足最小尺寸要求
  • 簇具有足够的稳定性
  • 避免过度分裂或不当合并
  • 保留数据中最显著的层次结构

HDBSCAN算法的优势

  1. HDBSCAN是一种基于密度的层次聚类算法,能够自动确定簇的数量,不需要提前指定簇的数量或者借助其他手段评估可能的簇数量。
  2. 与DBSCAN一样,能够发现任意形状的簇,但是相比DBSCAN算法无法区分不同密度的簇(尤其是密度差异较大的簇),HDBSCAN算法能够处理密度分布差异较大的数据集。
  3. 不同于 OPTICS,HDBSCAN 提供了自动的簇提取机制,无需手动调整参数或观察可达距离图。
  4. 更少的参数依赖,HDBSCAN 只需要一个主要参数 MinClusterSize(最小簇大小),易于设置。

HDBSCAN算法的不足

虽然HDBSCAN在处理不同形状和密度的簇方面表现出色,但也存在一些局限性:。

  1. **参数敏感性: **HDBSCAN 的性能仍受 min_cluster_sizemin_samples 参数的影响。min_cluster_size 控制最小簇的大小,min_samples 影响单个点的密度估计。不合适的参数设置可能导致识别出过少或过多的簇,或者产生不符合预期的簇结构。
  2. 计算复杂度: HDBSCAN 需要构建层次聚类树并计算每个点的核心距离,这在大型数据集上可能非常耗时。虽然有一些优化策略可以提高计算效率,但在大规模数据场景下,HDBSCAN 的计算成本仍然较高。

总结

DBSCAN、OPTICS 和 HDBSCAN 都是基于密度的聚类算法,它们在处理复杂数据分布、发现任意形状簇和识别噪声点方面表现良好。DBSCAN 是密度聚类的基础算法,OPTICS 改进了其对不同密度簇的适应性,而 HDBSCAN 进一步结合了层次聚类的思想,并提供了自动化的簇提取方法,适用于更广泛的场景。

Reference

[1] Ester M, Kriegel H P, Sander J, et al. A density-based algorithm for discovering clusters in large spatial databases with noise[C]//kdd. 1996, 96(34): 226-231.

[2] Campello R J G B, Moulavi D, Sander J. Density-based clustering based on hierarchical density estimates[C]//Pacific-Asia conference on knowledge discovery and data mining. Berlin, Heidelberg: Springer Berlin Heidelberg, 2013: 160-172.

[3] Ankerst M, Breunig M M, Kriegel H P, et al. OPTICS: Ordering points to identify the clustering structure[J]. ACM Sigmod record, 1999, 28(2): 49-60.

[4] Schubert E, Sander J, Ester M, et al. DBSCAN revisited, revisited: why and how you should (still) use DBSCAN[J]. ACM Transactions on Database Systems (TODS), 2017, 42(3): 1-21.

[5] https://hdbscan.readthedocs.io/en/latest/how_hdbscan_works.html#condense-the-cluster-tree

[6] https://www.biaodianfu.com/hdbscan.html

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

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

相关文章

零基础 监控数据可视化 Spring Boot 2.x(Actuator + Prometheus + Grafana手把手) (上)

一、安装Prometheus Releases prometheus/prometheus GitHubhttps://github.com/prometheus/prometheus/releases 或 https://prometheus.io/download/https://prometheus.io/download/ 1. 下载适用于 Windows 的二进制文件: 找到最新版本的发布页面&#xf…

解决Qt打印中文字符出现乱码

在 Windows 平台上,默认的控制台编码可能不是 UTF-8,这可能会导致中文字符的显示问题。 下面是在 Qt 应用程序中设置中文字体,并确保控制台输出为 UTF-8 编码: 1. Qt 应用程序代码 在 Qt 中,我们可以使用 QApplic…

PDFelement 特别版

Wondershare PDFelement Pro 是一款非常强大的PDF编辑软件,它允许用户轻松地编辑、转换、创建和管理PDF文件。这个中文特别版的软件具有许多令人印象深刻的功能,PDFelement Pro 提供了丰富的编辑功能,可以帮助用户直接在PDF文件中添加、删除、…

SpringBoot-Web入门-入门程序

1.如何创建一个springBoot-Web工程? 实战演示: 新建一个模块,找到Spring Boot选项 点击下一步之后,选择勾选对应的依赖。我这里勾选的是web下的Spring Web 创建完毕之后,在src的main下的java对应的包下创建一个Contro…

从光子到图像——相机如何捕获世界?

引言 你是否想过为何我们按一下相机快门就可以将眼前广袤多彩的世界显示于一个小小的相机屏幕上?本期推文中将带着大家重现从光子转换为电子、电子转换为图像中数字驱动值的整个流程。 ▲人们通过相机捕获眼前的场景 从光子到电子的转换 光线首先通过光学镜头进入相…

《机器学习》——贝叶斯算法

贝叶斯简介 贝叶斯公式,又称贝叶斯定理、贝叶斯法则,最初是用来描述两个事件的条件概率间的关系的公式,后来被人们发现具有很深刻的实际意义和应用价值。该公式的实际内涵是,支持某项属性的事件发生得愈多,则该属性成…

【非常详细】TCP/IP协议详解

一、TCP/IP简介 TCP/IP(传输控制协议/互联网协议)是一种用于连接网络设备的协议族,广泛应用于互联网和局域网中。它提供了在不同类型的网络上进行通信的标准和方法。 二、TCP/IP模型 TCP/IP在数据包设计上采用封装和分用的策略,…

Nginx代理同域名前后端分离项目的完整步骤

前后端分离项目,前后端共用一个域名。通过域名后的 url 前缀来区别前后端项目。 以 vue php 项目为例。直接上 server 模块的 nginx 配置。 server{ listen 80; #listen [::]:80 default_server ipv6onlyon; server_name demo.com;#二配置项目域名 index index.ht…

C++中的表达式

文章目录 算数操作符位操作符bitset对象或整型值的使用将位移操作符用作IO 赋值操作符赋值操作符的右结合性赋值操作具有低优先级 自增和自减操作符条件操作符sizeof操作符优先级new和delete表达式类型转换何时发生隐式转换显示转换旧式强制类型转换 C中的表达式由一个或多个操…

WebSocket 测试入门篇

Websocket 是一种用于 H5 浏览器的实时通讯协议,可以做到数据的实时推送,可适用于广泛的工作环境,例如客服系统、物联网数据传输系统, 基础介绍 我们平常接触最多的是 http 协议的接口,http 协议是请求与响应的模式&…

海外招聘丨 弗拉瑞克商学院—博士研究员:智能家居技术业务和能源管理中的数据分析和人工智能

雇主简介 Vlerick 是一所领先的国际商学院……与众不同。是的,我们提供完全认可的世界一流教育课程,将理论知识和实践见解完美结合。是的,我们是一家领先的学术机构,拥有创新和独立研究的悠久传统。是的,我们拥有国际…

NUTTX移植到STM32

STM32移植NUTTX 1. Ubuntu下搭建开发环境1.1 先决条件1.2 下载 NuttX1.3 使用Make 进行编译1.4 烧录运行 2.通过NUTTX点亮LED2.1 部署操作系统2.2 修改配置文件2.3 编译运行程序 开发板:DshanMCUF407 官方开发文档:安装 — NuttX latest 文档 参考文档&…

Redis 优化秒杀(异步秒杀)

目录 为什么需要异步秒杀 异步优化的核心逻辑是什么? 阻塞队列的特点是什么? Lua脚本在这里的作用是什么? 异步调用创建订单的具体逻辑是什么? 为什么要用代理对象proxy调用createVoucherOrder方法? 对于代码的详细…

Python 中的错误处理与调试技巧

💖 欢迎来到我的博客! 非常高兴能在这里与您相遇。在这里,您不仅能获得有趣的技术分享,还能感受到轻松愉快的氛围。无论您是编程新手,还是资深开发者,都能在这里找到属于您的知识宝藏,学习和成长…

关于腾讯4K算法搭建使用

准备国内服务器一台,轻量服务器请尽量开全端口安装linux,centos7.6-7.9系统,记住纯净系统,然后安装宝塔宝塔安装环境为nginx1.24,7.2(PHP版本没有要求),Mysql5.7(没有要求) 准备活动完毕!!! 上传…

工艺参数优化、工程设计优化!GRNN神经网络+NSGAII多目标优化算法(Matlab)

目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.GRNN神经网络NSGAII多目标优化算法,工艺参数优化、工程设计优化(Matlab完整源码和数据) 多目标优化是指在优化问题中同时考虑多个目标的优化过程。在多目标优化中,通…

【Rust自学】11.6. 控制测试运行:并行和串行(连续执行)测试

喜欢的话别忘了点赞、收藏加关注哦(加关注即可阅读全文),对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 11.6.1. 控制测试的运行方式 cargo test和cargo run一样,cargo test也会编译代…

nginx负载均衡-基于端口的负载均衡(一)

注意: (1) 做负载均衡技术至少需要三台服务器:一台独立的负载均衡器,两台web服务器做集群 一、nginx分别代理后端web1 和 web2的三台虚拟主机 1、web1(nginx-10.0.0.7)配置基于端口的虚拟主机 [rootOldboy extra]# …

DDcGAN_多分辨率图像融合的双鉴别条件生成对抗网络_y译文马佳义

摘要: 在本文中,我们提出了一种新的端到端模型,称为双鉴别条件生成对抗网络(DDcGAN),用于融合不同分辨率的红外和可见光图像。我们的方法建立了一个生成器和两个鉴别器之间的对抗博弈。生成器的目的是基于特…

【C++/控制台】2048小游戏

源代码&#xff1a; #include <iostream> #include <windows.h> #include <stdio.h> #include <math.h> #include <stdlib.h> #include <conio.h> #include <time.h>// #define KEY_DOWN(VK_NONAME) ((GetAsyncKeyState(VK_NONAME)…