首页 > 编程语言 >基于prim算法求出网络最小生成树实现网络社团划分和规划

基于prim算法求出网络最小生成树实现网络社团划分和规划

时间:2024-10-15 20:19:58浏览次数:8  
标签:tmp 粒子 Xc Yc 网络 prim 社团 id TSP

1.程序功能描述 路线制定

1,将算法得到的各社团的需充电节点数量排序,将其视为节点权值

2,利用prim算法求出最小生成树,即完成了整个网络规划。

2.测试软件版本以及运行结果展示 MATLAB2022a版本运行

Tttttttttt12345

3.核心程序

%节点权值
W   = [];
Xz  = [];
Yz  = [];
Ridx= 0;
for j=1:length(Cpn)
    if Cpn(j) == 0%N型社团
       Ridx    = Ridx + 1; 
       tmp     = C{j,1};
       E       = Eres(tmp);
       %找到能量最小的三个
       [VV,II] = sort(E);
       %求出其质心作为停留点
       indx    = tmp(II(1:min(3,length(tmp))));
       Xz      = [Xz,mean(Xo(indx))];
       Yz      = [Yz,mean(Yo(indx))];
       %分析无需充电节点
       Nindx1  = find(E>=0.9*Ec);
       %分析需充电节点
       Nindx2  = find(E< 0.9*Ec);
       %权值
       W       = [W,length(Nindx2)];
    end
end
%权值
W
%利用prim算法求出最小生成树,即完成了整个网络规划
figure;
for j = 1:length(Cj)
    tmp = Cj{j,1};
    X0  = Xo(tmp);
    Y0  = Yo(tmp);
    plot(X0,Y0,colors{j});
    hold on
    Xc(j)= mean(X0);
    Yc(j)= mean(Y0);
    for i = 1:length(tmp)
        dist(i) = sqrt((Xc(j)-X0(i))^2 + (Yc(j)-Y0(i))^2);
    end
    if Cpn(j) == 1
       plot3(Xc(j),Yc(j),max(dist)); 
    else
       plot4(Xc(j),Yc(j),max(dist)); 
    end
    hold on
end
plot(Xc,Yc,'rs','LineWidth',2,'MarkerEdgeColor','b','MarkerFaceColor','y','MarkerSize',10)
title('社团划分结果(Red:P;Black:N),Yellow:P&N中心点');
hold on
[All_Lens,T,xx,yy]=func_prim([Xc;Yc]);
grid on;
 
%按先序遍历顺序访问
for i=1:length(T)-1
    Xc(i) = xx(T(1,i));
    Yc(i) = yy(T(1,i));
end
%统计首次通过的
Xc1 = unique(Xc);
Yc1 = unique(Yc);
%路由表,保存点坐标
[Xc1',Yc1']
12_035m


4.本算法原理 旅行商问题(Traveling Salesman Problem, TSP)是组合优化领域的一个经典NP难问题,旨在寻找访问一系列城市并返回起点的最短路径。TSP问题可以描述为:给定一个城市集合和每对城市之间的距离,要求找出访问每个城市一次并返回起点的最短路径。

4.1 遗传算法(Genetic Algorithm, GA)在TSP中的应用 遗传算法是一种模拟自然选择和遗传学机制的优化算法,适用于求解组合优化问题。在TSP问题中,GA通过编码生成初始路径种群,然后通过选择、交叉和变异等操作不断迭代优化,最终找到近似最优解。

编码方式:采用自然数编码,每个城市的编号代表一个基因,一条路径则由一串基因组成。 初始种群生成:随机生成一定数量的初始路径,构成初始种群。 适应度函数:以适应度函数来衡量每个个体的优劣。在TSP问题中,适应度函数通常取为路径长度的倒数。 选择操作:采用轮盘赌选择法,即根据每个个体的适应度值在总体适应度值中的比例来选择个体。 交叉操作:采用部分映射交叉(PMX)或顺序交叉(OX)等方法,生成新的个体。 变异操作:通过随机交换路径中两个城市的位置来实现变异。

4.2 粒子群优化算法在TSP中的应用 粒子群优化算法是一种模拟鸟群觅食行为的优化算法,适用于连续和离散优化问题。在TSP问题中,PSO将每个解看作一个粒子,通过不断更新粒子的速度和位置来寻找最优解。

  粒子表示:每个粒子表示一个可能的解,即一条路径。粒子的位置由路径中城市的排列顺序决定。
   速度更新公式:根据每个粒子的历史最优位置和群体最优位置来更新粒子的速度。速度更新公式为:(v_{id} = w * v_{id} + c1 * rand() * (pbest_{id} - x_{id}) + c2 * rand() * (gbest_d - x_{id})),其中 (v_{id}) 表示第i个粒子在第d维上的速度,(x_{id}) 表示第i个粒子在第d维上的位置,(pbest_{id}) 表示第i个粒子在第d维上的历史最优位置,(gbest_d) 表示群体在第d维上的最优位置,w为惯性权重,c1和c2为学习因子,rand()为随机数生成函数。

位置更新公式:根据更新后的速度来更新粒子的位置。位置更新公式为:(x_{id} = x_{id} + v_{id})。

   需要注意的是,在更新位置时要保证新生成的路径满足TSP问题的约束条件。

标签:tmp,粒子,Xc,Yc,网络,prim,社团,id,TSP
From: https://blog.51cto.com/u_16286143/12260248

相关文章

  • 计算机网络第1章——概述(湖科大计算机网络学习笔记)
    目录1.1信息时代的计算机网络1.1.1计算机网络的各类应用1.1.2计算机网络带来的负面问题1.1.3我国互联网发展情况1.2因特网概述1.2.1网络、互联网与因特网的区别与关系网络互联网因特网1.2.2因特网发展的三个阶段1.2.3因特网服务提供者1.2.4基于ISP的多......
  • 【网络原理大花园】https 加密技术的深度解析,让你透彻理解, 建议收藏 ~ ~ ~
    本篇会加入个人的所谓鱼式疯言❤️❤️❤️鱼式疯言:❤️❤️❤️此疯言非彼疯言而是理解过并总结出来通俗易懂的大白话,小编会尽可能的在每个概念后插入鱼式疯言,帮助大家理解的.......
  • 【SPIE独立出版】2024年第三届信息学,网络与计算技术国际学术会议(ICINC2024,10月25-27)
    2024年第三届信息学,网络与计算技术国际学术会议(ICINC2024)将于2024年10月25-27日于中国郑州召开。会议将围绕信息技术与通信,网络与计算技术等在相关领域中的最新研究成果,为来自国内外高等院校、科学研究所、企事业单位的专家、教授、学者、工程师等提供一个分享专业经验......
  • 《问题:ping自己的数据包经过了哪些网络设备?》
    问题:ping自己的数据包经过了哪些设备?在主机上ping自己,并使用wireshark抓包分析WLAN接口下抓包命令行ping结果:wireshark抓包结果:空空如也~Adapterforloopbacktrafficcapture接口下抓包回环网卡(Loopbackadaptor),是一种特殊的网络接口,不与任何实际设备连接,而是完全......
  • GZ073 网络系统管理赛项赛题第5套A模块
    2023****年全国职业院校技能大赛网络系统管理赛项模块A:网络构建(样题10)目录任务描述…3任务清单…3(一)基础配置…3(二)有线网络配置…3(三)无线网络配置…5(四)出口网络配置…7附录1:拓扑图…8附录2:地址规划表…9任务描述CII集团公司业务不断发展壮大,为适应IT......
  • 计算机网络基础进阶
    三次握手四次挥手三次握手1------建立连接----------------------2ACK=1,seq=02------传输数据,建立连接---------11------传输数据,建立连接---------2三次握手用于建立TCP连接,确保通信双方都准备好进行数据传输。整个过程涉及三次报文交换:第一次握手(客户端发送SYN):客户端......
  • 计算机网络常见面试题总结(上)
    目录计算机网络基础网络分层模型常见网络协议计算机网络基础网络分层模型OSI七层模型是什么?每一层的作用是什么?OSI七层模型是国际标准化组织提出的一个网络分层模型,其大体结构以及每一层提供的功能如下图所示:每一层都专注做一件事情,并且每一层都需要使用下一层提......
  • 20222301 2024-2025-1 《网络与系统攻防技术》实验二实验报告
    1.实验内容本次实验主要围绕渗透测试与远程执行控制展开,通过不同工具和技术手段实现了对目标主机的深入渗透与监控。实验内容可以概括为以下几个方面:1.远程Shell获取:实验首先通过`netcat`和`cron`定时任务,以及`socat`与Windows任务计划相结合的方式,实现了对目标主机的远程Shell......
  • ncnn:高性能神经网络推理框架
    ncnn:为移动设备打造的高效神经网络推理引擎ncnn是由腾讯AILab开源的一个高性能神经网络推理计算框架,专为移动平台深度优化。它的设计初衷就是为了在移动设备上高效部署和运行深度学习模型,让AI技术真正走进普通用户的日常生活中。主要特点ncnn具有以下几个突出的特点:高性......
  • 1.网工入门篇--------网络硬件通讯媒介介绍
    双绞线数据传输功能双绞线是一种常见的网络通讯媒介,主要用于传输电信号形式的数据。它能够以不同的速率传输数据,例如在常见的以太网应用中,可以支持10Mbps、100Mbps、1000Mbps(即千兆以太网)甚至更高的传输速率。这种传输速率可以满足各种规模网络的数据传输需求,从简单的家庭网......