【基于PSINS】UKF/SSUKF对比的MATLAB程序

请添加图片描述

UKF与SSUKF

UKF是:无迹卡尔滤波
SSUKF是:简化超球面无迹卡尔曼滤波

UKF

相较于传统的KF算法,UKF能够更好地处理非线性系统,并且具有更高的估计精度。它适用于多种应用场景,如机器人定位导航、目标跟踪、信号处理等。

SSUKF

简化超球面无迹卡尔曼滤波是一种用于状态估计的滤波算法。它是卡尔曼滤波(Kalman Filter)的一种扩展形式,用于解决非线性系统的状态估计问题。
SUKF的核心思想是将非线性函数通过高斯-埃尔米特(Gaussian-Hermite)积分转化成线性函数,并利用无迹变换(Unscented Transform)对状态空间进行采样。在SUKF中,状态空间被视为超球面,每个采样点代表一个可能的状态。通过对超球面上的采样点进行加权求和,可以得到状态的估计值和协方差矩阵。
简化超球面无迹卡尔曼滤波是一种常用的状态估计算法,但在实际应用中需要根据具体问题进行参数调整和优化,以获得最佳的估计结果。

例程

例程从PSINS的UKF153和SSUKF153的程序修改而来,如果有工具箱(版本不限),即可直接运行这个对比的例程。
例程将两者算法放在一个m文件里面,重新设计了一个带有加速、减速、爬升、下降、转弯的三维运动轨迹,让两个程序在同样的轨迹和相同的传感器误差特性下运行,结果可靠。
在工具箱原有的单个算法

运行结果

运行结果分成两部分:

  • 第一部分是借用了工具箱的绘图命令,绘制的UKF误差曲线,此部分误差是 真值 − U K F 真值-UKF 真值UKF 真值 − S S U K F 真值-SSUKF 真值SSUKF
  • 第二部分是我自己原创的三维轨迹图和三轴位置误差对比曲线
    UKF误差曲线:
    请添加图片描述
    SSUKF误差曲线:
    请添加图片描述
    三维轨迹图:
    请添加图片描述
    三轴的误差对比图:
    请添加图片描述

源代码

代码如下:【需要PSINS工具箱】

% 【PSINS】UKF/SSUKF对比
% 无迹卡尔滤波和简化超球面无迹卡尔曼滤波
% 使用三维轨迹(加速、减速、旋转、爬升下降)
% 对比滤波后的姿态、速度、位置
% Evand
% 2024-7-25/Ver1
clear;clc;close all;
glvs
psinstypedef('test_SINS_GPS_UKF_153_def');
ts = 0.1;       % sampling interval
%% 轨迹设置
avp0 = [[0;0;0]; [0;0;0]; [0;0;0]]; % init avp
% trajectory segment setting
traj_ = [];
seg = trjsegment(traj_, 'init',         0);
seg = trjsegment(seg, 'uniform',      100);
seg = trjsegment(seg, 'accelerate',   10, traj_, 1);
seg = trjsegment(seg, 'uniform',      100);
seg = trjsegment(seg, 'coturnleft',   45, 2, traj_, 4);
seg = trjsegment(seg, 'climb',        10, 2, traj_, 50);
seg = trjsegment(seg, 'uniform',      100);
seg = trjsegment(seg, 'descent',      10, 2, traj_, 50);
seg = trjsegment(seg, 'uniform',      100);
seg = trjsegment(seg, 'coturnleft',   45, 2, traj_, 4);
seg = trjsegment(seg, 'uniform',      100);
seg = trjsegment(seg, 'deaccelerate', 5,  traj_, 2); %2
seg = trjsegment(seg, 'uniform',      100);
% generate, save & plot
trj = trjsimu(avp0, seg.wat, ts, 1);
%% 初始化
% initial settings
[nn, ts, nts] = nnts(2, trj.ts);
imuerr = imuerrset(0.03, 100, 0.001, 5);
imu = imuadderr(trj.imu, imuerr);
davp0 = avperrset([0.5;-0.5;20], 0.1, [1;1;3]);
ins = insinit(avpadderr(trj.avp0,davp0), ts);
%% UKF
rk = poserrset([1;1;3]);
kf = kfinit(ins, davp0, imuerr, rk);
kf.fx = @largephiu15ukf;
len = length(imu); [avp_ukf, xkpk] = prealloc(fix(len/nn), 10, 2*kf.n+1);
timebar(nn, len, '15-state SINS/GPS UKF仿真,时间较长'); 
ki = 1;
for k=1:nn:len-nn+1k1 = k+nn-1;  wvm = imu(k:k1,1:6);  t = imu(k1,end);ins = insupdate(ins, wvm);kf.px = ins;kf = ukf(kf);if mod(t,1)==0posGPS = trj.avp(k1,7:9)' + davp0(7:9).*randn(3,1);  % GPS pos simulation with some white noisekf = ukf(kf, ins.pos-posGPS, 'M');  % UKF filter[kf, ins] = kffeedback(kf, ins, 1, 'avp');avp_ukf(ki,:) = [ins.avp', t];xkpk(ki,:) = [kf.xk; diag(kf.Pxk); t]';  ki = ki+1;endtimebar;
end
avp_ukf(ki:end,:) = [];  xkpk(ki:end,:) = []; fprintf('完整代码下载链接:https://gf.bilibili.com/item/detail/1105881012');
%% SSUKF filter
ins = insinit(avpadderr(trj.avp0,davp0), ts);

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

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

相关文章

【解决方案】华普微基于CMT2189D的低功耗广域网解决方案

一、方案概述 随着物联网的快速发展,对于无线通信的需求越来越高。传统的通信技术可能无法满足物联网设备的特殊要求,如低功耗、长距离覆盖和大规模连接。LPWAN技术应运而生,旨在为物联网设备提供低成本、低功耗的远距离通信解决方案。ZETA作…

【Qt】Qt容器和STL容器的区别

1、简述 Qt容器和STL容器略有不同,作为一个Qter,应该知道它们之间的异同。 Qt容器官网介绍:https://doc.qt.io/qt-5/containers.html STL容器官网介绍:https://zh.cppreference.com/w/cpp/container 2、Qt容器和STL容器的对应关系 注意:QList 与 std::list 无关,QSet …

<数据集>铁路工人安全帽安全背心识别数据集<目标检测>

数据集格式:VOCYOLO格式 图片数量:3065张 标注数量(xml文件个数):3065 标注数量(txt文件个数):3065 标注类别数:3 标注类别名称:[vest, helmet, worker] 序号类别名称图片数框数1vest305978832helmet…

谷粒商城实战笔记-59-商品服务-API-品牌管理-使用逆向工程的前后端代码

文章目录 一, 使用逆向工程生成的代码二,生成品牌管理菜单三,几个小问题 在本次的技术实践中,我们利用逆向工程的方法成功地为后台管理系统增加了品牌管理功能。这种开发方式不仅能快速地构建起功能模块,还能在一定程度…

Go语言常见序列化协议全面对比

先说结论 从易用性、性能、内存占用、编码后大小等几个方面综合考虑 ProtoBuf 胜出。 Gob 从性能和 I/O 带宽占用上都和 ProtoBuf 差不多,唯一劣势是编解码时内存占用较多。考虑到不用再写 IDL 带来的易用性,如果整个系统内不存在使用除 Go 以外其他语言…

使用 Snorkel 和 MinIO 的以数据为中心的 AI

如今,业界都在谈论大型语言模型及其编码器、解码器、多头注意力层和数十亿(即将数万亿)的参数,人们很容易相信好的人工智能只是模型设计的结果。不幸的是,事实并非如此。好的人工智能需要的不仅仅是一个精心设计的模型…

医疗器械ce认证办理流程介绍

CE认证是的产品安全认证,所有进入市场的医疗器械都必须进行医疗器械CE认证,医疗器械CE认证为了解决成员国之间的贸易壁垒,组织逐步将自己建成一个统一的大市场,以确保人员、服务、资本和产品(如医疗器械)的自由流通。在医疗器械领…

查找手机归属地轻松快捷,专业手机号码归属地数据源

在如今的信息社会中,手机已经成为了人们生活中不可或缺的一部分。当我们接到一个陌生的电话时,或者想了解一个电话号码的归属地时,我们可以借助一些工具来查找手机归属地。本文将介绍一种轻松快捷、专业的手机号码归属地数据源,并…

box-shadow属性的复合写法及高级用法,超详细!

前言:最近又叕看到了一个好看的特效,随后整理了一下,发现实现起来主要靠一个css属性就实现了,有一次刷新了我对css强大的认知😎,这个属性就是box-shadow,平常我们用到的比较少,但是针…

智慧工地视频汇聚管理平台:打造现代化工程管理的全新视界

一、方案背景 科技高速发展的今天,工地施工已发生翻天覆地的变化,传统工地管理模式很容易造成工地管理混乱、安全事故、数据延迟等问题,人力资源的不足也进一步加剧了监管不到位的局面,严重影响了施工进度质量和安全。 视频监控…

LLMs之Llama 3.1:Llama 3.1的简介、安装和使用方法、案例应用之详细攻略

LLMs之Llama 3.1:Llama 3.1的简介、安装和使用方法、案例应用之详细攻略 导读:2024年7月23日,Meta重磅推出Llama 3.1。本篇文章主要提到了Meta推出的Llama 3.1自然语言生成模型。 背景和痛点 >> 过去开源的大型语言模型在能力和性能上一…

C语言------指针讲解(3)

一、字符指针 在指针中,我们知道有一类指针类型为字符指针char*; int main() {char ch w;char* pc &ch;*pc w;return 0; } 还有一种使用方式如下: 上述代码中,本质是把hello的首字符的地址放到了pstr中。即把一个常量字符串的首字符…

netty使用redis发布订阅实现消息推送

netty使用redis发布订阅实现消息推送 场景 项目中需要给用户推送消息: 接口 RestController public class PushApi {Autowiredprivate PushService pushService;/*** 消息推送* param query* return*/PostMapping("/push/message")public String push(RequestBody…

国内访问Docker Hub慢问题解决方法

在国内访问Docker Hub时可能会遇到一些困难,但幸运的是,有多种解决方案可以帮助你顺利下载Docker镜像。以下是一些有效的解决方案: 配置Docker镜像源:你可以通过配置Docker的daemon.json文件来使用国内镜像源,比如DaoC…

四、GD32 MCU 常见外设介绍(8)SPI 模块介绍

串行外设接口(Serial Peripheral Interface,缩写为 SPI) 提供了基于SPI 协议的数据发送和接收功能, 可以工作于主机或从机模式。 SPI 接口支持具有硬件 CRC 计算和校验的全双工和单工模式。 8.1.SPI 基础知识 SPI 物理层 SPI接…

【Three.js基础学习】17.imported-models

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 前言 课程回顾: 如何在three.js 中引入不同的模型? 1. 格式 (不同的格式) https://en.wikipedia.org/wiki/List_of_file_form…

UART编程框架详解

1. UART介绍 UART:通用异步收发传输器(Universal Asynchronous Receiver/Transmitter),简称串口。 调试:移植u-boot、内核时,主要使用串口查看打印信息 外接各种模块 1.1 硬件知识_UART硬件介绍 UART的全称是Unive…

Unity UGUI 之 事件接口

本文仅作学习笔记与交流,不作任何商业用途 本文包括但不限于unity官方手册,唐老狮,麦扣教程知识,引用会标记,如有不足还请斧正 本文在发布时间选用unity 2022.3.8稳定版本,请注意分别 1.什么是事件接口&…

找实习,三本计算机 > 985文科 ?

2018年3月,大三下学期。 写了一段时间博客以后,竟有人说要内推我。 我说我大三,还没毕业,准备暑假去找实习。 网上认识的朋友建议我去春招实习试试,还有些厂在走流程中,还有机会。 我婉拒了&#xff0c…

Centos 8 配置网络源

备份当前的软件源配置文件: sudo cp -a /etc/yum.repos.d /etc/yum.repos.d.bak 清理原有的 yum 仓库配置信息: sudo rm -f /etc/yum.repos.d/*.repo 获取阿里云的 CentOS 8 源配置: sudo curl -o /etc/yum.repos.d/CentOS-Base.repo ht…