基于无线传感器网络的MCKP-MMF算法matlab仿真

本文涉及的产品
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
实时计算 Flink 版,5000CU*H 3个月
简介: MCKP-MMF算法是一种启发式流量估计方法,用于寻找无线传感器网络的局部最优解。它从最小配置开始,逐步优化部分解,调整访问点的状态。算法处理访问点的动态影响半径,根据带宽需求调整,以避免拥塞。在MATLAB 2022a中进行了仿真,显示了访问点半径请求变化和代价函数随时间的演变。算法分两阶段:慢启动阶段识别瓶颈并重设半径,随后进入周期性调整阶段,追求最大最小公平性。

1.程序功能描述
基于流量估计,MCKP-MMF算法便可以找到本地MCKP-MMF的近似解。其基本思想与MMKP-MMF相似,但是相比之下,MCKP-MMF采取了更为简单的策略从而使之成为一种启发式算法并且运行更快。算法从最小配置开始,并将所有访问点初始化为活动状态。此后,算法在执行的每一轮中发现一个较好的部分解,并将相关的访问点置为停止状态,直至所有访问点都成为停止状态,算法终止。

1.png

某个访问点可能先后收到来自多个拥塞节点的重新设置影响半径的要求,此时为了满足带宽消耗最大的节点的带宽限制,访问点需要将其新影响半径设置为其中最小的一个。一种简单的方法是每次收到这样的请求之后,将其中包含的新影响半径与访问点当前影响半径比较,如果新影响半径较小则修改当前影响半径为新影响半径,否则访问点保持当前影响半径。这样作的一个副作用是访问点的影响半径将随时间增长而变小。从另一方面,节点由于仅通过本地信息为与之相关的访问点确定影响半径,可能无法得到访问点真正的最优影响半径。为了消除这个副作用并帮助访问点跳出本地最优状态从而更接近全局最优配置,每个访问点需要周期性的增加其影响半径。

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

2.jpeg
3.jpeg
4.jpeg
5.jpeg
6.jpeg

3.核心程序
```while(times <Stimes)
figure(2);
plot(Xn,Yn,'b.');
hold on;
plot(Xm,Ym,'r.');
hold on;

 times
 times    = times + 1;
 SATVs    = SATV*ones(1,N);

Tpk = zeros(M,1); %代价函数
NEXT_ptr = 0;
NEXT_Set = ones(1,M);

while(NEXT_ptr<= M)
%所有活动访问点半径均被增加且所得为合适解
%计算代价函数
for j = 1:M
for i1 = 1:N
d = sqrt( (Xn(i1) - Xm(j))^2 + (Yn(i1) - Ym(j))^2 );
%判断是否在一定范围之内
if d <= Rs(j)
%进行资源分配
Tpk(j) = Tpk(j) + Requst(j,i1);
else
Tpk(j) = Tpk(j);
end
end
end

     [A,I]             = sort(Tpk);

     if A > 0
        %选择最小的一个

Tpk_min = A(1);
Tpk_ind = I(1);
NEXT_Set(Tpk_ind) = 0;
if feasible(A,rij) == 1
%没有被违反
Rs(Tpk_ind) = Rs(Tpk_ind) + Step;
if (NEXT_Set(Tpk_ind)) == 0
NEXT_ptr = NEXT_ptr;
else
NEXT_ptr = NEXT_ptr + 1;
end
else
%违反了,则直接退出进入下一个循环
NEXT_ptr = M+1;
end
else
%如果流量为0,则说明没有发生任何请求,其实半径自动递增
Tpk_min = A(1);
Tpk_ind = I(1);
Rs(Tpk_ind) = Rs(Tpk_ind) + Step;
end
end

 %多个拥塞节点的重新设置影响半径
 for j = 1:M
     %表示该访问点处于第1阶段
     if FLag(j) == 0
        %计算每个节点到访问点的距离
        for i1 = 1:N
            d = sqrt( (Xn(i1) - Xm(j))^2 + (Yn(i1) - Ym(j))^2 );
            %判断是否在一定范围之内
            if d <= Rs(j)
               %进行资源分配
               SATVs(1,i1) = SATVs(1,i1) - Requst(j,i1);
            else
               SATVs(1,i1) = SATVs(1,i1); 
            end    
            %每次请求完之后,判断是否拥堵
            if SATVs(1,i1) <= 0%表示拥堵

saturated_state{j,i1} = [1,Rs',Xm(j),Ym(j),Xn(i1),Yn(i1)];
FLag(j) = 1;
else
saturated_state{j,i1} = [0,zeros(1,M),0,0,0,0];
FLag(j) = FLag(j);
end
end
end
%**
end
%绘制仿真结果
figure(3);
subplot(421);
plot(R(1,:),'b','linewidth',2);
xlabel('TIMES');
ylabel('Radius');
grid on;
title('资源点1半径请求变化');
subplot(422);
plot(R(2,:),'b','linewidth',2);
xlabel('TIMES');
ylabel('Radius');
grid on;
title('资源点2半径请求变化');
subplot(423);
plot(R(3,:),'b','linewidth',2);
xlabel('TIMES');
ylabel('Radius');
grid on;
title('资源点3半径请求变化');
subplot(424);
plot(R(4,:),'b','linewidth',2);
xlabel('TIMES');
ylabel('Radius');
grid on;
title('资源点4半径请求变化');
subplot(425);
plot(R(5,:),'b','linewidth',2);
xlabel('TIMES');
ylabel('Radius');
grid on;
title('资源点5半径请求变化');
subplot(426);
plot(R(6,:),'b','linewidth',2);
xlabel('TIMES');
ylabel('Radius');
grid on;
title('资源点6半径请求变化');
subplot(427);
plot(R(7,:),'b','linewidth',2);
xlabel('TIMES');
ylabel('Radius');
grid on;
title('资源点7半径请求变化');
subplot(428);
plot(R(8,:),'b','linewidth',2);
xlabel('TIMES');
ylabel('Radius');
grid on;
title('资源点8半径请求变化');
%绘制仿真结果
figure(4);
subplot(421);
plot(TPK(1,10:end),'b','linewidth',2);
xlabel('TIMES');
ylabel('代价函数');
grid on;
title('资源点1代价函数');
subplot(422);
plot(TPK(2,10:end),'b','linewidth',2);
xlabel('TIMES');
ylabel('代价函数');
grid on;
title('资源点2代价函数');
subplot(423);
plot(TPK(3,10:end),'b','linewidth',2);
xlabel('TIMES');
ylabel('代价函数');
grid on;
title('资源点3代价函数');
subplot(424);
plot(TPK(4,10:end),'b','linewidth',2);
xlabel('TIMES');
ylabel('代价函数');
grid on;
title('资源点4代价函数');
subplot(425);
plot(TPK(5,10:end),'b','linewidth',2);
xlabel('TIMES');
ylabel('代价函数');
grid on;
title('资源点5代价函数');
subplot(426);
plot(TPK(6,10:end),'b','linewidth',2);
xlabel('TIMES');
ylabel('代价函数');
grid on;
title('资源点6代价函数');
subplot(427);
plot(TPK(7,10:end),'b','linewidth',2);
xlabel('TIMES');
ylabel('代价函数');
grid on;
title('资源点7代价函数');
subplot(428);
plot(TPK(8,10:end),'b','linewidth',2);
xlabel('TIMES');
ylabel('代价函数');
grid on;
title('资源点8代价函数');
12_008m

```

4.本算法原理
算法的执行可以分为两个阶段。第一阶段是通常所谓的慢启动阶段,在该阶段,各个sink开始于最小半径的请求,然后以某种速度增加其请求半径,直到算法发现一个潜在的瓶颈节点,此时相关sink将收到消息。算法中initRadius过程负责确定每次增加请求半径。某个sink收到一个消息之后重新设置其请求半径为某一较小值以试图缓解拥塞。 resetRadius过程负责在收到消息之后计算新的请求半径。该sink随后进入算法的第二阶段。进入第二阶段的sink将周期性的试图增加其请求半径,以取得最优 max-min公平请求半径。此步骤由increaseRadius过程处理。这样增加的结果是,不久之后该sink再次收到消息并缩小请求半径,而后再次周期性增加。

    所有sink同时发出请求,并将初始半径设置为最小值。然后所有sink以同步方式增加请求半径直到网络中某一传感器节点上的数据流量饱和(该节点被称为瓶颈节点)。当某个传感器节点流量饱和时,覆盖该节点的所有sink停止增加其请求半径,但是其它sink继续增加其请求半径。当没有sink可以继续增加其请求半径时,算法结束。我们说此算法的解为最优解是因为该算法的解满足max-min公平性的同时被全局或局部最大化。
相关文章
|
2天前
|
算法 数据安全/隐私保护
基于AutoEncode自编码器的端到端无线通信系统matlab误码率仿真
本项目基于MATLAB 2022a实现自编码器在无线通信系统中的应用,仿真结果无水印。自编码器由编码器和解码器组成,通过最小化重构误差(如MSE)进行训练,采用Adam等优化算法。核心程序包括训练、编码、解码及误码率计算,并通过端到端训练提升系统性能,适应复杂无线环境。
98 65
|
1天前
|
算法
基于排队理论的客户结账等待时间MATLAB模拟仿真
本程序基于排队理论,使用MATLAB2022A模拟客户结账等待时间,分析平均队长、等待时长、不能结账概率、损失顾客数等关键指标。核心算法采用泊松分布和指数分布模型,研究顾客到达和服务过程对系统性能的影响,适用于银行、超市等多个领域。通过仿真,优化服务效率,减少顾客等待时间。
|
1天前
|
算法
基于电导增量MPPT控制算法的光伏发电系统simulink建模与仿真
本课题基于电导增量MPPT控制算法,使用MATLAB2022a的Simulink进行光伏发电系统的建模与仿真,输出系统电流、电压及功率。电导增量调制(IC)算法通过检测电压和电流变化率,实时调整光伏阵列工作点,确保其在不同光照和温度条件下始终处于最大功率输出状态。仿真结果展示了该算法的有效性,并结合PWM技术调节逆变流器占空比,提高系统效率和稳定性。
|
2天前
|
传感器 算法 物联网
基于粒子群算法的网络最优节点部署优化matlab仿真
本项目基于粒子群优化(PSO)算法,实现WSN网络节点的最优部署,以最大化节点覆盖范围。使用MATLAB2022A进行开发与测试,展示了优化后的节点分布及其覆盖范围。核心代码通过定义目标函数和约束条件,利用PSO算法迭代搜索最佳节点位置,并绘制优化结果图。PSO算法灵感源于鸟群觅食行为,适用于连续和离散空间的优化问题,在通信网络、物联网等领域有广泛应用。该算法通过模拟粒子群体智慧,高效逼近最优解,提升网络性能。
|
2天前
|
机器学习/深度学习 数据采集 算法
基于GWO灰狼优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真
本项目基于MATLAB2022a,展示了时间序列预测算法的运行效果(无水印)。核心程序包含详细中文注释和操作视频。算法采用CNN-GRU-SAM网络,结合灰狼优化(GWO),通过卷积层提取局部特征、GRU处理长期依赖、自注意力机制捕捉全局特征,最终实现复杂非线性时间序列的高效预测。
|
19小时前
|
算法
基于SOA海鸥优化算法的三维曲面最高点搜索matlab仿真
本程序基于海鸥优化算法(SOA)进行三维曲面最高点搜索的MATLAB仿真,输出收敛曲线和搜索结果。使用MATLAB2022A版本运行,核心代码实现种群初始化、适应度计算、交叉变异等操作。SOA模拟海鸥觅食行为,通过搜索飞行、跟随飞行和掠食飞行三种策略高效探索解空间,找到全局最优解。
|
19小时前
|
算法 数据可视化 数据安全/隐私保护
一级倒立摆平衡控制系统MATLAB仿真,可显示倒立摆平衡动画,对比极点配置,线性二次型,PID,PI及PD五种算法
本课题基于MATLAB对一级倒立摆控制系统进行升级仿真,增加了PI、PD控制器,并对比了极点配置、线性二次型、PID、PI及PD五种算法的控制效果。通过GUI界面显示倒立摆动画和控制输出曲线,展示了不同控制器在偏转角和小车位移变化上的性能差异。理论部分介绍了倒立摆系统的力学模型,包括小车和杆的动力学方程。核心程序实现了不同控制算法的选择与仿真结果的可视化。
24 13
|
6月前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
272 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
6月前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
162 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
|
6月前
|
数据采集 存储 移动开发
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码
本文介绍了2023年五一杯数学建模竞赛B题的解题方法,详细阐述了如何通过数学建模和MATLAB编程来分析快递需求、预测运输数量、优化运输成本,并估计固定和非固定需求,提供了完整的建模方案和代码实现。
138 0
【2023五一杯数学建模】 B题 快递需求分析问题 建模方案及MATLAB实现代码