首页 > 编程语言 >基于PLE结合卡尔曼滤波的RSSI定位算法matlab仿真

基于PLE结合卡尔曼滤波的RSSI定位算法matlab仿真

时间:2023-12-05 15:13:39浏览次数:31  
标签:xb RSSI 卡尔曼滤波 Number PLE matlab Position rssi

1.算法运行效果图预览

 

 

 

 

 

2.算法运行软件版本

MATLAB2022a

 

3.算法理论概述

         基于PLE(Power-Law Equalizer)结合卡尔曼滤波的RSSI(Received Signal Strength Indicator)定位算法是一种利用无线信号强度进行位置估计的方法。该方法通过PLE算法对RSSI进行预处理,然后使用卡尔曼滤波器对处理后的数据进行位置和速度的估计。其整体流程图如下图所示:

 

 

 

一、基本原理

 

      PLE算法:PLE算法是一种用于提取信号特征的方法,它可以削弱多径效应等干扰因素对RSSI的影响,提高位置估计的准确性。PLE算法的核心思想是对接收到的信号强度进行幂次变换,将非线性关系转化为线性关系。具体公式如下:

 

Y = X^α

 

       其中,X表示接收到的信号强度,Y表示经过PLE处理后的信号强度,α为PLE算法的参数,需要根据实际环境进行调整。

      卡尔曼滤波器:卡尔曼滤波器是一种高效的递归滤波器,它可以通过对过去和现在的测量结果进行加权,估计未来的状态变量。在RSSI定位中,卡尔曼滤波器可以用于估计被定位物体的位置和速度。具体公式如下:

 

预测步骤:

 

X_pred = FX_est + BU

P_pred = FP_estF^T + Q

 

更新步骤:

 

Z_pred = HX_pred

Y = Z - Z_pred

K = P_predH^T*(HP_predH^T + R)^(-1)

X_est = X_pred + KY

P_est = (I - KH)*P_pred

 

其中,X_est表示估计的状态变量(即位置和速度),P_est表示估计误差协方差矩阵,F表示状态转移矩阵,B表示控制输入矩阵,U表示控制输入变量,Z表示测量值,H表示观测矩阵,Q表示过程噪声协方差矩阵,R表示测量噪声协方差矩阵,K表示卡尔曼增益矩阵,Y表示测量残差,I表示单位矩阵。

 

二、算法流程

 

初始化:设定初始位置、速度、PLE算法的参数α、卡尔曼滤波器的参数(F、B、H、Q、R)等。

PLE处理:对接收到的RSSI进行PLE处理,得到处理后的信号强度。

卡尔曼滤波:将处理后的信号强度作为测量值Z,使用卡尔曼滤波器进行位置和速度的估计。

更新估计值:根据卡尔曼滤波器的输出结果,更新估计的位置和速度。

迭代处理:重复执行步骤2-4,直到达到设定的迭代次数或收敛条件。

输出结果:输出最终估计的位置和速度。

三、优缺点

 

基于PLE结合卡尔曼滤波的RSSI定位算法具有以下优点:

 

可以削弱多径效应等干扰因素对RSSI的影响,提高位置估计的准确性。

通过对过去和现在的测量结果进行加权,可以减小测量噪声对位置估计的影响。

可以有效地利用RSSI的时空相关性,提高位置估计的稳定性。

具有较好的鲁棒性和适应性,可以适用于不同的环境和应用场景。

 

 

 

4.部分核心程序

for Num_xb = Num_xb2
    Num_xb
    Indx = Indx + 1;
    Dis        = RoomLength/(Num_xb-1); 
    for m=1:Stimes
        m
        rng(m);
        %生成节点坐标
        Position_X = (0.7*rand)*RoomLength;
        Position_Y = (0.7*rand)*RoomWidth;
        Position   = [Position_X,Position_Y];
        %计算节点到信标的距离
        for i=1:Num_xb
             XB(:,i)   = [i;(i-1)*Dis;0];
             Dist(:,i) = sqrt((Position_X-((i-1)*Dis))^2+Position_Y^2);
        end
        %基于RSS的定位算法  
        for i=1:Num_xb
            Number_rssi(1,i) = i;
            %每个信标节点的RSSI值
            if Dist(i) > Good_radius  
               Number_rssi(2,i) = 0;
            else
               Number_rssi(2,i) = func_RSSI_cal(Dist(i),Alpha);
            end
        end
        Number_rssi2 = Number_rssi;
        
        Number_rssi_save{m} = Number_rssi;
        Position_X2{m}      = Position_X;
        Position_Y2{m}      = Position_Y;
        %进行卡尔曼滤波
        %进行卡尔曼滤波
        %进行卡尔曼滤波
        tmps            = Number_rssi_save{m}(2,:);
        kalman_dat2{m}  = func_kalman(tmps); 
 
        Number_rssi(1,:)= Number_rssi_save{m}(1,:);
        Number_rssi(2,:)= kalman_dat2{m};
        Position_X  = Position_X2{m};
        Position_Y  = Position_Y2{m};
        
        %将RSSI值从大到小排列  
        for i = 1:Num_xb
            for j = i:Num_xb
                if Number_rssi(2,i) < Number_rssi(2,j)
                   a = Number_rssi(1,j);
                   b = Number_rssi(2,j);
                   Number_rssi(2,j) = Number_rssi(2,i);
                   Number_rssi(1,j) = Number_rssi(1,i);
                   Number_rssi(1,i) = a;
                   Number_rssi(2,i) = b;
                end
            end
        end
        %RSSI值最大的信标的距离
        for i=1:Best_xb
            Dist(i) = Dis*( (func_RSSI_cal(Dis,Alpha)/Number_rssi(2,i))^(1/2.8) );
        end
        %求未知节点坐标
        for i=1:Best_xb
            Beaconn(1,i) = XB(2,Number_rssi(1,i));
            Beaconn(2,i) = XB(3,Number_rssi(1,i));
        end
        All_num=Best_xb; 
        for i=1:2
            for j=1:(All_num-1)
                a(i,j) = Beaconn(i,j)-Beaconn(i,All_num);
            end
        end
        A =-2*(a');
        for i=1:(All_num-1)
            B(i,1)=Dist(i)^2-Dist(All_num)^2-Beaconn(1,i)^2+Beaconn(1,All_num)^2-Beaconn(2,i)^2+Beaconn(2,All_num)^2;
        end
        %计算X坐标
        X1    = pinv(A'*A)*A'*B;
        X_pos = X1(1,1);
        %计算Y坐标
        z    = 0;
        for j=1:Best_xb    
            z = z + sqrt(abs(Dist(j)^2-(X_pos-Beaconn(1,j))^2));
        end
        Y_pos = z/Best_xb;
        Loc = [X_pos;Y_pos];
        %点位误差
        error1(m) = sqrt((abs(Position_X-Loc(1)))^2+(abs(Position_Y-Loc(2)))^2);
        %横坐标误差
        error2(m) = abs(Loc(1)-Position_X);
        %纵坐标误差
        error3(m) = abs(Loc(2)-Position_Y);
        Number_rssis(:,m) = Number_rssi(2,:); 
    end
    Number_rssixb{Indx} = mean(Number_rssis,2);
    Number_xb{Indx}     = [1:Num_xb];
end
figure;
semilogy(Number_xb{1},Number_rssixb{1},'b-o');
grid on;
xlabel('信标数目');
ylabel('RSSI');
legend('信标数:30,RSSI排序后仿真图');
save result.mat Number_xb Number_rssixb

  

标签:xb,RSSI,卡尔曼滤波,Number,PLE,matlab,Position,rssi
From: https://www.cnblogs.com/matlabworld/p/17877235.html

相关文章

  • 基于FPGA的图像直方图统计实现,包括tb测试文件和MATLAB辅助验证
    1.算法运行效果图预览  2.算法运行软件版本vivado2019.2 matlab2022a 3.算法理论概述      基于FPGA的图像直方图统计实现主要是通过利用FPGA的并行处理能力,对图像中的每个像素进行统计,以计算出每个灰度级出现的次数或概率。这个过程涉及到对图像数据的快速......
  • 卡尔曼滤波
    1.卡尔曼滤波入门卡尔曼滤波的引入:滤波就是将测量得到的波形中的的噪声过滤掉,使得到的数据更趋于真实情况,也更加平滑,方便使用。如下图所示(红色曲线是测量直接得到的波形,紫色曲线是滤波后得到的平滑曲线)卡尔曼滤波适用的系统:卡尔曼滤波适用线性高斯系统1.线性系统:满足叠加性和......
  • MATLAB的SAVE命令动态批量保存TXT文件
    使用save();fori=1:6str=[num2str(i),’.txt’];m=[12;34];save(str,’m’,’-ascii’);%注意m的单引号,一定记得加上,否则出错end 将会得到1.txt,2.txt,3.txt,4.txt,5.txt,6.txt.(注意上段代码只是实例,不可在matlab中直接运行,因为输入可能夹杂中文符号,可能出错,最......
  • 基于Levenberg-Marquardt算法的声源定位matlab仿真
    1.算法运行效果图预览   2.算法运行软件版本matlab2022a 3.算法理论概述       Levenberg-Marquardt算法是求非线性最小二乘问题的一种优化算法。它在不需要二阶导数信息的情况下,仍然可以取得相当不错的优化效果。它对于具有强非线性性和高维度的问题,尤为......
  • 基于FPGA的RGB图像转Ycbcr实现,包括tb测试文件以及MATLAB辅助验证
    1.算法运行效果图预览 将FPGA的数据导入到matlab进行显示    2.算法运行软件版本Vivado2019.2 matlab2022a 3.算法理论概述     基于FPGA的RGB图像转Ycbcr转换的实现,主要是通过数字电路的设计,利用硬件并行处理的能力,快速完成图像数据的转换。   ......
  • 基于TDOA和FDOA的RSSI定位算法matlab仿真
    1.算法运行效果图预览仿真定位误差随着节点数量的增加而降低的变化曲线: 三种算法在不同的网络大小下的估计误差:   2.算法运行软件版本matlab2022a  3.算法理论概述      TDOA和FDOA是基于测距的定位算法中的两种常见方法,它们都是通过测量信号的到达时......
  • 基于FPGA的图像形态学膨胀算法实现,包括tb测试文件和MATLAB辅助验证
    1.算法运行效果图预览在FPGA中仿真结果如下所示:   将FPGA中的仿真结果导入到matlab显示二维图,效果如下:   2.算法运行软件版本matlab2022a vivado2019.2 3.算法理论概述      膨胀操作是形态学中另外一种基本的操作。膨胀操作和腐蚀操作的作用是相......
  • 记Redux下载后,运行examples/todos时,报错Error: error:0308010C:digital envelope rout
    1、Redux下载下载地址gitclonehttps://github.com/reactjs/redux.git进入examples/todos,下载依赖:npminstall2、问题复现及解决执行命令npmrunstart此时终端报错:Error:error:0308010C:digitalenveloperoutines::unsupported解决方法:打开package.json,修改......
  • matlab如何保存figure中去掉白边的图片
    ​输出图片成可直接调入的灰度图,设置输出图片空白边距,以及调整图片大小,纵横比。一、先显示图片,imshow。如果是plot,或者newplot,直接看“三”。imshow(strain_image,'border','tight','initialmagnification','fit');%'border','tight'的组合功能意思是去掉图像周边空白%'In......
  • MATLAB 单变量函数一阶及N阶求导
     1对一维函数的求导及求特定函数处的变量值%%最简单的一阶单变量函数进行求导functionusemyfunArray()%主函数必须位于最上方clcclearsymsx%symsx代表着声明符号变量x,只有声明了符号变量才可以进行符号运算,包括求导。%f(x)=sin(x)+x^2;%我们......