| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 人工智能 -> 社区发现算法——BigCLAM 算法 -> 正文阅读 |
|
[人工智能]社区发现算法——BigCLAM 算法 |
《Overlapping Community Detection at Scale: A Nonnegative Matrix Factorization Approach》 BIGCLAM(Cluster Affiliation Model for Big Networks,大型网络的聚类关系模型)是一个bipartite affiliation network模型。 BigCLAM方法流程: community affiliation graph model (AGM) 《Community-affiliation graph model for overlapping network community detection》 通过节点-社区隶属关系(下图左图)生成相应的网络(下图右图)。 AGM生成图的流程 给定参数 ( V , C , M , { p C } ) (V,C,M,\lbrace p_C\rbrace) (V,C,M,{pC?}),每个社区 c 内的节点以概率 p C p_C pC?互相链接。 对同属于多个社区的节点对,其相连概率就是: p ( u , v ) = 1 ? ∏ c ∈ M u ? M v ( 1 ? p C ) p(u,v) = 1 - \prod_{c\in M_u \bigcap M_v}(1-p_C) p(u,v)=1?∏c∈Mu??Mv??(1?pC?) (注意:如果节点 u 和 v没有共同社区,其相连概率就是0。为解决这一问题,我们会设置一个 background “epsilon” 社区,每个节点都属于该社区,这样每个节点都有概率相连 p ( u , v ) = ? p(u,v) = \epsilon p(u,v)=? 论文中建议 ? = 2 ∣ E ∣ ∣ V ∣ ( ∣ V ∣ ? 1 ) \epsilon = \frac{2|E|}{|V|(|V|-1)} ?=∣V∣(∣V∣?1)2∣E∣?) AGM可以生成稠密重叠的社区 虽然,AMG模型是在重叠社区挖掘的时候引入的,但并不意味着AMG模型只能生成有重叠社区的网络。事实上,其非常灵活,可以生成不同类型的社区结构。如 通过AGM发现社区:给定图,找到最可能产生出该图的AGM模型参数(最大似然估计) 图拟合(graph fitting) 通过前面我们知道AGM的参数主要有三个:
给定一张图G 我们需要找到 F = a r g m a x P ( G ∣ F ) F = argmax P(G|F) F=argmaxP(G∣F) 为了解决这一问题,我们需要高效的计算 P ( G ∣ F ) P(G|F) P(G∣F), 然后最大化F(使用梯度下降等优化算法) graph likelihood P ( G ∣ F ) P(G|F) P(G∣F) 通过F得到边产生的概率矩阵P(u,v), G具有邻接矩阵,从而得到 P ( G ∣ F ) = ∏ ( u , v ) ∈ G P ( u , v ) ∏ ( u , v ) ? G ( 1 ? P ( u , v ) ) P(G|F) = \prod_{(u,v)\in G}P(u,v) \prod_{(u,v)\notin G}(1-P(u,v)) P(G∣F)=∏(u,v)∈G?P(u,v)∏(u,v)∈/?G?(1?P(u,v)) 即通过AGM产生原图的概率。(原图中有的边乘以生成概率,没有的边乘以不生成的概率(1-生成概率)) 前面是普通的AGM。而BIGCLAM作为AGM的松弛版本,改进之处在于增加了边权重,采用了NMF方法等。 松弛AGM(“Relax” the AGM) 成员关系具有strength(如图所示): F u A F_uA Fu?A是节点 u属于社区 A 的成员关系的strength(如果 F u A = 0 F_uA = 0 Fu?A=0,说明没有成员关系(strength非负) 对于社区C,其内部节点u,v的链接概率为: P c ( u , v ) = 1 ? e x p ( ? F u C ? F v C ) P_c(u,v) = 1 - exp(-F_uC \cdot F_vC) Pc?(u,v)=1?exp(?Fu?C?Fv?C) 0 ≤ P c ( u , v ) ≤ 1 0\leq P_c(u,v)\leq1 0≤Pc?(u,v)≤1 P c ( u , v ) = 0 P_c(u,v) = 0 Pc?(u,v)=0(节点之间无链接) 当且仅当 F u C ? F v C = 0 F_uC \cdot F_vC = 0 Fu?C?Fv?C=0(至少有一个节点对社区C没有成员关系) P c ( u , v ) ≈ 1 P_c(u,v) \approx 1 Pc?(u,v)≈1(节点之间无链接) 当且仅当$F_uC \cdot F_vC $ 很大(两个节点都对社区C有强成员关系strength) 节点对之间可以通过多个社区相连,如果在至少一个社区中相连,节点对就相连,u,v至少在一个社区相连的概率为: P ( u , v ) = 1 ? ∏ C ∈ T ( 1 ? P C ( u , v ) ) P(u,v) = 1 - \prod_{C\in T}(1-P_C(u,v)) P(u,v)=1?∏C∈T?(1?PC?(u,v)) 减数就是u与v在任何社区都不相连的概率 所以节点连接的概率与共享成员们的强度(两点同属于的社区数)成正比 P ( u , v ) = 1 ? e x p ( ? F u T F v ) P(u,v) = 1 - exp(-F_u^TF_v) P(u,v)=1?exp(?FuT?Fv?) BigCLAM model 给定一个网络G(V,E), 我们最大化G在我们模型下的似然度 但是直接用概率的话,其值就是很多小概率相乘,数字小会导致numerically unstable的问题,所以要用log likelihood 优化$ l( F )$:从随机成员关系F开始,迭代直至收敛: 对每个节点u,固定其它节点的membership、更新 F u F_u Fu?。我们使用梯度提升的方法,每次对 F u F_u Fu?做微小修改,使log-likelihood提升。 对 F u F_u Fu?的偏微分等于: 在梯度提升时候,前部分与u的度数线性相关(快),后部分与图中节点数线性相关(慢) 因此我们可以将后者分解: 右式第一项可以提前计算并缓存好,每次直接用;后两项与u的度数线性相关。这样整个梯度步花费u的度数的线性时间。 总计来说,梯度步骤如下: 当我们找到了F,就可以生成想要的重叠社区,进而完成了我们的社区划分。 F还可以通过GNN获得 使用GNN的好处:
但是真实世界的图形通常是极其稀疏的, ∣ E ∣ n 2 < < 1 \frac{|E|}{n^2}<<1 n2∣E∣?<<1,即真是存在的边 比可能存在的边小很多。 式子第二部分的贡献要大得多。解决方法:取两项平均值 优化好F后,我们将节点分配给社区: 设置一个阈值𝜌:超参数,NOCD选择𝜌= 0.5 将节点𝑢分配到社区𝐶 如果 F u C > p F_uC>p Fu?C>p 一个实例: BigCLAM总结:
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/10 3:03:11- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |