随机过程——卡尔曼滤波学习笔记

一、均方预测和随机序列分解

考虑随机序列X(k),X(k-1),X(k-2),\cdots, X(2),X(1),X(0)

使用X(k-1),X(k-2),\cdots,X(2),X(1),X(0)预测X(k)

定义X_{MS}(k) = E[X(k)|X(k-1),X(k-2),\cdots ,X(0)]

称为X(k)均方可预测部分。 

X(k),X(k-1),\cdots ,X(1),X(0)相互独立,则X(k)均方不可预测的

X_{MS}(k) = E[X(k)|X(k-1),X(k-2),\cdots ,X(0)] = E[X(k)]

定义随机序列X(k)新息序列V(k)=X(k)-X_{MS}(k) 

V(k)基于样本观测的条件均值为0,即均方不可预测。

V(k)与X_{MS}(k)是正交的,即E[V(k)X_{MS}(k)] = 0

二、卡尔曼滤波

输入观测量z(n),对x(n)进行估计得到\hat{x}(n)

1. 系统模型

状态方程

x(n)=F(n,n-1)x(n-1)+v_1(n-1)

观测方程 

z(n)=C(n)x(n)+v_2(n)

 其中,

x(n)状态向量N \times 1

z(n)观测向量M \times 1

v_1(n)状态噪声N \times 1,高斯白噪声

v_2(n)观测噪声M \times 1,高斯白噪声

F(n, n-1)状态转移矩阵N \times N

C(n)观测矩阵M \times N

相关性质:

(1)乘积率:F(n+1, n-1) = F(n+1, n)F(n, n-1)

(2)状态噪声自相关矩阵:E\left[ v_1(n) v_1^H(n) \right ] = Q_1(n) \delta(n-k)

(3)观测噪声自相关矩阵:E\left[ v_2(n) v_2^H(n) \right ] = Q_2(n) \delta(n-k)

(4)噪声独立性:E\left[ v_1(n) v_2^H(n) \right ] = 0

2. 新息过程

定义MMSE下的预测误差e(n)为新息过程,记作a(n)

a(n) = z(n) - \hat{d}(n) = z(n) - W^Hz_{n-1}

\hat{d}(n)记作\hat{z}\left( n | Z_{n-1} \right )是用前n-1个观测值对z(n)进行MMSE估计。

其中,

观测向量:z_{n-1} = \left[ z(1), z(2), z(3), \cdots , z(n-1) \right ]^T

权向量:W = \left[ w_1, w_2, \cdots, w_{n-1} \right ]^{T}

性质

(1)当前新息与以前各观测量正交

E\left[ a(n) z^{*}(n) \right ] = 0, k=0,1,2,\cdots,n-1

(2)当前新息与以前各新息正交

E\left[ a(n) a^{*}(n) \right ] = 0, k=0,1,2,\cdots,n-1

(3)新息与观测量等价

3. 用观测量估计(MMSE估计)状态变量

\hat{x}(n|Z_n) = W^{H} z_n = W^HL_{n}^{-1}a_n = b^{H}a_n

其中,

a_n = a(n) = \left[ a(1), a(2), \cdots, a(n) \right ]^T

b(n) = \left[ b(1), b(2), \cdots, b(n) \right ]^T

A(n) = E\left[ a_n a_n^{H} \right ]

p_a(n) = E\left[ a_n x^{*}(n) \right ]

递推形式:

\hat{x}(n|Z_n) = b^{H} a_n = \sum_{i=1}^{n} b^{*}(i)a(i) = \hat{x}(n|Z_{n-1}) + b^{*}(n)a(n)

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

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

相关文章

目标检测脚本之mmpose json转yolo txt格式

目标检测脚本之mmpose json转yolo txt格式 一、需求分析 在使用yolopose及yolov8-pose 网络进行人体姿态检测任务时,有时需要标注一些特定场景的中的人型目标数据,用来扩充训练集,提升自己训练模型的效果。因为单纯的人工标注耗时费力&…

No Feign Client for loadBalancing defined. 错误解决

1、原因 在使用Spring Cloud Feign进行服务调用时,如果想要利用Ribbon或Spring Cloud LoadBalancer实现客户端负载均衡,需要确保项目中已经引入了对应的依赖。 从Spring Cloud 2020.0及以上版本开始,Ribbon已被弃用,并推荐使用…

响应式Web开发项目教程(HTML5+CSS3+Bootstrap)第2版 例3-4 CSS 立方体

代码 <!doctype html> <html> <head> <meta charset"utf-8"> <title>CSS 立方体</title> <link href"CSS/style.css" rel"stylesheet" type"text/css"> <style> .box {width: 200px…

BigDecimal去掉小数位无效0并转换为String

BigDecimal去掉小数位无效0并转换为String //去掉小数位无效0并转换为Stringpublic static String takeOutZero(BigDecimal data) {int point String.valueOf(data).indexOf(".");if(point > 0){String[] split String.valueOf(data).split("");int a…

Spring上下文之support模块MessageSourceAccessor

博主介绍:✌全网粉丝5W+,全栈开发工程师,从事多年软件开发,在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战,博主也曾写过优秀论文,查重率极低,在这方面有丰富的经验✌ 博主作品:《Java项目案例》主要基于SpringBoot+MyBatis/MyBatis-plus+…

「JavaSE」类和对象1

&#x1f387;个人主页&#xff1a;Ice_Sugar_7 &#x1f387;所属专栏&#xff1a;快来卷Java啦 &#x1f387;欢迎点赞收藏加关注哦&#xff01; 类和对象 &#x1f349;类的定义&#x1f34c;类的实例化 &#x1f349;this引用&#x1f349;对象的构造及初始化&#x1f34c;…

【JAVA】Java 中什么叫单例设计模式?请用 Java 写出线程安全的单例模式

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;JAVA ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 懒汉式&#xff08;Lazy Initialization&#xff09;&#xff1a; 双重检查锁定&#xff08;Double-Checked Locking&#xff09;…

C 练习实例26

题目&#xff1a;利用递归方法求5!。 程序分析&#xff1a; 使用递归要找到函数 f(n)与f(n-1)的关系&#xff0c;以及结束条件 此处的函数关系为&#xff1a;f(n) n*f(n-1)&#xff0c;f(n)为n的阶层 代码&#xff1a; #include <stdio.h> long double f(int n) {i…

MySQL篇—自带物理克隆数据工具Clone插件介绍(第一篇,总共三篇)

各位小伙伴&#xff0c;今天我为大家介绍一下MySQL Clone Plugin这个插件&#xff0c;简单来说&#xff0c;就是MySQL 8.0.17版本之后的一个物理克隆数据工具&#xff0c;它能够帮助我们快速、高效地克隆或复制数据库&#xff0c;极大地简化了数据库迁移、备份和恢复的过程&…

5分钟了解股票交易!上海股票开户交易佣金最低是多少?怎么开户费用最低?

股票交易是指通过证券市场买卖股票的活动。以下是股票交易的基本步骤&#xff1a; 开立证券账户&#xff1a;首先需要选择一家证券公司&#xff0c;向其提交相关材料开立证券账户&#xff0c;并完成账户开立手续。 研究和选择股票&#xff1a;在决定购买股票之前&#xff0c;建…

GPCR蛋白一般残基编号(Generic residue numbering)

文章目录 前言定义特殊情况参考连接 前言 在相应的文章中看到对于对于描述GPCR中的序列位置&#xff0c;往往在除了在当前蛋白的氨基酸序列序号意外&#xff0c;会在右上角标注一个类似于6 x 49的编号。经查这个编号有一个统一名称&#xff1a;Generic residue numbering。本文…

【AT 指令开发】软件框架与接口

目录 1 软件逻辑2.代码2.1 at_command.h2.2 at_command.c本文主要用于记录纯MCU无OS下,AT 指令开发软件框架 1 软件逻辑 2.代码 2.1 at_command.h #ifndef AT_COMMAND_H #define AT_COMMAND_Hvoid AT_CMD_Process(uint8_t *uartBuffer, uint8_t dataLen);/*描述AT指令返回值…

Kamailio使用自定义DNS条目

绕过DNS服务器&#xff0c;使用自定义DNS条目&#xff0c;有多种办法&#xff0c;这里仅提供其中一种&#xff1a; modparam("corex", "dns_cache", "typeA;namekamailio.org;addr192.168.1.100;ttl3600000;flags2") # 可以定义多次 其中&#x…

UIControl 功能和用法

UIControl 功能和用法 大家好&#xff0c;我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;今天&#xff0c;让我们深入探讨iOS开发中常用的UI控件之一——“UIControl”&#xff0c;并详…

Springboot 中接口服务重试机制

在平时开发中可能在调用服务时会遇到调用失败的情况&#xff0c;在springboot 中retery 机制可以很好的满足我们的开发场景&#xff0c;下面举个简单的例子模拟第三方调用。 package com.szhome.web.action;import com.szhome.web.service.ThirdApiService; import org.spring…

Vue+element-china-area-data实现省市区三级联动

安装依赖 npm install element-china-area-data -S cnpm install element-china-area-data -S 引用 import { provinceAndCityData, regionData, provinceAndCityDataPlus, regionDataPlus, CodeToText, TextToCode } from element-china-area-data&#xff1b; provinceAnd…

Linux 命令解释程序(shell)的模拟实现

1.实验内容 分析、设计与实现基于 Linux 内核的命令解释程序&#xff08;Shell&#xff09;&#xff0c;主要包括系统环境变量的设置和初始化、系统命令提示符显示、命令辨别解析&#xff08;区分内部命令与外部命令及不同内部命令&#xff09;、典型内部命令&#xff08;譬如…

写点东西《Docker入门(上)》

写点东西《Docker入门&#xff08;上&#xff09;》 环境变量 Docker 镜像 Docker CMD 与 ENTRYPOINT 有什么区别 Docker 中的网络&#xff1a; Docker 存储&#xff1a; Docker 是一个工具&#xff0c;允许开发人员将他们的应用程序及其所有依赖项打包到一个容器中。然后&…

【Redis】Redis 进阶

文章目录 1. BigKey1.1 MoreKey1.2 BigKey 2. 缓存双写一致性更新策略2.1 读缓存数据2.2 数据库和缓存一致性的更新策略2.3 canal 实现双写一致性 3. 进阶应用3.1 统计应用3.2 hyperloglog3.3 GEO3.4 bitmap 4. 布隆过滤器5. Redis 经典问题5.1 缓存预热5.2 缓存穿透5.3 缓存击…

Android Persistent自启机制

1.persistent属性的使用 在开发系统级的App时&#xff0c;很有可能就会用persistent属性。当在AndroidManifest.xml中将persistent属性设置为true时&#xff0c;那么该App就会具有如下两个特性&#xff1a; 在系统刚起来的时候&#xff0c;该App也会被启动起来 该App被强制杀…