Nat. Mach. Intell. | 基于深度强化学习寻找网络中的关键节点

本文涉及的产品
公网NAT网关,每月750个小时 15CU
简介: Nat. Mach. Intell. | 基于深度强化学习寻找网络中的关键节点

今天给大家介绍哈佛大学Yang-Yu Liu课题组和加利福尼亚大学洛杉矶分校Yizhou Sun课题组发表在nature machine intelligence上的一篇文章“Finding key players in complex networks through deep reinforcement learning”,作者提出一种基于深度强化学习框架FINDER来寻找一组能对网络功能产生最大影响的关键节点序列。


image.png

image.png

1


研究背景


寻找网络中一组最优节点集合是网络科学中的重要课题。删除(增添)一部分重要的节点能极大减弱(增强)网络的连通性,从而影响网络的功能,利用这一特性,可以高效地破坏网络结构,也可以设计出对于攻击或者扰动表现出更优鲁棒性的网络。传统方法难以兼顾效率和性能,且大多数只针对特定的场景。得益于近年来深度学习在组合优化问题的发展,Fan Changjun等提出了一种基于深度强化学习的方法来寻找网络中的关键节点序列。

image.png

2

研究方法

整个深度学习过程的目的:使累积归一化的连通性ANC最小。对于节点无权值的网络,作者定义ANC为:

image.png

critical node(CN)问题中,被定义为

image.png

其中为原网络的节点个数,为第块连通块的大小(节点个数),为原网络的连通性,为从原网络中移除节点序列后的连通性。网络分解问题(ND)中,被定义为,即极大连通子图的大小。对于有些问题,节点被分配了不同的权值,ANC被重新定义为:

image.png

其中为节点移除后损失系数,且

image.png

整个深度强化学习过程中,将移除节点后的残余网络定义为状态,决策为移除(或激活)已经确定的关键节点,收益为累积归一化连通性的衰减。具体的深度学习过程主要包括以下四个步骤:


(1) 编码


编码的目的是利用基于神经网络的图表征学习,将网络的结构信息转化为低维嵌入向量。具体做法是采用一种类似于GraphSAGE的归纳式图表征学习方法来聚合节点嵌入向量,这些向量被初始化为该节点的邻居的特征(如度,移除代价),接着通过一个附带可学习参数的非线性算子转换,将网络节点信息聚合K次,可以将其视为K次神经网络,当前层节点的嵌入向量由上一层该节点以及它邻居的嵌入向量获得,最后一层为输出层,即得到关于每个节点的嵌入向量,这些向量包含了节点的结构位置以及节点特征间的长期交互作用信息。


为了得到网络更为复杂的信息,引入一个虚拟节点,该节点以网络中所有真实节点为邻居,而这些真实节点的邻居不包含该虚拟节点。重复上面的图表征学习方法,得到该节点的嵌入向量。


(2)解码


在解码过程中,作者定义一个评分函数Q function, 利用编码过程得到状态和决策的嵌入信息,计算出一个关于节点的得分Q来评价可能的决策的优劣。根据得分Q采取贪心策略,具体做法是以概率选中Q值最大的节点,以1-的概率随机选择其他节点。作者在实验过程中实际采取的策略是以概率选择Q值最大的前k个节点,以微小的精度损失来减小时间复杂度。


当残余网络只包含孤立节点,收集n步转移信息,即4元组并将它们存入经验回放缓冲区,执行贪心策略50000次,同时更新参数。


(3)训练模型


该过程是为了得到合适的参数。作者定了损失函数如下:

image.png

其中,,为在经验回收缓冲区采样得到关于未来收益更为精确的值,表示折扣因子,为更新后的网络参数,表示节点有连边,为节点的嵌入向量,为原始网络的节点数,函数包含两部分:1. Q-learning loss使预测值和目标值误差最小;2. 在嵌入空间中,Graph reconstruction loss用来保留原始网络结构。实验中作者采用30-50个节点的BA网络模型,进行大量训练,最终使以上损失函数的值最小。


(4) 应用


将训练好的模型用于合成网络和真实网络,这个过程中为了减小时间复杂度,作者每次移除一部分节点而不是每次移除一个。实验最终发现:移除网络1%的节点对网络的性能几乎没有影响。


3


数据


作者将训练的模型分别用于两类网络数据集:1. 人工生成的网络不同规模的BA网络各100个,节点个数分为为30-50,50-100,100-200,200-300,300-400以及400-500。2. 真实网络:Crime,HI-II-14,Digg,Enron,Gnutella31,Epinions,Facebook,Youtobe,Flickr,具体信息如下:

image.png

4


实验


对于人工生成三类网络数据:节点无权值网络,节点权值与度成比例的网络以及随机节点权值网络,针对关键节点(CN)和网络分解(ND)两个问题,作者将提出FINDER框架与其他方法进行比较,最终得出结论:在节点权值分布不同的网络中,无论是CN问题还是ND问题,FINDER始终优于其他方法。具体表现为采用FINDER方法移除相同百分比的节点,对网络的连通性破坏更严重。

image.png

对于真实网络,节点都是无权的,为了改变节点权值,作者采取了两种策略:1. 将与度成比例非负数赋予节点获得node-degree网络,2. 随机将权值赋予节点获得node-random-weight网络。依然针对CN问题和ND问题,作者将FINDER方法与其他方法进行对比,下图显示,移除相同比例的节点,FINDER能更大程度破坏这些真实网络的连通性,图表示随着移除节点的比例变化,网络的连通性的变化。对于CN问题,网络连通性表示为

image.png

对于ND问题,连通性为

image.png

image.png

image.png

对于不同的情况(网络权值分布差异,CN与ND问题的不同),FINDER优于其他方法。特别地,对于节点权值不同的网络,即 node-degree-weight以及node-random-weight网络,FINDER应用后的表现远远超过其他方法。如图k中,为了实现网络连通性衰减为50%,其他方法需要移除整个网络中超40%的节点,应用FINDER则只需要移除大约14%的节点,即实现对网络相同的破坏效果 ,FINDER方法更为高效。


FINDER性能分析


当网络节点权值存在差异时,FINDER在寻找关键节点时性能远胜过其他方法。为了探究其原因,作者在真实网络crime中给节点随机分配权值(节点移除的代价),并绘制出不同方法寻找到的关键节点的代价分布直方图,从图中可以看到:无论是CN问题还是ND问题,FINDER寻找出的关键节点往往移除代价较小,从而能够实现一种更为高效的节点移除策略。

image.png

5


结论


作者提出了一种深度强化学习框架FINDER,该方法只采用小规模的BA网络进行训练,而将它应用于寻找大型真实网络的关键节点时,无论在效率还是性能上都表现优异。针对不同的网络问题,依据定义的连通性度量方式选择对应奖励机制即可。FINDER的表现体现了BA网络模型的应用价值,加深了深度学习技术与复杂网络的融合。应用FINDER也有助于设计出鲁棒性更强的网络系统。



相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
目录
相关文章
|
17天前
|
机器学习/深度学习 算法 PyTorch
深度强化学习中SAC算法:数学原理、网络架构及其PyTorch实现
软演员-评论家算法(Soft Actor-Critic, SAC)是深度强化学习领域的重要进展,基于最大熵框架优化策略,在探索与利用之间实现动态平衡。SAC通过双Q网络设计和自适应温度参数,提升了训练稳定性和样本效率。本文详细解析了SAC的数学原理、网络架构及PyTorch实现,涵盖演员网络的动作采样与对数概率计算、评论家网络的Q值估计及其损失函数,并介绍了完整的SAC智能体实现流程。SAC在连续动作空间中表现出色,具有高样本效率和稳定的训练过程,适合实际应用场景。
73 7
深度强化学习中SAC算法:数学原理、网络架构及其PyTorch实现
|
17天前
|
传感器 算法
基于GA遗传优化的WSN网络最优节点部署算法matlab仿真
本项目基于遗传算法(GA)优化无线传感器网络(WSN)的节点部署,旨在通过最少的节点数量实现最大覆盖。使用MATLAB2022A进行仿真,展示了不同初始节点数量(15、25、40)下的优化结果。核心程序实现了最佳解获取、节点部署绘制及适应度变化曲线展示。遗传算法通过初始化、选择、交叉和变异步骤,逐步优化节点位置配置,最终达到最优覆盖率。
|
4月前
|
缓存 算法 物联网
基于AODV和leach协议的自组网络平台matlab仿真,对比吞吐量,负荷,丢包率,剩余节点个数,节点消耗能量
本系统基于MATLAB 2017b,对AODV与LEACH自组网进行了升级仿真,新增运动节点路由测试,修正丢包率统计。AODV是一种按需路由协议,结合DSDV和DSR,支持动态路由。程序包含参数设置、消息收发等功能模块,通过GUI界面配置节点数量、仿真时间和路由协议等参数,并计算网络性能指标。 该代码实现了节点能量管理、簇头选举、路由发现等功能,并统计了网络性能指标。
197 73
|
2月前
|
存储 网络协议 安全
30 道初级网络工程师面试题,涵盖 OSI 模型、TCP/IP 协议栈、IP 地址、子网掩码、VLAN、STP、DHCP、DNS、防火墙、NAT、VPN 等基础知识和技术,帮助小白们充分准备面试,顺利踏入职场
本文精选了 30 道初级网络工程师面试题,涵盖 OSI 模型、TCP/IP 协议栈、IP 地址、子网掩码、VLAN、STP、DHCP、DNS、防火墙、NAT、VPN 等基础知识和技术,帮助小白们充分准备面试,顺利踏入职场。
140 2
|
2月前
|
运维 负载均衡 安全
|
3月前
|
网络协议 安全 网络安全
Cisco-网络端口地址转换NAPT配置
Cisco-网络端口地址转换NAPT配置
|
3月前
|
安全 网络安全 数据安全/隐私保护
Cisco-网络地址转换动态NAT
Cisco-网络地址转换动态NAT
|
3月前
|
安全 网络安全 数据安全/隐私保护
Cisco-网络地址转换静态NAT
Cisco-网络地址转换静态NAT
|
3月前
|
传感器 算法 C语言
基于无线传感器网络的节点分簇算法matlab仿真
该程序对传感器网络进行分簇,考虑节点能量状态、拓扑位置及孤立节点等因素。相较于LEACH算法,本程序评估网络持续时间、节点死亡趋势及能量消耗。使用MATLAB 2022a版本运行,展示了节点能量管理优化及网络生命周期延长的效果。通过簇头管理和数据融合,实现了能量高效和网络可扩展性。
116 10
|
5月前
|
测试技术 数据库
探索JSF单元测试秘籍!如何让您的应用更稳固、更高效?揭秘成功背后的测试之道!
【8月更文挑战第31天】在 JavaServer Faces(JSF)应用开发中,确保代码质量和可维护性至关重要。本文详细介绍了如何通过单元测试实现这一目标。首先,阐述了单元测试的重要性及其对应用稳定性的影响;其次,提出了提高 JSF 应用可测试性的设计建议,如避免直接访问外部资源和使用依赖注入;最后,通过一个具体的 `UserBean` 示例,展示了如何利用 JUnit 和 Mockito 框架编写有效的单元测试。通过这些方法,不仅能够确保代码质量,还能提高开发效率和降低维护成本。
67 0