【TDOA最小二乘解算】两步最小二乘迭代的TDOA解算方法,适用于二维平面、自适应锚点(附MATLAB代码)

news2024/11/21 22:23:43

请添加图片描述

本文所述的MATLAB代码实现了一个基于两步加权最小二乘法的二维目标定位算法,利用多个锚点(基站)和时间差到达(TDOA)数据来估计未知目标的位置。

文章目录

  • 运行结果
  • 代码
  • 代码功能概述
  • 代码结构和详细说明
    • 初始化部分
    • 参数和待测点位置定义
    • 生成目标轨迹
    • TDOA建模
    • 距离差计算
    • 迭代初值估算
    • 最小二乘迭代
      • 粗迭代部分
      • 细节迭代部分
    • 最小二乘解
    • 结果绘图
    • 10. 输出结果
  • 总结

运行结果

  • 3个锚点时的情况:
    在这里插入图片描述
  • 10个锚点时的情况:
    在这里插入图片描述
  • 可一键更改锚点数量:
    在这里插入图片描述

  • 命令行会输出真实值和估计值的坐标信息:
    在这里插入图片描述

代码

% 两步加权最小二乘,定位二维目标、N个锚点
% 2024-11-07/Ver1
%% 初始化
clc;clear;close all;
rng(1);
% 定义参数和待测点位置
num_stations = 10; % 基站数量(锚点数量)
std_var1 = 1e-9; %TDOA误差
% 固定基站位置
stations_position = 100*randn(num_stations,2);
c = 3e8;
% 生成轨迹数组
position = 50*ones(1,2)+50*randn(1,2);
% TDOA 建模

% 完整代码见:https://gf.bilibili.com/item/detail/1106616012

代码功能概述

该代码模拟了一个二维空间中的目标定位问题,使用随机生成的锚点位置和目标轨迹,并通过最小二乘法进行位置估计。目标的真实位置与估计位置通过图形可视化展示,便于对算法效果的直观理解。

代码结构和详细说明

初始化部分

clc; clear; close all;
rng(1);
  • clc:清除命令窗口的内容。
  • clear:清除工作空间中的所有变量。
  • close all:关闭所有打开的图形窗口。
  • rng(1):设置随机数生成器的种子,以确保结果的可重复性。

参数和待测点位置定义

num_stations = 10; % 基站数量(锚点数量)
std_var1 = 1e-9; % TDOA误差
stations_position = 100 * randn(num_stations, 2); % 随机生成基站位置
c = 3e8; % 声速
  • num_stations:定义基站的数量,这里设为10个。
  • std_var1:设定TDOA测量的标准差,用于模拟测量误差。
  • stations_position:随机生成基站在二维空间中的位置,坐标值为正态分布。
  • c:定义声速(单位:米/秒)。

生成目标轨迹

position = 50 * ones(1, 2) + 50 * randn(1, 2);
  • 生成一个目标位置,初始位置为(50, 50)附近的一个随机点。

TDOA建模

delta = ones(num_stations, 1) * position - stations_position; % 计算未知点与基站的相对位置
r_ideal = (sum(delta.^2, 2)).^(1/2); % 计算理想距离
delta_t = r_ideal / c + std_var1 * randn(size(r_ideal)); % 计算TDOA并添加噪声
r = delta_t * c; % 计算实际距离
  • delta:计算未知目标与各基站之间的相对位置(矢量)。
  • r_ideal:根据相对位置计算目标到各个基站的理想距离。
  • delta_t:根据理想距离计算到达时间,并添加高斯噪声。
  • r:将到达时间转换为实际距离。

距离差计算

Ri = r(2:end, :);
R1 = ones(num_stations - 1, 1) * r(1, :);
R = Ri - R1; % 计算距离差
  • 计算从第一个基站到其他基站的距离差,这将用于后续的最小二乘法计算。

迭代初值估算

position_est = mean(stations_position); % 基站位置均值作为初始估计
  • 使用所有基站位置的均值作为初始位置估计。

最小二乘迭代

for i1 = 1:100 % 可设置迭代次数
    ...
end
  • 迭代100次以优化位置估计,每次迭代计算新的位置估计。

粗迭代部分

h = (R(1))^2 + norm(stations_position(1, :))^2 - norm(stations_position(2, :))^2 + 2 * (R(1)) * norm(position_est - stations_position(1, :));
Ga = 2 * (stations_position(1, :) - stations_position(2, :));
B = 2 * diag([norm(position_est - stations_position(2, :));]);
  • 计算初步的残差和雅可比矩阵的构造。

细节迭代部分

for i2 = 3:num_stations
    ...
end
  • 在每次迭代中,更新残差h和雅可比矩阵A,并计算最小二乘解。

最小二乘解

Q = std_var1^2 * (0.5 * eye(num_stations - 1) + 0.5 * ones(num_stations - 1));
W = (B * Q * B')^(-1); % 计算加权矩阵
u_star = (Ga' * W * Ga)^(-1) * Ga' * W * h; % 计算最小二乘解
  • 构造加权矩阵W,计算最小二乘解u_star,用于更新位置估计。

结果绘图

figure;
hold on
plot(stations_position(:, 1), stations_position(:, 2), 'r*'); % 绘制基站位置
plot(position(1), position(2), 'ok'); % 绘制真实目标位置
plot(position_est(1), position_est(2), '.b'); % 绘制估计目标位置
xlabel('X轴'); ylabel('Y轴');
legend('锚点', '真实值', '估计值');
  • 可视化锚点、真实位置和估计位置,便于观察定位效果。

10. 输出结果

fprintf('真实值坐标:%s\n', num2str(position));
fprintf('估计值坐标:%s\n', num2str(position_est));
  • 打印真实目标位置和估计位置的坐标。

总结

M A T L A B MATLAB MATLAB代码使用两步加权最小二乘法通过 T D O A TDOA TDOA技术实现了二维目标定位。它通过随机生成的锚点和目标位置进行模拟,展示了如何通过迭代优化算法来提高位置估计的准确性。代码结构清晰,适合用于理解和实现基于 T D O A TDOA TDOA的定位算法。

如有需要,可私信或通过下方的卡片联系我

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

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

相关文章

Comfy UI 工作流(三)高清修复 - 低显存放大

前面提到的几种高清修复、高清放大都会占用,较多的现存。 和 Sd Web UI 中的 SD Upscale 放大一样,Comfy UI 中也提供有类似的自定义节点,通过分块的方式进行图片放大,从而减少现、显存的占用,该方式也经常用于 Com…

形态学图像处理(Morphological Image Processing)

形态学图像处理(Morphological Image Processing) 前言 ‍ 本博客为个人总结数字图像处理一课所写,并给出适当的扩展和相应的demo。 写博客跟做 checkpoint​ 很像,毕竟个人还不能达到那种信手拈来的境界,忘了就是从零开始训练&#xff0…

数据库迁移--laravel进阶篇

本地开发中的数据库和线上发布的数据库是不一样的,每进行一个线上版本的更新,很可能也涉及大量数据库的改动,那么这些数据库的改动在laravel中可以使用数据库迁移来处理。 比如我想创建一张flights数据表 执行php artisan make:migration create_flights_table命令就能自动生…

正则表达式完全指南,总结全面通俗易懂

目录 元字符 连接符 限定符 定位符 修饰符(标记) 运算符优先级 普通字符集及其替换 零宽断言 正向先行断言 负向先行断言 正向后发断言 负向后发断言 捕获组 普通捕获组 命名捕获组 PS:非捕获组 正则表达式在线测试: 正则在线测试工具 …

vulfocus在线靶场:CVE-2018-7600 速通手册

目录 一、启动环境,访问页面,语言选择中文,打开phpmyadmin 二、phpmyadmin中打开小房子 三、选择显示php信息 四、ctrlF,搜索flag,复制粘贴到任务中,通关 一、启动环境,访问页面,…

springboot实战(13)(@PatchMapping、@RequestParam、@URL、ThreadLocal线程局部变量)

目录 一、PATCH请求方式。 二、实现用户更新头像功能。 三、注解RequestParam。 四、注解URL。(对传来的参数是否是合法地址进行校验) 一、PATCH请求方式。 patch中文翻译:局部、小块。PATCH 请求主要用于对已存在的资源进行局部修改&#xf…

记录下,用油猴Tampermonkey监听所有请求,绕过seesion

油猴Tampermonkey监听所有请求,绕过seesion 前因后果脚本编写 前因后果 原因是要白嫖一个网站的接口,这个接口的页面入口被隐藏掉了,不能通过页面调用,幸好之前有想过逆向破解通过账号密码模拟登录后拿到token,请求该…

Spring Cloud Hystrix 豪猪哥 服务容错与保护组件

Spring Cloud Hystrix 豪猪哥 服务容错与保护组件 一、Spring Cloud Hystrix概述1.简介2.核心功能3.雪崩效应 二、Hystrix服务降级1.服务降级简介2.样例准备3.服务提供者降级4.服务消费者降级5.全局降级方法6.对API接口降级方法 三、Hystrix服务熔断1.服务熔断机制简介2.熔断工…

Facebook商城号封号的原因是什么?

Facebook商城作为一个重要的销售平台,不仅为商家提供了巨大的市场机会,也带来了一系列需要警惕的风险,其中包括账号被封的风险。本文将从环境异常、频繁操作和违规行为三个主要方面深入探讨,解析导致Facebook商城账号被封禁的具体…

Android okhttp 网络链接各阶段监控

步骤 1: 添加依赖 在项目的 build.gradle 文件中,添加 OkHttp 依赖: implementation com.squareup.okhttp3:okhttp:4.11.0 步骤 2: 创建自定义的 EventListener 创建一个自定义的 EventListener 类: import android.util.Log import okht…

MyBatis——#{} 和 ${} 的区别和动态 SQL

1. #{} 和 ${} 的区别 为了方便,接下来使用注解方式来演示: #{} 的 SQL 语句中的参数是用过 ? 来起到类似于占位符的作用,而 ${} 是直接进行参数替换,这种直接替换的即时 SQL 就可能会出现一个问题 当传入一个字符串时&#xff…

【Python】30个Python爬虫的实战项目!!!(附源码)

Python爬虫是数据采集自动化的利器。本文精选了30个实用的Python爬虫项目,从基础到进阶,每个项目都配有完整源码和详细讲解。通过这些项目的实战,可以全面掌握网页数据抓取、反爬处理、并发下载等核心技能。 一、环境准备 在开始爬虫项目前…

深述C++模板类

1、前言 函数模板是通用函数的描述,类模板是通用类的描述,使用任意类型来描述类的定义。和函数模板有很多相似的地方,关于函数模板可以看我之前写过的一篇文章:简述C函数模板。这里就不过多赘述。 2、模板类的基本概念 模板类的…

C语言教程指针笔记整理

https://www.bilibili.com/video/BV1cx4y1d7Ut?spm_id_from333.788.videopod.episodes&vd_sourcee8984989cddeb3ef7b7e9fd89098dbe8&p107 本篇为贺宏宏老师C语言教程指针部分笔记整理 //.c文件 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include …

从二维到一维:动态规划矩阵问题的优化之道

动态规划中的矩阵问题是非常经典的应用场景&#xff0c;比如最小路径和问题。这类问题很自然地可以想到使用二维 dp 数组来求解。 我们定义&#xff1a; dp[i][j] 表示从矩阵的第 i行第 j列到右下角的最小路径和。 基本解法 求解过程从右下角开始&#xff0c;向左上角遍历&am…

git,ssh免密公钥配置,gitee为例,GitHub,gitlab同理

git&#xff0c;ssh免密公钥配置&#xff0c;gitee为例&#xff0c;视频教程在这 git&#xff0c;ssh免密公钥配置&#xff0c;gitee为例&#xff0c;GitHub&#xff0c;gitlab同理_哔哩哔哩_bilibili 一、进入.ssh目录 cd ~/.ssh 二、查看是否有id_rsa.pub这个文件 分为…

Spring Boot整合Kafka,实现单条消费和批量消费,示例教程

如何安装Kafka&#xff0c;可以参考docker搭载Kafka集群&#xff0c;一个文件搞定&#xff0c;超简单&#xff0c;亲试可行-CSDN博客 1、在pom.xml中加入依赖 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-sta…

基于Vue+SpringBoot的求职招聘平台

平台概述 本平台是一个高效、便捷的人才与职位匹配系统&#xff0c;旨在为求职者与招聘者提供一站式服务。平台内设三大核心角色&#xff1a;求职者、招聘者以及超级管理员&#xff0c;每个角色拥有独特的功能模块&#xff0c;确保用户能够轻松完成从信息获取到最终录用的整个…

FPGA FIFO系列 - FIFO使用中需要注意的若干问题

FIFO使用中需要注意的若干问题 文章目录 FIFO使用中需要注意的若干问题前言场景1&#xff1a;包数据FIFO设计之冗余法场景2、FIFO数据传输之流控总结 前言 场景1&#xff1a;包数据FIFO设计之冗余法 场景&#xff1a;类似图像、文字等码流数据是不需要重复被访问的&#xff0c…

.NET 9 - BinaryFormatter移除

1.简单介绍 .NET 9 SDK正式版已经发布, 下载地址是.NET9 同时.NET Conf 2024 大会已经从2024-11-13开始了&#xff0c;感觉Aspire和AI的内容相对挺多的&#xff0c;主题分享演示时候打开的网站大部分都是Blazor制作的。 这次.NET Conf 2024老师也再次说明了一下&#xff0c;…