DeepWalk: Online Learning of Social Representations(2014 ACM SIGKDD)

DeepWalk: Online Learning of Social Representations----《DeepWalk:用于图节点嵌入的在线机器学习算法》

 
DeepWalk 是将 word2vector 用到 GNN 上
DeepWalk: 将 Graph 的每个节点编码为一个 D 维向量(无监督学习),Embedding 中隐式包含了 Graph 中的社群、连接、结构信息,可用于后续节点分类等下游任务(监督学习)。
在这里插入图片描述

摘要

  我们提出了 DeepWalk,一种学习网络中节点潜在表示的新方法。这些潜在表示在连续向量空间中对社会关系进行编码,很容易被统计模型利用。DeepWalk 概括了语言建模和无监督特征学习(或深度学习)从单词序列到图形的最新进展
  DeepWalk 使用从截断随机游走获得的局部信息,通过将游走视为句子的等价物来学习潜在表示。我们在 BlogCatalog、Flickr 和 YouTube 等社交网络的多个多标签网络分类任务上展示了 DeepWalk 的潜在表示。我们的结果表明,DeepWalk 的性能优于具有挑战性的基线,这些基线允许对网络进行全局视图,特别是在存在丢失信息的情况下。当标记数据稀疏时,DeepWalk 的表示可以提供比竞争方法高出 10% 的 F1 分数。在一些实验中,DeepWalk 的表示能够优于所有基线方法,同时使用的训练数据少 60%。
  DeepWalk 也是可扩展的。它是一种在线学习算法,可以构建有用的增量结果,并且可以轻松并行化。这些品质使其适合广泛的现实世界应用,例如网络分类和异常检测。

引言

  网络表示的稀疏性既是优点也是缺点。稀疏性使得设计高效的离散算法成为可能,但也使得统计学习中的泛化变得更加困难。网络中的机器学习应用(例如网络分类 [15, 37]、内容推荐 [11]、异常检测 [5] 和缺失链接预测 [22])必须能够处理这种稀疏性才能生存。
  在本文中,我们首次将深度学习(无监督特征学习)[2]技术引入网络分析中,该技术在自然语言处理中已被证明是成功的。我们开发了一种算法(DeepWalk),通过建模短随机游走序列来学习图顶点的网络连接结构信息。网络连接结构信息是捕捉邻域相似性和社区成员关系的顶点的潜在特征。这些潜在表示将社会关系编码在连续低维稠密向量空间中。DeepWalk 概括了神经语言模型处理一组随机游走序列组成的特殊语言。这些神经语言模型已被用来捕获人类语言的语义和句法结构[6],甚至逻辑类比[28]。
  DeepWalk 将图作为输入并输出每个节点的潜在表示。将我们的方法应用于经过充分研究的空手道网络的结果如图 1 所示。图1a所示为图结构呈现形式。图1b显示了我们的方法输出的结果(二维embedding)。除了惊人的相似性之外,我们注意到(1b)的线性可分离部分对应于通过输入图(1a)中的模块化最大化找到的簇(显示为顶点颜色)。
在这里插入图片描述
  为了展示 DeepWalk 在现实场景中的潜力,我们评估了其在大型异构图中具有挑战性的多标签网络分类问题的性能。在关系分类问题中,特征向量之间的链接违背了传统机器学习的独立同分布假设。解决此问题的技术通常使用近似推理技术 [31, 35] 来利用依赖性信息来改进分类结果。我们通过学习与标签无关的图的表示来远离这些方法。我们的嵌入向量的质量不受标记顶点选择的影响(但是受顺序影响),因此它们可以在任务之间共享。
  DeepWalk 在创建社交维度方面优于其他潜在表示方法 [39, 41],特别是当标记节点稀缺时。通过非常简单的线性分类器(例如逻辑回归),我们的表示可以实现出色的性能。我们的表示是通用的,可以与任何分类方法(包括迭代推理方法)结合。DeepWalk 实现了所有这些目标,同时也是一种可轻松并行化的在线算法。

  我们的贡献如下:

  • 我们引入深度学习作为分析图形的工具,以构建适合统计建模的鲁棒表示。DeepWalk 学习短随机游走序列中存在的结构规律。
  • 我们广泛评估了我们在多个社交网络上的多标签分类任务的表示。我们发现,在标签稀疏的情况下,分类性能显着提高,在我们考虑的最稀疏问题上,比 Micro F1 提高了 5%-10%。在某些情况下,即使训练数据少 60%,DeepWalk 的表示也能优于竞争对手。
  • 我们通过使用并行实现构建网络规模图(例如 YouTube)的表示来展示我们算法的可扩展性。此外,我们描述了构建我们方法的流处理版本所需的最小更改。

问题定义

  我们考虑将社交网络的成员分为一个或多个类别的问题。更形式化来说, G = ( V , E ) G = (V,E) G=(V,E) ,其中 V V V 是节点, E E E 是邻接矩阵, E ⊆ ( V × V ) E \subseteq (V \times V) E(V×V)。给定一个部分标记的社交网络 G L = ( V , E , X , Y ) {G_L} = (V,E,X,Y) GL=(V,E,X,Y),其属性 X ∈ R ∣ V ∣ × S X \in {R^{\left| V \right| \times S}} XRV×S,其中 S S S 是每个节点向量的维度, Y ∈ R ∣ V ∣ × ∣ y ∣ Y \in {R^{\left| V \right| \times \left| y \right|}} YRV×y y y y 是标签集(多标签)。
  在传统的机器学习分类设置中,我们的目标是学习一个假设 H H H,它将 X X X 中的元素映射到标签集 y y y 中。在我们的例子中,我们可以利用 G G G 结构中嵌入的示例依赖性的重要信息来实现卓越的性能。
  在文献中,这被称为关系分类(或集体分类问题[37])。传统的关系分类方法将问题作为无向马尔可夫网络中的推理,然后使用迭代近似推理算法(例如迭代分类算法[31]、吉布斯采样[14]或标签松弛[18])来计算给定网络结构的标签的后验分布。
  我们提出了一种不同的方法来捕获网络拓扑信息。我们提出了一种无监督方法,该方法不是将标签空间混合为特征空间的一部分,而是学习捕获独立于标签分布的图结构的特征(只用连接学习节点嵌入)。
  结构表示和标签任务之间的这种分离避免了迭代方法中可能发生的级联错误(误差累积)[33]。此外,同样的表示可用于该网络的多个分类问题
  我们的目标是学习 X E ∈ R ∣ V ∣ × d {X_E} \in {R^{\left| V \right| \times d}} XERV×d,其中 d d d 是较小的潜在维度。这些低维表示是分布式的(分布式:各个维度都不为0);这意味着每个向量都由维度的子集来表达,并且每个维度都对空间表达的社会概念的子集做出贡献。
  利用这些结构特征,我们将扩大属性空间(反映连接信息的Embedding+反映节点本身的特征)以帮助分类决策。这些特征是通用的,可以与任何分类算法(包括迭代方法)一起使用。然而,我们相信这些功能的最大用途是它们可以与简单的机器学习算法轻松集成。正如我们将在第 6 节中展示的那样,它们在现实网络中可以适当扩展。

学习图节点嵌入表示

我们寻求学习具有以下特征的 embedding:

  • 适应性(弹性扩容):真实的社交网络在不断发展;新的社会关系不应该需要再次重复学习过程。
  • 社群聚类信息:潜在维度之间的距离应该代表一个度量,用于评估网络中相应成员之间的社会相似性。这允许在具有同质性的网络中进行泛化。
  • 低维:当标记数据稀缺时,低维模型可以更好地泛化(防止过拟合),并加快收敛和推理速度。
  • 连续性:我们需要潜在的表示来模拟连续空间中的部分社区成员资格。除了提供社区成员的详细的视图之外,连续表示在社区之间具有平滑的决策边界,从而允许更鲁棒的分类。

  为了满足这些要求,我们的方法使用最初为语言建模设计的优化技术,从短随机游动序列中学习顶点的表示。在这里,我们回顾 随机游走语言建模 的基础知识,并描述它们的组合如何满足我们的需求。

随机游走

  我们将以顶点 v i {v_i} vi 为起始节点的随机游走表示为 W v i {W_{{v_i}}} Wvi。这是一个随机过程,随机变量为 W v i 1 , W v i 2 , . . . , W v i k W_{{v_i}}^1,W_{{v_i}}^2,...,W_{{v_i}}^k Wvi1,Wvi2,...,Wvik 使得 W v i k + 1 W_{{v_i}}^{k + 1} Wvik+1 是从顶点 v k {{v_k}} vk 的邻居中随机选择的顶点。随机游走已被用作内容推荐 [11] 和社区检测 [1] 中各种问题的相似性度量。它们还是一类 output sensitive(至少要遍历一遍全图)算法的基础,这些算法使用它们来计算时间复杂度小于输入图大小的局部社区结构信息。
  正是这种与局部结构的联系促使我们使用短随机游走序列作为从网络中提取信息的基本工具。除了捕获社区信息之外,使用随机游走作为我们算法的基础还为我们提供了另外两个理想的属性。首先,局部探索很容易并行化。多个随机游走器(在不同的线程、进程或机器中)可以同时探索同一图的不同部分。其次,依靠从短随机游走获得的信息,可以适应图结构的微小变化(在线增量学习),而无需全局重新计算。我们可以使用新的随机游走迭代更新学习模型,从时间变化区域次线性地更新到整个图。

连接:幂律

(幂律通常描述节点度的分布,表明少数节点具有非常高的度,而大多数节点的度较低。这种分布特征是具有长尾部分的)
  在选择了在线随机游走作为捕获图结构的原语之后,我们现在需要一种合适的方法来捕获这一信息。如果连通图的度分布遵循幂律分布(无标度),我们观察到顶点在短随机游走中出现的频率也将遵循幂律分布。
  自然语言中的词频遵循类似的分布,语言建模技术可以解释这种分布行为。为了强调这种相似性,我们在图 2 中展示了两种不同的幂律分布。第一个来自无标度图上的一系列短随机游走,第二个来自英文维基百科的 100,000 篇文章的文本。
在这里插入图片描述
  我们工作的核心贡献是这样的想法:用于模拟自然语言的技术(其中符号频率遵循幂律分布(或Zipf定律))可以重新用于模拟网络中的社区结构。 我们在本节的其余部分中回顾了语言建模方面不断发展的工作,并将其转换为满足我们标准的顶点表示。

语言模型

  语言建模的目标是估计特定词序在语料库中出现的可能性。更形式化地说,给定一个单词序列:

W 1 n = ( w 0 , w 1 , . . . , w n ) W_1^n = ({w_0},{w_1},...,{w_n}) W1n=(w0,w1,...,wn)

其中, w i ∈ V {w_i} \in V wiV V V V 是词汇表),我们希望在所有训练语料库上最大化 Pr ⁡ ( w n ∣ w 0 , w 1 , . . . , w n − 1 ) \Pr ({w_n}|{w_0},{w_1},...,{w_{n - 1}}) Pr(wnw0,w1,...,wn1)
  表示学习的最新工作重点是使用概率神经网络来构建单词的一般表示,从而将语言建模的范围扩展到超出其原始目标。
  在这项工作中,我们提出了语言建模的概括,以通过一系列短随机游走来探索图。这些游走序列可以被认为是特殊语言中的短句和短语。直接的模拟是根据随机游走中迄今为止访问过的所有先前顶点来估计顶点 v i {v_i} vi 的可能性:

Pr ⁡ ( v i ∣ v 1 , v 2 , . . . , v i − 1 ) \Pr ({v_i}|{v_1},{v_2},...,{v_{i - 1}}) Pr(viv1,v2,...,vi1) (用前i-1个节点预测第i个节点)

  我们的目标是学习潜在表示,而不仅仅是节点共现的概率分布,因此我们引入映射函数 Φ : v ∈ V ↦ R ∣ V ∣ × d \Phi :v \in V \mapsto {R^{\left| V \right| \times d}} Φ:vVRV×d。该映射 Φ \Phi Φ 表示与图中每个顶点 v v v 相关的潜在社会表征。(实际上,我们用没有大小限制的参数 ∣ V ∣ × d {\left| V \right| \times d} V×d 矩阵表示 Φ \Phi Φ,该矩阵稍后将用作我们的 X E {X_E} XE)接下来的问题是估计可能性:

Pr ⁡ ( v i ∣ ( Φ ( v 1 ) , Φ ( v 2 ) , . . . , Φ ( v i − 1 ) ) ) \Pr ({v_i}|(\Phi ({v_1}),\Phi ({v_2}),...,\Phi ({v_{i - 1}}))) Pr(vi(Φ(v1),Φ(v2),...,Φ(vi1))) (用前i-1个节点的Embedding预测第i个节点, Φ \Phi Φ是查表操作)

  然而,随着游走长度的增加,计算这个目标函数变得不可行(概率相乘使值越来越小)。
  最近语言模型的放松 [26, 27] 彻底改变了预测问题。首先,它不是使用上下文来预测缺失的单词,而是使用一个单词来预测上下文。其次,上下文由出现在给定单词右侧和左侧的单词组成。最后,它消除了问题的排序约束。相反,该模型需要在不知道单词与给定单词的偏移量的情况下,最大化任何单词出现在上下文中的概率。
  就顶点表示建模而言,这会产生优化问题:

min ⁡ Φ − log ⁡ Pr ⁡ ( { v i − w , . . . , v i − 1 , v i + 1 , . . . , v i + w } ∣ Φ ( v i ) ) \mathop {\min }\limits_\Phi - \log \Pr (\{ {v_{i - w}},...,{v_{i - 1}},{v_{i + 1}},...,{v_{i + w}}\} |\Phi ({v_i})) ΦminlogPr({viw,...,vi1,vi+1,...,vi+w}∣Φ(vi)) (2)

  我们发现这些放松对于社区表征学习特别理想。首先,顺序无关假设更好地捕捉了随机游走提供的“近似”感。此外,这种松弛对于通过构建小模型来加快训练时间非常有用,因为一次给出一个顶点。
  从式(2)中解决优化问题的方法是建立表示方法,捕捉顶点之间在局部图结构中的共享相似性。具有相似邻域的顶点将获得相似的表示(编码相似性),并允许在机器学习任务中进行泛化。
  通过结合截断的随机游走和神经语言模型,我们制定了一种方法,满足所有我们想要的性质。该方法生成了低维的、存在于连续向量空间中的社交网络的表示。它的表示方法编码了潜在的社群成员形式,并且由于该方法输出有用的中间表示,它可以适应不断变化的网络拓扑。

方法

  在本节中,我们将讨论算法的主要组成部分。我们还介绍了几种方法的变体,并讨论了它们的优点。

回顾

  与任何语言建模算法一样,唯一需要的输入是语料库和词汇 V V V。DeepWalk 将一组短截断随机游走视为自己的语料库,并将图顶点视为自己的词汇表 ( v = V v = V v=V)。虽然在训练之前了解随机游走中的 V V V 和顶点频率分布是有益的,但并不是算法正常工作所必需的,正如我们将在4.2.2中展示的那样。

算法:DeepWalk

  该算法由两个主要部分组成;第一个是随机游走生成器,第二个是更新过程
  随机游走生成器采用图 G G G 并均匀采样随机顶点 v i {v_i} vi 作为随机游走序列 W v i {W_{{v_i}}} Wvi 的起始节点。游走从当前访问的顶点的邻居节点中均匀采样,直到达到最大长度 ( t t t)。虽然在实验中我们将随机游走的长度固定为特定值,但并没有限制随机游走必须具有相同的长度。这些随机游走可以具有重新启动(即返回到其根的跳转概率),但我们的初步结果没有显示使用重新启动会带来任何优势。实际上,我们的实现指定了从每个顶点开始的多个长度为 t t t 的随机游走 y y y
在这里插入图片描述
  算法 1 中的第 3-9 行显示了我们方法的核心。外循环指定我们应该在每个顶点开始随机游走的次数 y y y。我们认为每次迭代都是对数据进行“传递”,并在传递过程中对每个节点进行一次遍历。在每次传递开始时,我们都会生成一个随机顺序来遍历顶点。这不是严格要求的,但众所周知可以加速随机梯度下降的收敛。
  在内部循环中,我们迭代图的所有顶点。对于每个顶点 v i {v_i} vi,我们生成一个随机游走 ∣ W v i ∣ = t \left| {{W_{{v_i}}}} \right| = t Wvi=t,然后用它来更新我们的表示(第 7 行)。我们使用 SkipGram 算法 [26] 根据方程中的目标函数来更新这些表示。
在这里插入图片描述

SkipGram

  SkipGram 是一种语言模型,可最大化句子中窗口 w w w 内出现的单词之间的共现概率 [26]。算法 2 迭代出现在窗口 w w w 内的随机游走中的所有可能的搭配(第 1-2 行)。对于每个顶点,我们将每个顶点 v j {v_j} vj 映射到其当前表示向量 Φ ( v j ) ∈ R d \Phi ({v_j}) \in {R^d} Φ(vj)Rd(见图 3b)。对于给定 v j {v_j} vj 的表示,我们希望最大化其邻居在随机游走中的概率(第 3 行)。我们可以使用多种分类器选择来学习这种后验分布。例如,使用逻辑回归对前面的问题进行建模将产生大量等于 ∣ V ∣ \left| V \right| V 的标签,这可能是数百万或数十亿。此类模型需要大量的计算资源,这些资源可能跨越整个计算机集群 [3]。为了加快训练时间,可以使用 Hierarchical Softmax [29,30] 来近似概率分布。
在这里插入图片描述

优化

  模型参数集为 { Φ , T } \{ \Phi ,T\} {Φ,T},其中每个参数的大小为 O ( d ∣ V ∣ ) O(d\left| V \right|) O(dV)。随机梯度下降 (SGD) [4] 用于优化这些参数(第 4 行,算法 2)。使用反向传播算法来估计导数。SGD 的学习率 α \alpha α 在训练开始时最初设置为 2.5%,然后随着迄今为止看到的顶点数量线性下降。

并行

  如图 2 所示,社交网络随机游走中的顶点频率分布和语言中的单词都遵循幂律。这会导致不频繁顶点的长尾,因此,影响 Φ 的更新本质上是稀疏的。这允许我们在多工作人员的情况下使用异步版本的随机梯度下降(ASGD)。鉴于我们的更新是稀疏的,并且我们没有获取访问模型共享参数的锁,ASGD 将实现最佳收敛速度 [36]。当我们使用多线程在一台机器上运行实验时,已经证明该技术具有高度可扩展性,并且可以用于超大规模机器学习[8]。图 4 显示了并行化 DeepWalk 的效果。它表明,当我们将工作线程数量增加到 8 时,BlogCatalog 和 Flickr 网络的处理速度是一致的(图 4a)。它还表明,相对于串行运行的 DeepWalk,预测性能没有损失(图 4b)。
在这里插入图片描述

算法变体

  在这里,我们讨论我们提出的方法的一些变体,我们认为这些变体可能会令人感兴趣。

流式方法

  这种方法的一个有趣的变体是流式方法,它可以在不了解整个图的情况下实现。在这个变体中,图中的小步直接传递到表示学习代码,并且模型直接更新。对学习过程进行一些修改也是必要的。首先,使用衰减的学习率将不再可能。相反,我们可以将学习率 α \alpha α 初始化为一个小的常数值。这将需要更长的时间来学习,但在某些应用程序中可能是值得的。其次,我们不一定再构建参数树。如果 V V V 的基数已知(或可以有界),我们可以为该最大值构建分层 Softmax 树。当第一次看到顶点时,可以将它们分配给剩余的叶子之一。如果我们有能力先验地估计顶点频率,我们仍然可以使用霍夫曼编码来减少频繁的元素访问时间。

非随机游走

  一些图是由与一系列元素进行交互的代理创建的(例如,用户在网站上导航页面)。当图由这样的非随机游走流创建时,我们可以直接利用这个过程来提供给建模阶段。以这种方式采样的图不仅可以捕捉与网络结构相关的信息,还可以捕捉路径被遍历的频率。
  我们认为,这种变体还包含语言建模。句子可以被视为通过适当设计的语言网络的有目的的行走,而像 SkipGram 这样的语言模型就是为了捕捉这种行为而设计的。
  这种方法可以与流变体(第 4.4.1 节)结合起来,在不断发展的网络上训练特征,而无需显式构建整个图。使用这种技术维护表示可以实现网络规模分类,而无需处理网络规模图的麻烦。

实验设计

  在本节中,我们概述了我们将在实验中使用的数据集和方法。用于重现我们结果的代码和数据将在第一作者的网站上提供。

数据集

实验使用了三个数据集:BlogCatalog、Flickr 和 YouTube
在这里插入图片描述

基线方法

  为了验证我们方法的性能,我们将其与许多基线进行比较:SpectralClustering、Modularity、EdgeCluster、wvRN、Majority。

实验

  在本节中,我们将对我们的方法进行实验分析。我们在许多多标签分类任务上对其进行了全面评估,并分析了其在多个参数上的敏感性。

多标签分类

  为了便于我们的方法和相关基线之间的比较,我们使用与[39, 40]中完全相同的数据集和实验程序。具体来说,我们随机采样标记节点的一部分( T R {T_R} TR),并将它们用作训练数据。其余节点用作测试。我们重复此过程 10 次,并报告 Macro-F1 和 Micro-F1 的平均性能。如果可能的话,我们直接在此处报告原始结果 [39, 40]。
  对于所有模型,我们使用 LibLinear [10] 实现的一对剩余逻辑回归进行分类。我们给出 DeepWalk 的结果( y y y = 80, w w w = 10, d d d = 128)。(SpectralClustering、Modularity、EdgeCluster)的结果使用 Tang 和 Liu 的首选维度 d d d = 500。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
  表2所示,DeepWalk 的性能始终优于 EdgeCluster、Modularity 和 wvRN。当仅使用 20% 的标记节点进行训练时,DeepWalk 比提供 90% 的数据时的其他方法表现更好。当标记数据在 Macro-F1 (TR ≤ 20%) 和 Micro-F1 (TR ≤ 60%) 上稀疏时,DeepWalk 仍然表现出色。DeepWalk 可以扩展到大型图,并且在这种稀疏标记的环境中表现得非常好。(一句话:DeepWalk比其他方法好)

参数灵敏度

  为了评估 DeepWalk 参数化的变化如何影响其在分类任务上的性能,我们在两个多标签分类任务(Flickr 和 BlogCatalog)上进行了实验。对于此测试,我们将窗口大小和行走长度固定为合理值( w w w = 10, t t t = 40),这应该强调局部结构。然后,我们改变潜在维度的数量 ( d d d)、每个顶点开始的行走次数 ( y y y) 以及可用训练数据量 ( T R {T_R} TR),以确定它们对网络分类性能的影响。

维度 d d d 的影响

在这里插入图片描述
  图 5a1 和 5a3 检查了改变维度和训练率的影响。Flickr 和 BlogCatalog 之间的性能非常一致,并且表明模型的最佳维度取决于训练示例的数量。(请注意,1% 的 Flickr 的标记示例大约与 10% 的 BlogCatalog 一样多)。
  图 5a2 和 5a3 检查了改变维度和每个顶点的行走次数的影响。在不同的 y y y 值下,维度之间的相对性能相对稳定。首先,在两个图中,每个节点执行 y y y = 30步可以获得大部分的信息。第二,不同 y y y 值之间的相对差异在两幅图之间是相当一致的。
  他们还表明,模型的性能取决于它所经历的随机游走的数量,并且模型的适当维度取决于可用的训练示例。

随机游走次数 y y y 的影响

  图 5a 显示了增加 y y y(我们从每个顶点开始的随机游走次数)的效果。对于不同维度(图5b1,图5b3)和训练数据量(图5b2,图5b4),结果非常一致。最初,增加 y y y 对结果有很大影响,但这种影响很快就会减慢( y y y > 10)。这些结果表明,我们只需进行少量的随机游走就能够学习有意义的顶点潜在表示。
在这里插入图片描述

相关工作

我们提出的方法与以前的工作之间的主要区别可以总结如下:

  • 我们学习潜在的社会表征,而不是计算与中心性[12]或分区[41]相关的统计数据。
  • 我们不尝试扩展分类过程本身(通过集体推理[37]或图内核[20])。
  • 我们提出了一种仅使用局部信息的可扩展在线方法。大多数方法需要全局信息并且是离线的[16, 39–41]。
  • 我们将无监督表示学习应用于图。

在本节中,我们讨论网络分类和无监督特征学习的相关工作。

关系学习

  关系分类(或集体分类)方法[14,24,31,35]使用数据项之间的链接作为分类过程的一部分。集体分类问题中的精确推理是NP困难的,解决方案集中在使用近似推理算法,该算法可能无法保证收敛[37]。
  与我们的工作最相关的关系分类算法通过学习集群 [32]、通过在附近节点之间添加边 [13]、使用 PageRank [23] 或通过扩展关系分类以考虑其他特征 [43] 来整合社区信息。我们的工作采取了截然不同的方法。我们提出了一种学习网络结构表示的过程,而不是新的近似推理算法,然后可以由现有推理过程(包括迭代过程)使用该表示。
  还提出了许多从图生成特征的技术[12,16,39–41]。与这些方法相反,我们将特征创建过程构建为表示学习问题。
  图核[42]已被提议作为一种使用关系数据作为分类过程一部分的方法,但除非近似[19],否则速度相当慢。我们的方法是互补的;我们不是将结构编码为核函数的一部分,而是学习一种表示,允许它们直接用作任何分类方法的特征。

无监督特征学习

  分布式表示已被提出来建模概念之间的结构关系[17]。这些表示通过反向传播和梯度下降进行训练。计算成本和数值不稳定导致这些技术被放弃了近十年。最近,分布式计算允许训练更大的模型[3],并且出现无监督学习算法的数据增长[9]。分布式表示通常通过神经网络进行训练,这些网络在计算机视觉[21]、语音识别[7]和自然语言处理[6]等不同领域取得了进步。

结论

  我们提出了 DeepWalk,一种学习顶点潜在社会表征的新方法。使用截断随机游走的局部信息作为输入,我们的方法学习编码结构规律的表示。对各种不同图的实验说明了我们的方法在具有挑战性的多标签分类任务上的有效性。
  作为一种在线算法,DeepWalk 也具有可扩展性。我们的结果显示,我们可以为图创建有意义的表示,这些图对于运行谱方法来说太大了。在这样大的图上,我们的方法在显著优于其他设计用于处理稀疏性的方法。我们还展示了我们的方法是可并行的,允许多个工作进程同时更新模型的不同部分。
  除了有效和可扩展之外,我们的方法也是语言建模的一种有吸引力的概括。这种联系是互惠互利的。语言建模的进步可能会继续为网络产生改进的潜在表示。在我们看来,语言建模实际上是从不可观察的语言图中进行采样。我们相信,从可观察图建模中获得的见解反过来可能会改进不可观察图建模。
  在这个领域,我们未来的工作将重点研究这种二元性,利用我们的结果来改进语言建模,并加强该方法的理论基础。

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

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

相关文章

linux之 服务器ping百度能通,ping其他网址不通

表症问题 linux上ping域名解析出来的ip地址不正确 linux服务器ping百度能通,ping其他网址不通 linux上ping域名解析出来的ip地址不正确 ping 百度可以,说明dns解析是没问题的 但是,ping 其他网址不通,说明是 请求的其他网址的问…

Talk | PSU助理教授吴清云:AutoGen-用多智能体对话开启下一代大型语言模型应用

本期为TechBeat人工智能社区第548期线上Talk! 北京时间11月21日(周二)20:00,宾夕法尼亚州立大学助理教授—吴清云的Talk已准时在TechBeat人工智能社区开播! 她与大家分享的主题是: “ AutoGen:用多智能体对话开启下一代大型语言模…

根据商品ID获取虾皮数据接口|虾皮商品详情接口|虾皮关键词搜索商品列表接口|虾皮到手价接口|虾皮API接口

虾皮商品详情是指虾皮平台上商品的具体信息,包括但不限于商品名称、描述、价格、图片、评论等。要获取虾皮商品详情,您需要先登录虾皮网站或APP,然后浏览商品页面或搜索商品,找到您感兴趣的商品后,可以查看该商品的详情…

人工智能对我们的生活影响

目录 前言 一、人工智能的领域 二、人工智能的应用 三、对人工智能的看法 总结 🌈嗨!我是Filotimo__🌈。很高兴与大家相识,希望我的博客能对你有所帮助。 💡本文由Filotimo__✍️原创,首发于CSDN&#x1f4…

使用 API 管理平台的 5 大理由

组织需要治理和控制API生态系统,这种治理就是API管理的作用。 Uber 使用 API​​(应用程序编程接口)与 Google Maps 和 Twilio 等第三方服务连接,这有助于改善用户体验; Salesforce 提供 API,允许开发人员…

虚函数可不可以重载为内联 —— 在开启最大优化时gcc、clang和msvc的表现

下面是对该问题的一种常见回答: 首先,内联是程序员对编译器的一种建议,因此可以在在重载虚函数时在声明处加上inline关键字来修饰, 但是因为虚函数在运行时通过虚函数表,而内联函数在编译时进行代码嵌入,因…

创作一款表情包生成微信小程序:功能详解与用户体验优化

一、引言 在当今社交媒体充斥着各种趣味表情包的时代,表情包生成工具成为许多用户创作和分享创意的热门选择。为了迎合这一趋势,我设计并开发了一款功能丰富、用户友好的微信小程序,旨在让用户能够轻松而有趣地创作个性化的表情包。这篇博客将…

南京数字孪生赋能工业制造,加速推进制造业数字化转型

随着南京信息技术的迅猛发展和工业管理的不断演进,传统的工业管理方式已经无法满足企业对高效、智能和可持续发展的需求。针对这一情况,数字孪生技术应运而生,为南京工业管理带来了全新的变革和机遇。以数字孪生为理念,三维可视化…

大模型创业“风投”正劲,AGI Foundathon 大模型创业松活动精彩看点

这是一场万众瞩目的大模型领域盛会。当来自世界各地的顶尖大模型开发者、创业者、投资人汇聚一堂,他们对大模型应用层的思考碰撞出了哪些火花?应运而生了哪些令人眼前一亮的AI-Native产品? 让我们一起来回顾吧~

C#核心笔记——(二)C#语言基础

一、C#程序 1.1 基础程序 using System; //引入命名空间namespace CsharpTest //将以下类定义在CsharpTest命名空间中 {internal class TestProgram //定义TestProgram类{public void Test() { }//定义Test方法} }方法是C#中的诸多种类的函数之一。另一种函数*,还…

算法-二叉树-简单-二叉树的直径、将有序数组转换成二叉搜索树

记录一下算法题的学习9 二叉树的直径 题目:给你一棵二叉树的根节点,返回该树的 直径 。 二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。两节点之间路径的 长度 由它们之间边数表示 读完题目&…

如何打造适用的MES管理系统解决方案

在当前的制造业领域,项目型生产企业面临着独特的挑战。尽管国外的大型软件公司提供了某些解决方案,但由于地域、文化和制度的差异,这些方案并不完全满足企业的实际需求。为了解决这一难题,我们必须以客户为中心,围绕他…

机器学习中的特征选择:方法和 Python 示例

布拉加德什桑达拉拉詹 一、说明 特征选择是机器学习流程中至关重要且经常被低估的步骤。它涉及从数据集中的原始特征集中选择最相关的特征(输入变量或属性)的子集。特征选择的重要性怎么强调都不为过,因为它直接影响机器学习模型的质量、效率…

【C++】类与对象(中)

一、类的默认成员函数 如果一个类中什么成员都没有,简称为空类。 空类中真的什么都没有吗?并不是,任何类在什么都不写时,编译器会自动生成以下6个默认成员函数。 默认成员函数:用户没有显式实现,编译器会自…

解析大型语言模型的训练、微调和推理的运行时性能

背景 这篇论文是截至目前为数不多的介绍大模型训练配套环境比对的论文,对于想要入门大模型训练同学是个不错的入门资料。比较了不同尺寸模型(比较常用的7、13、70b),在不同型号gpu、训练框架、推理框架数据。结合自己实际工作需要…

华为认证 | HCIE考证流程详解!

HCIE(Huawei Certified ICT Expert,华为认证ICT专家)是华为认证体系中最高级别的ICT技术认证,旨在打造高含金量的专家级认证,为技术融合背景下的ICT产业提供新的能力标准,以实现华为认证引领ICT行业技术认证…

numpy报错:AttributeError: module ‘numpy‘ has no attribute ‘float‘

报错:AttributeError: module numpy has no attribute float numpy官网:NumPy 报错原因:从numpy1.24起删除了numpy.bool、numpy.int、numpy.float、numpy.complex、numpy.object、numpy.str、numpy.long、numpy.unicode类型的支持。 解决办法…

小程序Tab栏与页面滚动联动

小程序tab栏切换与页面滚动联动 tab栏与页面滚动联动点击tab栏页面跳到指定位置滚动页面时切换tab栏 tab栏与页面滚动联动 在进行小程序开发时,需要实现点击tab栏页面滚动到某一指定位置,并且滚动页面时,小程序的tab栏进行切换。 在一开始&a…

MP3音频文件体积怎么缩小?压缩的方法有哪些?

压缩音频文件可减小文件的大小,从而更轻松地上传到其他平台,或轻松的通过电子邮件进行分享。除此之外,压缩音频文件还可以节省硬盘上的储存空间。那MP3音频文件体积怎么缩小呢?继续阅读可查看压缩的详细流程。 什么是音频文件压缩…

开发上门按摩系统对技师如何管理,薪资结构怎么设计

开发完上门按摩系统平台上线之后,对技师的管理和薪资结构是非常重要的环节,关乎着平台的服务能力和服务质量,那么应该如何去管理和设计薪资结构呢 首先说技师管理: 一、培训和认证:平台应对技师进行全面的培训&#xf…