m基于RFID和DBSCAN聚类的InSAR室内三维定位算法的matlab仿真

news2025/5/24 1:27:46

目录

1.算法描述

2.仿真效果预览

3.MATLAB核心程序

4.完整MATLAB


1.算法描述

       许多室内应用需要有关物体的空间信息。示例应用程序包括项目查找,对象级别映射和在仓库或库中管理的大型对象。然而,使用802.11,可见光或声学的基于位置的服务的传统解决方案通常关注于用户,即人的位置而不是对象的位置。RFID技术通过集成RFID标签,可以在日常生活中识别和定位物体。标签反向散射的RF信号包括关于对象环境的许多信息,这些信息可用于导出对象的空间信息。为此,Malla等人。

       在本文中,我们提出了一种3D定位方案3DinSAR,用于通过分析标签反向散射载波的相位特征为室内RFID应用提供空间信息的对象。为了降低复杂性并最大限度地减少将我们的解决方案集成到现有系统的工作量,我们的方法不在环境中使用参考标签或额外的读取器天线。我们的3D定位方案仅使用一个可移动天线实现。它适用于便携式阅读器和运输车辆。

        我们的方法利用干涉合成孔径雷达(InSAR)高度确定理论。它扩展了现有的2D全息图定位方案。我们不是遍历所有耗时且因此效率不高的空间像素,而是通过使用与波路差异和标签高度相关的空间域相位差作为附加信息,将幼稚全息图定位扩展为3D方案。我们还考虑基于密度的空间聚类方法来选择最可能的位置以提高准确性。

      我们使用COTS组件实施我们的系统并在大学的办公环境中对其进行评估。使用真实硬件,我们表明我们的系统实现了定位精度,空间中位误差为0.24 m。我们的主要贡献是我们是第一个在没有任何参考标签和额外设备的情况下为基于3D RFID的本地化系统呈现真实世界的结果。

       我们设置的测试场景如下:
 

整个算法的基本流程是这样的:

第一、测量相位偏移

 

第二、计算二维全息图 

第三、

我们根据这个公式,得到xt ,即论文中介绍的 

第四、

 

第五、

然后上面的四个大的步骤,我们得到了xt,yt,zt的一堆数据点,比较散的一堆点。

此时,我们使用

这个聚类算法,分别计算xt,yt,zt中对应的最有可能的目标点。

2.仿真效果预览

matlab2022a仿真结果如下:

 

 

 

 

3.MATLAB核心程序

 
       
for sel = 1:6;   
    pos_reader=[0.2 0 0.63];
 
    N=50;
    d=zeros(1,N);
    for i=1:N;
        pos_reader(1)=0.2+0.02*(i-1);
        d(i)=norm(pos_tag(sel,:)-pos_reader);    %标签与天线之间的距离
    end
    C      = 3e8;                         %propagation speed
    f_c    = 920625000;                 %carrier frequency
    lambda = C/f_c;                  %wavelength
    phi    = [];
    std    = 5;
 
    phi_ii = mod(4*pi*d/lambda+randn(1,N)/2,2*pi);  %the measured phase offset 
 
    %WxL grid
    [w,l] = meshgrid(0.05:0.01:3,0.05:0.01:3);  
%     X     = [w(:) l(:)];
 
    P     = zeros(size(w));
    for n=1:N        
        pos_reader(1) = 0.2+0.02*(n-1);
        %网格点与天线的距离 
        d_2           = sqrt((w-pos_tag(sel,1)).^2+(l-pos_tag(sel,2)).^2);  
        P_1           = exp((mod(4*pi/lambda.*d_2,2*pi)-phi_ii(n)));   %RF holographic image
        P   =  P+real(P_1 );
    end 
 
    
    p = 0;               
    M = length(w);
    idx=0;
    x_t=[];
    y_t=[];
    [x,y]=find(P==min(min(P)));
    x_t=w(x,y);
    y_t=l(x,y);
 
    H=0.63;
    X=[];
    Y=[];
    Z=[];
    R_n=0.8;
    d_yz=sqrt((pos_tag(sel,2)-pos_reader(2))^2+(pos_tag(sel,3)-pos_reader(3))^2);
    STD=5;
    phi_yz=[];
    for j=1:STD
        phi_j=mod(4*pi*d_yz/lambda+randn(1)/2,2*pi);  
        phi_yz=[phi_yz phi_j];
    end
    phi_yz=mean(phi_yz);                        %利用InSAR时天线An测得相位 
    for B=0.01:0.01:0.34                          %改变天线高度 
        k=fix(2*B/lambda);                  %k is integer related to the antenna and tag positions
        for i=-k:1:k
            D=sqrt((pos_tag(sel,2)-pos_reader(2))^2+(pos_tag(sel,3)-pos_reader(3)-B)^2);      %天线高度为H+B时与标签距离  
            phi_B=mod(4*pi*D/lambda,2*pi);      %天线在z轴上的位置为H+B时测得的相位
            Delta_phi=phi_yz-phi_B+2*k*pi;              %相位差
            Delta_Rn=Delta_phi*lambda/(4*pi);           %天线高度改变前后与标签距离的差值
            R_n1=R_n+Delta_Rn;                          %天线高度为H+B时与标签的距离
            cosbeta=(R_n^2+B^2-Delta_Rn^2)/(2*R_n*B);   
            z_t=H+B*cosbeta;
            X=[X x_t];
            Y=[Y y_t];
            Z=[Z z_t];
        end
    end
 
    data1=[X;Y];
    data2=[Y;Z];
    data3=[X;Z];
    [k,C1] = dbscan(data1);
    [k,C2] = dbscan(data2);
    [k,C3] = dbscan(data3);
 
    X1=mean(C1(1,:));
    Y1=mean(C1(2,:));
 
    Y2=mean(C2(1,:));
    Z2=mean(C3(2,:));
 
    X3=mean(C1(1,:));
    Z3=mean(C1(2,:));
 
    X_(sel)=(X1+X3)/2;
    Y_(sel)=(Y1+Y2)/2;
    Z_(sel)=(Z2+Z3)/2;
end
01_179m

4.完整MATLAB

V

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/106128.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

浏览器里console是异步的

console我一直以为是同步执行的,直到在一本书上看到,才了解到console本身有异步的特性。虽然在平常开发中经常使用console,但是真的没有意识到它的异步性。 下面就看下异步的实例 基础类型 该类型是我们开发中经常使用的,正是这…

01VSCode配置Anaconda 环境和调试环境

VSCode配置Anaconda 环境 Anaconda 简介 自带Python解释器Anaconda 附带了一大批常用数据科学包150 多个科学包及其依赖项Anaconda 是在 conda(一个包管理器和环境管理器)上发展出来的,包含了虚拟环境管理工具通过虚拟环境可以使不同的Pyth…

【Python深度学习】RNN循环神经网络结构讲解及序列回归问题实战(图文解释 附源码)

需要全部代码请点赞关注收藏后评论区留言私信~~~ 循环神经网络 循环神经网络(Recurrent Neural Network,RNN)是用于对序列的非线性特征进行学习的深度神经网络。循环神经网络的输入是有前后关联关系的序列。 循环神经网络可以用来解决与序列…

python数据预处理时缺失值的不同处理方式!

在使用python做数据分析的时候,经常需要先对数据做统一化的处理,缺失值的处理是经常会使用到的。 一般情况下,缺失值的处理要么是删除缺失数据所在的行,要么就是对缺失的单元格数据进行填充。 今天介绍的是使用差补法/均值/固定…

CSS -- 08. 移动WEB开发之流式布局

文章目录移动WEB开发之流式布局1 移动端基础1.1 浏览器现状1.2 手机屏幕现状1.3 移动端调试方法2 视口2.1 布局视口 layout viewport2.2 视觉视口 visual viewport2.3 理想视口 ideal viewport2.4 meta视口标签3 二倍图3.1 物理像素&物理像素比3.2 多倍图3.3 背景缩放 back…

clickhouse-部署指南(亲测超详细)

文章目录环境要求测试环境Tar方式安装clickhouse用户授权访问控制服务配置启动连接测试TABIX webUI性能测试环境要求 ClickHouse可以在任何具有x86_64,AArch64或PowerPC64LE CPU架构的Linux,FreeBSD或Mac OS X上运行 官方预构建的二进制文件通常针对x86…

prometheus+grafana对数据库mysql监控

安装 mysql docker run --name mysql-test -p MYSQL ROOT_PASSWORD123456 -p23306:3306 mysql:5.7.26启动镜像的时候 已经是把docker容器内部的3306端口 映射到本机了 直接通过navicat连上 进入mysql容器内部 docker exec -it 容器id /bin/bash, 启动 mysql. docker start d…

33.flink cdc 实时数据同步利器

什么是flink cdc? 对很多初入门的人来说是无法理解cdc到底是什么个东西。 有这样一个需求,比如在mysql数据库中存在很多数据,但是公司要把mysql中的数据同步到数据仓库(starrocks), 数据仓库你可以理解为存储了各种各样来自不同数据库中表。 数据的同步…

2-2-3-7、FutureCompletableFuture详解

Runnable 线程的任务接口,用于定义被执行任务方法的抽象,是函数式接口(仅存在一个需要实现方法的接口),其方法为run方法通过对并发编程中java线程的了解,Thread调用start方法,最后操作系统会通过…

Confluence 调整会话超时(session timeout)

文章目录前言一、概括二、实际场景应用1.更改空闲超时2.更改记住我 cookie 的生命周期3.在用户通过身份验证后的某个时间强制注销用户总结前言 在 Confluence 中有两个会话 Cookie: JSESSIONID: 由 Tomcat 使用和管理。 默认情况下,这被视为会话 cooki…

类与对象(中)

类与对象类的6个默认成员函数构造函数概念特性析构函数概念特性拷贝构造函数概念特性赋值运算符重载运算符重载赋值运算符重载前置 后置 重载const成员函数取地址及const取地址操作符重载类的6个默认成员函数 当类中没有任何成员时,称作空类 但是呢,编译…

Docker使用(容器、镜像相关命令)

虚拟化 在计算机中,虚拟化(英语:Virtualization)是一种资源管理技术,是将计算机的各种实体资源,如服务器、网络、内存及存储等,予以抽象、转换后呈现出来,打破实体结构间的不可切割…

虹科方案|将以太网连接添加到Dell EMC PowerVault™ ML3 SAS库

一、Dell EMC 和 ATTO 磁带解决方案 Dell EMC 和 ATTO 提供了业界唯一的商用解决方案,可将高速以太网连接添加 到标准 SAS LTO 磁带驱动器。ATTO XstreamCORE ET 8200 智能网桥允许您使用 iSCSI 和 iSER 协议通过标准以太网远程连接到 SAS 磁带驱动器。当与采用最新…

花 2 个月备战字节跳动Java岗,3 轮面试拿下 60W Offer

最近收到一位刚入职字节的 Java 工程师朋友投稿——以下内容来自其亲身经历,某双非硕士拿到 字节 60W offer ,感谢他的走心分享(文末附硬货笔记) PART1:个人情况简介 菜 J 一枚,本硕都是计算机&#xff08…

[论文阅读] SqueezeSeg V1

文章目录1. 主要思想2. 具体方法2.1 数据处理方式2.2 网络架构3. 实验支撑4. 总结启示5. 相关文献paper 原论文的链接 code: 源代码链接 paper全称:SqueezeSeg: Convolutional Neural Nets with Recurrent CRF for Real-Time Road-Object Segmentation from 3D LiDA…

【02】FreeRTOS获取10.4.6源码+移植到STM32F407步骤

目录 1.获取FreeRTOS源码 1.1 FreeRTOS官网下载步骤 1.2FreeRTOS源码内容 1.3FreeRTOS内核文件 1.3.1Demo文件夹 1.3.2Source文件夹 2.FreeRTOS移植 2.1添加FreeRTOS源码 2.1.1复制FreeRTOS源码 2.1.2将文件添加到工程 2.1.3添加头文件路径 2.2添加FreeRTOS.h 2.3修改SYS…

vpp process类型节点调度过程

vpp节点类型 VLIB_NODE_TYPE_PROCESS:process类型节点可以被挂起也可以被恢复,main线程上调度 (免费订阅,永久学习)学习地址: Dpdk/网络协议栈/vpp/OvS/DDos/NFV/虚拟化/高性能专家-学习视频教程-腾讯课堂 process节点注册 pro…

【MC】新加载器 Quilt 好用吗?和 Fabric 相比好在哪?

在今年四月 (2022/4/20) ,一个船新加载器 Quilt 发布了第一个测试版。 Quilt officially entered its first beta today, attracting an influx of new users and an amazing amount of support and positive feedback. By the end of the day, Quilt was happily l…

Go语言设计与实现 -- 字符串

Go语言的字符串与Java和python是一样的。具有不可变性。是一个只读的字节数组,如图所示。 因为Go的字符串具有不可变性,所以我们只能通过string和[]byte类型之间反复转换实现修改。 将这一段内存复制到栈上将变量的类型转换成[]byte后并修改字节数据将修…

功能上新|使用 Excel 低门槛进行指标分析!

Kyligence Zen 功能上新啦!用户不仅可以在 Kyligence Zen 中定义、分析和管理指标,还可直接使用 Excel 插件来分析 Kyligence Zen 中已经定义好的指标,学习无门槛,上手更轻松!欢迎访问 http://zen.kyligence.io 申请免…