渐进式网络恢复调研

news2024/10/9 6:30:07

渐进式网络恢复调研

问题定义(PNR)

如果发生重大网络中断(例如由地震、洪水等大规模灾害),运营商必须通过一系列修复步骤来恢复其网络基础设施。优化这个序列以在恢复过程中最大化提供的服务数量的问题通常称为渐进式网络恢复(Progressive Network Recovery,PNR)。参考

文献总结

文献等级年份方法研究对象优化目标简介
ref1CCF-A
ToN
2021确定性取整+列生成算法PSRAWRSL提出了渐进切片恢复(PSR)问题,设计了八种恢复策略;采用两阶段PSR元启发算法,通过整数线性规划模型实现快速且可扩展的切片恢复,可提高最多50%的切片恢复数量。
ref2CCF-A
JSAC
2020贪心启发RATIO+DQNPNR总效用研究了具有虚拟网络功能(VNFs)的网络中的渐进恢复问题,并引入基于深度强化学习的渐进恢复技术DeepPR来接近最优解。
ref3CCF-None2020启发算法JPRJPR累计加权内容可达性提出了一种可扩展的启发式算法用于联合渐进恢复,该算法安排网络节点/链路和数据中心的顺序修复,以最大化内容可达性
ref4CCF-C
TNSM
2018迭代随机恢复算法ISR信息不确定下PSR最小化预期恢复成本探索了在不确定故障模式下进行网络恢复的问题,并提出了一种渐进的解决方法ISR,该方法通过逐步监测,以更少的修复成本来恢复网络。
ref5CCF-A
INFOCOM
2017启发算法CeDARPDAR最大化累计需求流提出了基于中心性的损害评估和恢复算法CeDAR,解决了网络损害评估和关键服务恢复的问题。
ref12CCF-A
INFOCOM
2011整数线性规划:多阶段递归PNRAWT提出了渐进网络恢复的新范式,针对大规模故障,在多个阶段使用有限修复资源最大化网络流,并提出了高效的启发式算法和扩展方法进行解决和评估

🏷:CeDAR和ISR的作者是同一批人

研究对象与优化目标解释

PSR:progressive slice network recovery,渐进式切片恢复。在5G网络中,面对大规模灾难或有目的攻击导致的网络中断,运营商必须通过一系列恢复步骤来修复网络基础设施的问题。

“切片”(slice)是指网络中的一种虚拟网络(Virtual Network,VN),它是由网络资源在物理网络上的一部分进行分割或切分而成的。

JPR:joint progressive network联合渐进式恢复,找到最优的网络节点/链路和数据中心恢复顺序。

PDAR:progressive damage assessment and network recovery,渐进式损害评估和网络恢复。考虑了更现实的不完全损坏信息下的网络恢复问题,其中损坏评估和关键业务恢复是联合进行的。

AWRSL:accumulative weighted number of recovered slices and virtual links,累积加权已恢复切片和虚拟链路数量。

AWT:accumulative weighted total,累计加权总流量。

方法解释

整数线性规划

整数线性规划 (Integer Linear Programming,ILP)是一种优化问题求解方法,它是线性规划(Linear Programming,LP)的一种扩展。在ILP中,目标是通过找到整数值的变量,使得满足线性约束条件下的目标函数最大化或最小化。与线性规划不同,ILP要求变量的取值必须是整数,这增加了问题的复杂性,因为整数条件使问题成为NP-hard问题。

在ILP中,目标函数和约束条件都是线性的,这意味着目标函数和约束条件中的变量之间的关系可以用线性函数表示。ILP可以用于多种实际问题,如资源分配、生产调度、路径规划等。由于整数条件的引入,ILP通常需要使用特定的求解算法来找到最优解,其中一种常用的算法是分支定界法(Branch and Bound)。

ILP在计算机科学、运筹学、工程等领域都有广泛的应用,它提供了一种强大的方法来解决复杂的优化问题。然而,对于大规模问题,ILP可能变得非常复杂和耗时,因为整数条件导致了组合爆炸的可能性。在实践中,通常需要结合启发式算法或近似算法来处理大规模的ILP问题。

列生成算法

列生成算法 (Column Generation Algorithm)是一种优化算法,用于解决包含大量变量的线性规划问题。在某些线性规划问题中,变量的数量可能非常大,导致传统的线性规划方法效率低下,难以求解。列生成算法通过动态地生成和添加变量(列)来解决这个问题。

列生成算法的基本思想是,将大规模线性规划问题分解成一个主问题(Master Problem)和一个定价问题(Pricing Problem)。主问题是原始问题的一个子集,它只包含一部分变量,并且通常较容易求解。定价问题用于在每次迭代中生成新的变量,即列,以改进主问题的解。定价问题是一个子问题,其目标是找到一个新的变量(列)以增加主问题的目标函数值。

在每次迭代中,列生成算法首先求解主问题,然后求解定价问题以生成新的变量,并将新的变量添加到主问题中。然后再次求解主问题,直到找不到更多的改进变量为止。通过不断添加新的变量,列生成算法逐步扩展主问题,最终得到整个线性规划问题的最优解。

列生成算法的优点在于,它能够充分利用问题的结构和特性,避免了对所有变量进行穷举搜索,从而大大提高了求解效率。它通常用于解决大规模线性规划问题,特别是在运输、资源分配、路径规划等领域具有广泛的应用。

RATIO

RATIO算法是一种基于贪心启发式(Heuristic)策略,并受到集合覆盖问题的近似算法启发的算法。集合覆盖问题是一个经典的组合优化问题,在该问题中,需要找到最小数量的集合,使得它们的并集包含了所有的元素。该启发式算法通过计算 u ( v ) d ( v ) \frac{u(v)}{d(v)} d(v)u(v)来为每个时间步中与功能节点相邻的节点中最具成本效益的节点分配资源。即利用效用/需求来进行贪心选择。RATIO的伪代码如下:
在这里插入图片描述

DQN

DQN代表深度强化学习(Deep Q-Network),它是一种强化学习算法,最初由DeepMind提出。DQN结合了深度学习和Q-learning算法,旨在通过神经网络来学习解决复杂的强化学习问题。

在DQN中,一个神经网络被用来近似Q值函数,该函数用于评估在给定状态下采取特定行动的预期累积奖励。DQN的核心思想是使用经验回放和目标网络来稳定和加速训练过程。

经验回放是一种记忆回放技术,用于随机抽取之前的经验样本来训练网络,从而减少样本之间的相关性,增加训练的稳定性。

目标网络是另一个神经网络,用于生成目标Q值来更新主网络的参数。通过使用目标网络,DQN可以减少更新过程中的估计误差,从而使得训练更加稳定。

DQN在解决诸如视频游戏等复杂任务中取得了显著的成功。它已经被广泛应用于图像处理、自然语言处理、自动驾驶等领域,并成为强化学习领域的重要里程碑之一。

SS

在这里插入图片描述

CeDAR

CeDAR
在这里插入图片描述

JPR

启发算法JPR:
在这里插入图片描述

ISR

迭代随机恢复算法ISR

image-20230725210853583

文献链接

ref1 Zhang Q, Ayoub O, Wu J, et al. Progressive slice recovery with guaranteed slice connectivity after massive failures[J]. IEEE/ACM Transactions on Networking, 2021, 30(2): 826-839.

ref2 Ishigaki G, Devic S, Gour R, et al. DeepPR: Progressive recovery for interdependent VNFs with deep reinforcement learning[J]. IEEE Journal on Selected Areas in Communications, 2020, 38(10): 2386-2399.

ref3 Ferdousi S, Tornatore M, Dikbiyik F, et al. Joint progressive network and datacenter recovery after large-scale disasters[J]. IEEE Transactions on Network and Service Management, 2020, 17(3): 1501-1514.

ref4 Tootaghaj D Z, Bartolini N, Khamfroush H, et al. On progressive network recovery from massive failures under uncertainty[J]. IEEE Transactions on Network and Service Management, 2018, 16(1): 113-126.

ref5 Ciavarella S, Bartolini N, Khamfroush H, et al. Progressive damage assessment and network recovery after massive failures[C]//IEEE INFOCOM 2017-IEEE conference on computer communications. IEEE, 2017: 1-9.

ref12Wang J, Qiao C, Yu H. On progressive network recovery after a major disruption[C]//2011 Proceedings IEEE INFOCOM. IEEE, 2011: 1925-1933.

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

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

相关文章

Phong光照模型原理及着色器实现

现实世界中的照明极其复杂,取决于太多因素,我们无法以有限的处理能力来计算这些因素。 因此,OpenGL 中的光照基于使用简化模型的现实近似值,这些模型更容易处理并且看起来相对相似。 这些照明模型基于我们所理解的光物理学。 其中…

桥接模式-处理多维度变化

程序员小名去摆摊卖奶茶了,口味有香、甜。 型号有大、中、小。假如小名先在家里把这些奶茶装好,那么最少要装2x3 6杯奶茶,如果此时新增一个口味:酸,那么就需要多装3杯奶茶了。而且这样做,等客户买走一种&a…

c++网络编程:Boost.asio源码剖析

1、前言 Boost库是一个可移植、提供源代码的C库,作为标准库的后备,是C标准化进程的开发引擎之一。Boost库由C标准委员会库工作组成员发起,其中有些内容有望成为下一代C标准库内容。在C社区中影响甚大,是不折不扣的“准”标准库。…

HCIA练习4

题目如下: 目录 第一步:IP的规划 第二步:缺省路由 第三步:开启telnet 第四步:编写ACL表 第五步:测试 思路分析: 华为默认允许所有,所以我们可以先写拒绝要求,再写允…

MobaXterm通过SSH访问Ubuntu服务器遇到的一个问题

在Windows下的MobaXterm界面配置完ubuntuIP以后显示access denied,排查发现是因为在ubuntu那边忘记安装了SSH Serve,安装过程如下: 第一步:安装所需包 让我们从打开终端输入一些必要命令开始。 注意,在安装新的包或…

【独家解答】面试题曝光:Spring容器中的Bean会不会被GC?

大家好,我是你们的小米!今天,我们来聊一个有关Spring容器中的Bean的话题,也是面试中经常被问到的问题:“Spring 容器中的Bean是否会被GC呢?为什么?”让我们一起揭开这个神秘的面纱,解…

记录一次软件安全测试过程

一.前言 xx的安测已经过去一段时间了,这两天xx需求刚发布。xx的外呼需求文档还没确定,所以趁着这个时间,进行一下复盘。这次xx安测,全程参与,经历了3轮,从5月份开始,到6月底正式通过安测,实属不易。安测主要分为漏洞扫描、越权扫描、日志审查、软件版本基线检查下面也将…

Visual Studio 2022 程序员必须知道高效调试手段与技巧(上)

🎬 鸽芷咕:个人主页 🔥 个人专栏:《C语言初阶篇》 《C语言进阶篇》 ⛺️生活的理想,就是为了理想的生活! 文章目录 📋 前言💬 什么是bug?💬 调试是什么?有多重要&#x…

css设置八等分圆

现需要上图样式的布局,我通过两张向右方的图片,通过定位和旋转完成了布局。 问题: 由于是通过旋转获取到的样式,实际的盒子是一个长方形,当鼠标移入对应的箭头时选中的可能是其他盒子,如第一张设计稿可以看…

uniapp 语音文本播报功能

最近uniapp项目上遇到一个需求 就是在接口调用成功的时候加上语音播报 , ‘创建成功’ ‘开始成功’ ‘结束成功’ 之类的。 因为是固定的文本 ,所以我先利用工具生成了 文本语音mp3文件,放入项目中,直接用就好了。 这里用到的工…

Android adb shell 查看App内存(java堆内存/vss虚拟内存/详细的内存状况/内存快照hprof)和系统可用内存

1.adb shell 获取app 进程的pid adb shell "ps|grep com.xxx包名"根据某个渠道包,去查询对应的pid,如下所示: 2.通过adb shell 查看设备的java dalvik 堆内存的最大值 执行命令行: adb shell getprop dalvik.vm.h…

【Java SE】继承与多态

目录 【1】继承 【1.1】为什么要继承 【1.2】继承概念 【1.3】继承的语法 【1.4】父类成员访问 【1.4.1】子类中访问父类的成员变量 【1.4.2】子类中访问父类的成员变量 【1.5】super关键字 【1.6】子类构造方法 【1.7】super和this 【1.8】再谈初始化 【1.9】prot…

element-plus中的collapse组件中的箭头图标移到左边问题解决(改进版)

1、问题BUG 这个问题虽然解决了,但是依旧有一些bug,首先我们来看一下,他的样式变成了什么样的。 下面就是我们修改后的样子了,但是对于我们的需求来说,左边的箭头样式是没问题了 可是到了箭头到了右边却变成了下面的…

17_LinuxLCD驱动

目录 Framebuffer设备 LCD驱动简析 LCD驱动程序编写 LCD屏幕参数节点信息修改 LCD 屏幕背光节点信息 使能Linux logo显示 设置LCD作为终端控制台 Framebuffer设备 先来回顾一下裸机的时候LCD驱动是怎么编写的,裸机LCD驱动编写流程如下: 1.初始化I.MX6U的eLCDIF控制器,…

Gumbel Softmax Trick

Gumbel Softmax Trick 重参数化技巧(re-parameters trick)Gumbel softmax trick基于Softmax的采样基于Gumbel-max的采样基于Gumbel-softmax采样Softmax中的温度系数tau 算法学习之gumbel softmax 【Learning Notes】Gumbel 分布及应用浅析 gumbel-softma…

Failed to connect to 127.0.0.1 port 7890科学上网导致的问题

找了很多种解法: 首先这个.config配置文件有两个地方存在:先使用第一种方式,不管用再试第二种 第一个位置git安装路径:不需要重启 E:\git\Git\etc,这个需要看你自己的安装路径,找到http_proxy删除即可第二…

类型转换函数

再论类型转换 标准数据类型之间会进行隐式的类型安全转换 转换规则如下: 问题 普通类型与类类型之间能否进行类型转换? 类类型之间能否进行类型转换? 再论构造函数 构造函数可以定义不同类型的参数 参数满足下列条件时称为转换构造函数…

LocalDateTime的json格式化问题

目录 解决: 1、注册日期序列化器 2、自定义LocalDateTime的JSON格式 3、使用第三方库 总结: 实体类中定义了LocalDateTime类型的属性,获取数据会出现以下日期格式问题: 讲述: 对于LocalDateTime的JSON序列化和反序…

解析数据可视化工具:如何选择最合适的软件

在当今信息爆炸的时代,数据已成为各行各业的重要资源。为了更好地理解和分析数据,数据可视化成为一种必不可少的工具。市面上数据可视化工具不说上千也有上百,什么帆软、powerbi、把阿里datav,腾讯云图、山海鲸可视化等等等等&…

【VCS】(6)Code Coverage

Code Coverage VCS 中 Code Coverage 的类型Code Coverage Flow代码覆盖率选项Lab Code Coverage初步尝试其他格式的覆盖率报告屏蔽部分代码屏蔽整个模块 设计和验证到底要做到什么程度? 这里其中一个指标就是 Code Coverage。 代码覆盖率一般考虑以下几个方面&…