首页 > 编程语言 >m基于最小生成树算法的无线传感器网络MCDS生成matlab仿真

m基于最小生成树算法的无线传感器网络MCDS生成matlab仿真

时间:2023-04-02 22:24:47浏览次数:42  
标签:Node 连通 最小 MCDS Num WSN matlab 生成

1.算法描述

       一个有 n 个结点的连通图的生成树是原图的极小连通子图,且包含原图中的所有 n 个结点,并且有保持图连通的最少的边。 最小生成树可以用kruskal(克鲁斯卡尔)算法或prim(普里姆)算法求出。图的所有生成树中具有边上的权值之和最小的树称为图的最小生成树 (Minimum Spanning Tree,MST) ;一个连通图的生成树是一个极小连通子图,它含有图中全部顶点,但只有构成一棵树的 n − 1 n-1n−1 条边;对于一个带权 (假定每条边上的权均为大于零的数) 连通无向图 G GG 中的不同生成树,其每棵树的所有边上的权值之和也可能不同;简单来说,对于一个有 n nn 个点的图,边一定是大于等于 n − 1 n-1n−1 条的,最小生成树就是在这些边中选择 n − 1 n-1n−1 条出来连接所有的 n nn 个点,且这n − 1 n-1n−1 条边的边权之和是所有方案中最小的;

 

        对于一个带权连通无向图G=(V,E),生成树不同,每棵树的权(树中所有边上的权值和)也不同,设R为G的所有生成树的集合,若T为R中权值和最小的生成树,则T称为G的最小生成树(Minimum-Spanning-Tree,MST)

 

注:

 

1、最小生成树可能有多个,但边的权值之和总是唯一且最小的

 

2、最小生成树的边数=定点数-1,砍掉一条则不连通,增加一条则会出现回路

 

3、若一个连通图本身就是一颗树,则其最小生成树就是它本身

 

4、只有连通图才有生成树,非连通图只有生成森林

 

       无线传感器网络(Wireless Sensor Networks, WSN)是一种整合了传感器,网络以及微机电的新型网络技术。WSN具有低功耗、自组织、低成本以及部署方便等优势。因此,WSN被广泛应用在各种通信场景中,如环境监测、火灾预警以及军事防化领域等[]。为了提升WSN的通信性能,降低WSN的能耗,构建WSN的最小连通支配集(Minimum Connected Dominating Set, MCDS)具有十分重要的意义。

 

       在WSN对应的图定义为G=(V, E, R),V表示的是WSN中所有的节点集合,E表示边的集合,R表示的是WSN节点的可通信半径。假设图G为全连通图,图中所有节点的连接为双向连接。其中,图G的支配集(Dominating Set, DS)可以定义为如下表达式:

 

 

 

 

公式1中,如果D中至少存在一个节点u与之相邻,此时D为图G的一个支配集。进一步,连通支配集(Connected Dominating Set, CDS)可以定义为如下表达式:

 

 

 

 

        公式2的含义为当V中任意一个节点属于D或者至少与D中的某个节点连接。其中D表示支配集DS,。那么当DS为连通的,此时DS即为CDS。由于CDS的集合并不是唯一的,其中规模最小的即被称之为MCDS。

 

2.仿真效果预览

matlab2022a仿真结果如下:

 

 

 

 

 

 

 

 

 

 

 

 

3.MATLAB核心程序

 

%初始化无线传感器网络的节点坐标点
Radius    = 25;
Node_Nums = [40:10:150];
for ii = 1:length(Node_Nums)
    ii
    for jj = 1:50
        rng(jj);
        Node_Num = Node_Nums(ii);
        for i=1:Node_Num
            Posxy(i,1)=150*rand(1,1);
            Posxy(i,2)=100*rand(1,1);
        end
        %网络图参数提取
        %度
        %将网络图转换为矩阵的变量
        Connect_matrix = zeros(Node_Num,Node_Num);
        W              = zeros(Node_Num,Node_Num);
        D              = [];%度数
        for i=1:Node_Num
            num = 0;
            for j=1:Node_Num
                if i~=j
                    dist = (Posxy(i,1)-Posxy(j,1))^2+(Posxy(i,2)-Posxy(j,2))^2;
                    if dist < Radius^2 
                       num                 = num+1;
                       Connect_matrix(i,j) = 1;
                    end
                end
            end
            d(i) = num;
            D    = [D,d(i)];%计算度数
        end
 
        x = Posxy(:,1);
        y = Posxy(:,2);
 
    %%
    %下面是对比算法,直接通过最小生成树来产生MCDS,放这里,我们作为对比使用
        [X_,Y_,M,MD,T]=func_tree(Connect_matrix,Node_Num,W,x,y,D);
        Sizes = length(M);
        Ti(jj)= Sizes/Node_Num;
    end
    Ti1(ii)= mean(Ti);
end
p   = polyfit(Node_Nums,Ti1,4);
Ti2 = polyval(p,Node_Nums);

 

  

 

标签:Node,连通,最小,MCDS,Num,WSN,matlab,生成
From: https://www.cnblogs.com/51matlab/p/17281557.html

相关文章

  • m基于WOA优化的SVM乳腺癌细胞和正常细胞分类识别算法matlab仿真,对比BP网络,SVM,PSO+S
    1.算法描述       SVM是有监督的学习模型,我们需要事先对数据打上分类标签,通过求解最大分类间隔来求解二分类问题。如果要求解多分类问题,可以将多个二分类器组合起来形成一个多分类器。        WOA算法设计的既精妙又富有特色,它源于对自然界中座头鲸群体狩猎行......
  • k8s快速生成yaml的两种方式
    第一.kubectlcreate命令[root@k8s-master~]#kubectlcreatedeploymentnginx--image=nginx-oyaml--dry-run#不创建pod,打印出来W010616:21:43.89167917615helpers.go:663]--dry-runisdeprecatedandcanbereplacedwith--dry-run=client.apiVersion:apps/v......
  • 生成数字
     importmcpi.minecraftasminecraftimportmcpi.blockasblockmc=minecraft.Minecraft.create()#3*5区域清空defcleanField(baseX,baseY,baseZ):mc.setBlocks(baseX,baseY,baseZ,baseX,baseY+4,baseZ+2,block.AIR.id)defshowScore(baseX,......
  • 生成数字csv
    csv文件: importtimeimportmcpi.minecraftasminecraftimportmcpi.blockasblockmc=minecraft.Minecraft.create()#3*5区域清空defcleanField(baseX,baseY,baseZ):mc.setBlocks(baseX,baseY,baseZ,baseX,baseY+4,baseZ+2,block.AIR.id)......
  • matlab神经网络训练函数和性能函数
    Theresponseisderivedfromwebsearchresults.Hereisatablethatsummarizessomeoftheadvantages,disadvantagesandapplicationsofdifferenttrainingfunctionsandperformancefunctionsforneuralnetworks.训练函数性能函数优点缺点应用场合......
  • 使用 MybatisPlusCore 自带的雪花算法生成不重复数字
    这里不介绍雪花算法的实现原理,可以自行搜索查阅网上的资料。这里主要介绍雪花算法的使用场景,如何调用第三方类库MybatisPlusCore自带的方法来使用雪花算法。雪花算法的主要使用场景,就是生成不重复的数字,作为数据库表的主键使用。你可能会使用uuid作为主键,但是其占用16个......
  • 前端通过Swagger生成相关接口文件
    1.Swagger 多分组在很多大型系统中,为了方便对接口进行归类,往往使用了 Swagger 多分组功能,这样会使系统的接口散落在多个 swagger.json 中。将SpecificationDocumentSettings属性的EnableAllGroups设置为true。启用之后在 Swagger 导航栏顶部下拉分组将出现......
  • tkinter生成列表
    importtkinterfromtkinterimportttkfromtkinterimport*importpymysql#导入消息对话框子模块importtkinter.messageboxdefselect_student_study():    root=Tk()    root.title('自习时间')  root.geometry('600x800')  root.confi......
  • 使用mybatis-plus方法自动生成代码(1)
    首先,在项目的pom.xml文件中添加如下依赖:<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-generator</artifactId><version>3.4.3</version></dependency><dependency><groupId&......
  • DB First生成实体层的命令行
    使用EFCore,需要先安装几个依赖包  命令行:Scaffold-DbContext"Server=localhost;Database=smallapp;User=root;Password=12345"MySql.EntityFrameworkCore......