【WSN定位】基于RSSI的加权质心定位算法-Matlab代码

news2025/7/13 8:48:20

文章目录

    • 1. 原始质心定位算法
    • 2. 基于RSSI的加权质心定位算法基本思想
    • 3. 基于RSSI的加权质心定位算法流程图
    • 4. 部分代码展示
    • 5. 运行结果展示
    • 6. 资源获取

1. 原始质心定位算法

可参考质心定位算法

2. 基于RSSI的加权质心定位算法基本思想

传统的质心算法在求解过程中只是将未知节点通信范围内所有锚节点的坐标对应相加取平均,并没有体现出不同位置的锚节点对未知节点的影响不同,也并没有充分利用未知节点收到的来自其邻居节点发送来的数据包的信息。因此,可以在无线信号 RSSI 及其模型的基础上综合考虑锚节点与未知节点的远近程度对未知节点的影响,给每个锚节点赋予不同的权值 w w w,以此来提高未知节点的坐标精确度,如公式(1)所示:
( x , y ) = ( ∑ i = 1 n w i x i ∑ i = 1 n w i , ∑ i = 1 n w i y i ∑ i = 1 n w i ) (1) (x,y)=(\frac{\sum_{i=1}^{n}w_{i}x_{i}}{\sum_{i=1}^{n}w_{i}}, \frac{\sum_{i=1}^{n}w_{i}y_{i}}{\sum_{i=1}^{n}w_{i}})\tag{1} (x,y)=(i=1nwii=1nwixi,i=1nwii=1nwiyi)(1)
其中, x x x是待定位节点的横坐标, y y y是待定位节点的纵坐标, w i w_{i} wi是对应的权值。权值该如何选取呢?根据理论知识和实验可知,RSSI 的值随着距离的增大而减少,即锚节点距离未知节点近的 RSSI 值高,反之 RSSI 值低,但是若直接用 RSSI 值作为权值会不容易使人理解。因此,可以利用 RSSI-d 距离转换公式将 RSSI 值转换成对应的距离 d i d_{i} di,将距离未知节点近的锚节点其距离值所占的权重大,反之,占的权重小,所以令 w i = 1 d i w_{i}=\frac{1}{d_{i}} wi=di1

基本思想是:将接收到的信号强度 RSSI 转换为传输距离 d d d,距离 d d d越大对未知节点影响越小,距离 d d d越小对未知节点的影响越大,与距离成反比,因此权值取 1 d i \frac{1}{d_{i}} di1,再将权值加到传统的质心算法中形成了基于 RSSI 测距的加权质心定位算法。基于 RSSI 测距的加权质心位算法的公式如下:
( x , y ) = ( ∑ i = 1 n 1 d i x i ∑ i = 1 n 1 d i , ∑ i = 1 n 1 d i y i ∑ i = 1 n 1 d i ) (2) (x,y)=(\frac{\sum_{i=1}^{n}\frac{1}{d_{i}}x_{i}}{\sum_{i=1}^{n}\frac{1}{d_{i}} }, \frac{\sum_{i=1}^{n}\frac{1}{d_{i}}y_{i}}{\sum_{i=1}^{n}\frac{1}{d_{i}}})\tag{2} (x,y)=(i=1ndi1i=1ndi1xi,i=1ndi1i=1ndi1yi)(2)

3. 基于RSSI的加权质心定位算法流程图

在这里插入图片描述

图1 基于RSSI测距的加权质心定位算法

4. 部分代码展示

% 以dm为半径,寻找每个待定位节点周围的锚节点
for i=1:1:m
d=norm((xy(:,i)-SS),2);
    if d<=dm
        % xy是锚节点坐标矩阵,是一个2行m列的矩阵,所有横坐标为第一行,纵坐标为第二行
        % xx(j,i)表示第j个待定位节点的第i个锚节点的横坐标,yy(j,i)表示第j个待定位节点的第i个锚节点的纵坐标
        for jj = 1:threshold
            d_rssi(jj)=rssi_distance(d);
        end
        q(j,i)=1/d;
        xx(j,i)=xy(1,i);
        yy(j,i)=xy(2,i);
        k=k+1;
    else
        q(j,i)=0;  
        xx(j,i)=0;
        yy(j,i)=0;
    end
end

5. 运行结果展示

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

6. 资源获取

A资源获取说明

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

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

相关文章

网络协议-加密和HTTPs证书

目录 对称加密和非对称加密 加密解密 加密方法/解密方法 对称加密/非对称加密 非对称加密&#xff08;秘钥对&#xff09; 思考 解决信任问题 证书体系 算法如何验证证书就是Alibaba 实际的证书体系 ​编辑 常见算法介绍 DES&#xff08;Data Encryption Standard&…

量子力学、波函数与量子计算:揭开宇宙微观奥秘的神奇之门

在一个遥远的星球&#xff0c;生活着一群拥有超自然力量的智慧生物。他们能够随心所欲地让物体在空间瞬移&#xff0c;甚至能够预测未来。有一天&#xff0c;一位地球科学家意外穿越到了这个星球。经过一番了解&#xff0c;科学家惊奇地发现&#xff0c;他们所掌握的这种神奇力…

ai智能文章改写软件-ai智能文案自动生成

AI同义转换&#xff0c;掀起内容创作新革命&#xff01; 如今&#xff0c;在数字化时代&#xff0c;内容创作日益受到重视&#xff0c;越来越多的人致力于网站排名优化、内容创意提升以及用户体验改善。然而&#xff0c;吸引用户阅读和提供有价值的信息并不那么容易。因此&…

云原生个人线路 K8s本地集群搭建(实操)

声明&#xff1a;此文章为博主个人学习记录&#xff0c;仅供学习和交流&#xff0c;如有侵权请联系博主。 kubernetes本地集群部署 三种方式 minikube 集群模拟器 裸机 kindminikube Docker客户端部署 裸机 环境 虚拟机 VMware 三台centos7 每台2g内存 2cpu 30g硬盘 k8s-mas…

Keil5 MDK新建项目工程

本文重点介绍基于Keil5 MDK实现新建一个完整的工程&#xff0c;第一次新建比较繁琐&#xff0c;建好后续工程可以直接复用 一、新建工程框架 1.新建一个文件夹&#xff0c;命名为Template 2.点击 MDK 的菜单: Project –>New Uvision Project &#xff0c;然后将目录定位…

( “树” 之 前中后序遍历) 145. 二叉树的后序遍历 ——【Leetcode每日一题】

基础概念&#xff1a;前中后序遍历 1/ \2 3/ \ \ 4 5 6层次遍历顺序&#xff1a;[1 2 3 4 5 6]前序遍历顺序&#xff1a;[1 2 4 5 3 6]中序遍历顺序&#xff1a;[4 2 5 1 3 6]后序遍历顺序&#xff1a;[4 5 2 6 3 1] 层次遍历使用 BFS 实现&#xff0c;利用的就是 BFS…

Git从远程仓库克隆仓库后推送到指定分支

git克隆到本地仓库 在得到一个git仓库地址后&#xff0c;首先要配置本地仓库&#xff0c;配置远程仓库地址才可以远程拉取项目。 本地配置的一般流程&#xff1a; git init初始化一个空白git仓库 2. 配置在自己额用户名和邮箱 配置个人信息时方便再团队合作时能知道是谁再何…

2023 CCBN广电展顺利召开,ATEN宏正携广电专属系列解决方案亮相

4月19日-4月21日&#xff0c;第二十九届中国国际广播电视信息网络展览会(CCBN2023)于北京市石景山区首钢会展中心盛大开幕。本届CCBN广电展以“大视听向未来”为主题&#xff0c;内容涵盖广播电视、网络视听、电影、信息化视听、视听消费电子、通信、IT等多个领域创新科技和行业…

MySQL高级第十三篇:MySQL事物日志(redo日志-undo日志执行流程)

MySQL高级第十三篇&#xff1a;MySQL事物日志&#xff08;redo日志-undo日志执行流程&#xff09; 一、概述二、redo 日志1. 为什么需要 redo日志&#xff1f;2. redo 日志的特点3. redo log 整体流程4. redo log 的刷盘策略&#xff1f; 三、undo 日志1. 什么是 undo 日志&…

1026. 节点与其祖先之间的最大差值(4-19日

题目&#xff1a;给定二叉树的根节点 root&#xff0c;找出存在于 不同 节点 A 和 B 之间的最大值 V&#xff0c;其中 V |A.val - B.val|&#xff0c;且 A 是 B 的祖先。 &#xff08;如果 A 的任何子节点之一为 B&#xff0c;或者 A 的任何子节点是 B 的祖先&#xff0c;那么…

context 浅析

在缺少直接调用关系的两个函数之间传递数据&#xff0c;一般都会考虑使用 context&#xff0c;而 context 也被用来存储整个请求链路的公参信息&#xff0c;用户 uid、链路 traceID、特定的业务参数等。函数第一个参数类型设置为 context.Context 也是 Go 的默认写法&#xff0…

2 常见模块库(3)

2.9 积分模块&#xff08;2&#xff09; External reset: 在什么条件下进行外部重置操作描述一下每个选项&#xff1a; Rising&#xff1a;当重置信号从非正的值&#xff08;0或负值&#xff09;变为正值时&#xff0c;重置积分器的状态。 Falling&#xff1a;当重置信号从正…

Java每日一练(20230419)

目录 1. 二叉树的最大深度 &#x1f31f; 2. 二叉树的层序遍历 &#x1f31f;&#x1f31f; 3. 最短回文串 &#x1f31f;&#x1f31f;&#x1f31f; &#x1f31f; 每日一练刷题专栏 &#x1f31f; Golang每日一练 专栏 Python每日一练 专栏 C/C每日一练 专栏 Jav…

双向带头循环链表的实现

双向带头循环链表 双向带头循环链表结构讲解期望实现功能创建链表和头节点作用头插和头删头插头删 尾插与尾删尾插尾删 pos 删除和插入插入删除 打印和查找 整体代码 这个数据结构可以算是YYDS的存在了。 我们前面讲过的单链表&#xff0c;尾删和尾插需要遍历数组&#xff0c;极…

是时候该换掉你的axios了

axios是一个基于Promise的HTTP客户端&#xff0c;每周的npm下载量4000W&#xff0c;如果回到在10年前&#xff0c;promise式的请求工具是一个很大的创新&#xff0c;它解决了请求繁琐的问题&#xff0c;在那个性能要求不那么高的年代可谓是一骑绝尘。但随着时间的推移&#xff…

【网络】UDP协议 TCP协议

&#x1f941;作者&#xff1a; 华丞臧. &#x1f4d5;​​​​专栏&#xff1a;【网络】 各位读者老爷如果觉得博主写的不错&#xff0c;请诸位多多支持(点赞收藏关注)。如果有错误的地方&#xff0c;欢迎在评论区指出。 推荐一款刷题网站 &#x1f449; LeetCode刷题网站 文章…

Centos7安装Elasticsearch6.4.3和Kibana6.4.3

一、下载好安装文件上传到/usr/local 二、安装Java环境 1&#xff09;、解压jdk tar -zxvf jdk-8u181-linux-x64.tar.gz2&#xff09;、 配置Java环境变量 vim /etc/profile 3&#xff09;、profile末尾添加 export JAVA_HOME/usr/local/jdk1.8.0_181 export PATH$JAVA_HO…

【2023 · CANN训练营第一季】昇腾AI入门课(Pytorch)---昇腾AI入门课(PyTorch)微认证考试

1、下列不属于昇腾计算服务层的是() 2、AscendCL的优势包括() 3、使用AscendCL开发应用的基本流程&#xff0c;以下正确的是&#xff1f; 4、关于AscendCL初始化&#xff0c;以下说法不正确的是&#xff1f; 5、以下关于ATC工具说法正确的是 6、模型转换工具的名称是&#xf…

深入实战探究 Vue 2.7 Composition API 的强大之处

最近几年公司开发一直使用的是 Vue2.6&#xff0c;对于逻辑复用使用的是 Mixin 方式&#xff0c;但随着项目体量的增加&#xff0c;带了一些问题&#xff0c;特别是&#xff1a;数据混乱问题&#xff1a;实例上的数据属性从当前模板文件中无法查取到&#xff0c;存在多个 Mixin…

API 鉴权都有哪些分类,这些重点不要错过

API鉴权是保证API安全性和可用性的一项重要措施。通过API鉴权&#xff0c;系统可以对用户或者应用进行有效的身份认证和权限管理。一般来说&#xff0c;在实际开发中&#xff0c;我们使用以下几种API鉴权方式&#xff1a; 1. 基本认证 基本认证是API鉴权的一种最基本形式。此方…