首页 > 编程语言 >m无线传感器网络WSN的时间同步捕获算法matlab仿真,对比单步捕获法,双步捕获法以及锯齿波匹配捕获法

m无线传感器网络WSN的时间同步捕获算法matlab仿真,对比单步捕获法,双步捕获法以及锯齿波匹配捕获法

时间:2023-04-16 22:26:06浏览次数:44  
标签:双步 相位 主机 捕获 WSN 算法 同步 节点

1.算法仿真效果

matlab2022a仿真结果如下:

 

 

 

 

 

 

 

2.算法涉及理论知识概要

2.1WSN同步概要

       由于,信息传输和计算会消耗大量的能量,无线传感器网络中的节点都是由电池供电,能源有限,让节点长时间持续时间同步过程以达到极高精确度的时钟同步将导致极大的损耗,节点持续进行时钟同步对能量有限的无线传感器网络来说是一种巨大的浪费。因此,在实际中,需要对节点的同步精度进行规划,此外,为了降低每个节点的反馈次数,可以考虑多节点协作的反馈方式。对于原算法,主机和目标节点的反馈是基于1对1的方式,即对于任何一个节点,需要进行同步,那么需要通过主机和节点之间进行反馈运算:

 

       每个节点需要做相位估计和反馈操作。为了进一步降低每个节点损耗,需要降低每个节点的运算量,那么我们采取如下的网络结构进行。

 

 

 

      即节点将相位估计的结果,以最小的功率发送到相邻节点,再由相邻节点发送给主机,这样,对于节点1,其在同一时间段内,只需要使用相位估计和短距离发送的功率,从而大大降低了单个节点的使用寿命。

 

 

 

 

 

        采用这种方式,可以大大降低发送功率,但是采用这种方式,需要在主机端设计多对一的接收机制,需要引入波速成形等技术。通过上述的思想,可以降低单个节点损耗,从而延长了单个节点的使用寿命。而采用多个相邻节点组合的方式,更进一步降低了发送节点的功耗,在接收端只要通过接收n个节点的信息来提取目标节点1的相位估计值。

 

2.2锯齿波匹配法

        利用锯齿波的这种线性特性进行分析:

 

 

 

 

       锯齿波的鉴相范围是指PFD的输出电压随相位误差单调、线性变化的范围。理想的PFD

 

的鉴相范围是,如商图所示。

 

 

 

 以上就是使用锯齿波线性特性的基本原理,下面将其特性应用到本课题中。

 

       由于实际中,主机发送的是窄脉冲信号,而不是直接发送一个相位信息,因此,需要通过将主机发送的窄脉冲信号和本地节点的锯齿波做相关操作,获得相关值。

 

2.3单步捕获算法和双步捕获算法的优缺点

       两步捕获算法(MS算法)包括两次主机捕获过程,其区别在于主机所发射的同步脉冲信号宽度。基本思想是把搜索空间内总的相位点数F划分为Q个子区间,每个子区间包括M个相位。Q和M的表示为:Q=[F/M],[ ]表示向上取整。正确相位就在某个子区间内。两步过程为:

 

第一步,粗相位的捕获:

 

 

 

        对Q个相位值,首先判断Q/2情况,计算其相关值(不同于原算法的相关运算),判断其正负,如果为正,所以真实相位<Q/2,如果为负说明真实相位>Q/2。

 

       然后进入下一个搜索区间,比如进入了1~Q/2区间,开始计算与Q/4的相关值,,,依次进行下去,那么搜索到正确值所需要的运算次数为:log2(Q)。

 

   那么其平均搜索次数为(1+log2(Q))/2 < (1+Q)/2

 

第二步:精相位的捕获:

 

    和上面同样道路,在定位粗相位的时候,开始下一步搜索,其平均搜索次数仅为

 

(1+log2(M))/2

 

 

 

3.MATLAB核心程序

 

Ts    = 100;    % 搜索的最大相位差
Ts1   = 10;     % 初步搜索步长
Ts2   = Ts/Ts1; % 初步搜索宽度,要求Ts是Ts1整数倍!
T     = 1;      % 捕获积分宽度,单位:信号周期数
 
N     = 500;    % 特定相位差条件下求均值的随机次数
pnacq = zeros(1,Ts);
nnacq = zeros(1,N);
 
 
Nacq  = zeros(1,length(fPd));       % 仿真获得不同fPd时的平均反馈次数
for pdi=1:length(fPd)
    for i=1:Ts          % 不同初始相位求平均
        rndphase = i-1; % 初始相位差, 设本振相位为0            
            rndp1 = floor(rndphase/Ts1);       % 分为两步搜索
            rndp2 = mod(rndphase,Ts1);
        for j=1:N       % 指定初始相位条件求平均
 
            nacq  = 0;                  % 捕获时长,单位:T
            curphase = rndp1;           % 主机当前调整的相位
            while(1)
                if(curphase==0)         % 正好在同步相位位置
                    if(rand()>fPd(pdi) || rand()>rPack)   % 同步漏检 或 同步确认丢失
                        curphase = Ts2-1;
                    else
                        nacq = nacq + 1; % 同步确认,设同步确认是理想的
                        break;          % 同步捕获完成
                    end;
                else
                    if(rand()<fPfa)     % 出现虚警
                        curphase = curphase -1;
                        nacq = nacq + 1;
                    else
                        curphase = curphase -1;
                    end;
                end;
            end;
            nacq = nacq+1;
            
            % 第二步搜索
            curphase = rndp2;
            while(1)
.................................................
            end;
            
            nnacq(j)=nacq+1;
        end; % end j cycle
        pnacq(i)=mean(nnacq);
 
    end; % end i cycle
    Nacq(pdi) = mean(pnacq)
 
end;
plot(fPd,Nacq,'gx-'); hold on;
save sbfkcs.mat fPd Nacq

 

  

 

标签:双步,相位,主机,捕获,WSN,算法,同步,节点
From: https://www.cnblogs.com/51matlab/p/17324247.html

相关文章

  • 源码共读 | 如何优雅的捕获 await 的错误
    前言Promise是一种在JavaScript中用于处理异步操作的机制。Promise在开发中被广泛使用,这篇文章将学习如何优雅的捕获await的错误。资源:仓库地址:await-to-js参考文章:Howtowriteasyncawaitwithouttry-catchblocksinJavascript(grossman.io)Promise的使用方法......
  • FireDAC FDScript发生异常无法捕获的问题。
    今天在调试程序时发现,如下红色标识代码执行时发生了错误(ProjectABTAYServer.exeraisedexceptionclassEMSSQLNativeExceptionwithmessage'[FireDAC][Phys][ODBC][Microsoft][ODBCSQLServerDriver][SQLServer]INSERT语句中列的数目小于VALUES子句中指定的值的数目。V......
  • m基于GA遗传优化和OSPF协议的WSN最短路由算法matlab仿真,并输出节点的不同层域
    1.算法仿真效果matlab2022a仿真结果如下:    2.算法涉及理论知识概要2.1GA遗传优化        GA把问题的解表示成“染色体”,在算法中也即是以二进制编码的串。并且,在执行遗传算法之前,给出一群“染色体”,也即是假设解。然后,把这些假设解置于问题的“环境”中,并按......
  • 为啥我请求那里都写了异常捕获了,还是报这个错?
    大家好,我是皮皮。一、前言前几天在Python白银交流群【喜靓仔】问了一个Python异常处理的问题,这里拿出来给大家分享下。二、实现过程这里粉丝给的信息十分有限,看问题其实还是挺难的,【论草莓如何成为冻干莓】给了一个指导。尝试进行断点定位问题:然后就找到了问题所在:这......
  • 3500/34 125696-01 捕获每个公交车站的GPS位置
    3500/34125696-01捕获每个公交车站的GPS位置因此,要设计特定的路线,必须为每个路线方向创建两条路线及其相应的公交车站。路线被设计成有向图,其中节点被用来表示汽车站,边被用来表示一个汽车站和另一个汽车站之间的距离。该模块使用Googlemaps的API,并对其进行扩展,以定义城市中特......
  • Android自定义捕获Application全局异常
    参考:http://bigcat.easymorse.com/?p=1152packageqianlong.qlmobile.ui;importjava.io.File;importjava.io.FileOutputStream;importjava.io.FilenameFilter;importjava.io.PrintWriter;importjava.io.StringWriter;importjava.io.Writer......
  • 学习-ts变量声明-捕获变量怪异之处
    经典面试题,varsetTimeout会在若干毫秒的延时后执行一个函数(等待其他代码执行完毕)。for(vari=0;i<10;i++){setTimeout(function(){console.warn(i);},1);//全是10}for(vari=0;i<10;i++){console.warn(i)//0-9} 未完待续。。。......
  • flask CBV写法/中间件/异常捕获/请求与响应/session/请求扩展
    flaskcbv写法基于类的视图写法fromflaskimportFlask,requestfromflask.viewsimportMethodView,Viewapp=Flask(__name__)app.debug=True#必须要继承MethodView这个类来编写classLoginView(MethodView):defget(self):print(request.method)......
  • ES6-ES11 ES9正则扩展-命名捕获分组
    视频<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="width=device-width,initial-scale=1.0"><title>......
  • .Net 6.0全局异常捕获
    背景:全局异常捕获是我们开发当中不可获取的一个环节,顾名思义就是全局的捕获异常,并响应出去,今天就带着各位童鞋们在.Net6.0当中如何做到全局异常捕获.思路:我们可......