卡尔曼滤波:从理论到应用的简介

news2024/12/23 3:46:16

卡尔曼滤波(Kalman Filter)是一种递归算法,用于对一系列噪声观测数据进行动态系统状态估计。它广泛应用于导航、控制系统、信号处理、金融预测等多个领域。本文将介绍卡尔曼滤波的基本原理、核心公式和应用案例。

1. 什么是卡尔曼滤波?

卡尔曼滤波由鲁道夫·卡尔曼在1960年提出,是一种基于最小均方误差准则的最优估计方法。简单来说,卡尔曼滤波使用当前的系统状态和新的测量数据来更新状态估计,并将噪声最小化,从而提供更准确的状态估计。

卡尔曼滤波的主要特点是它是递归的,这意味着它可以实时处理数据,不需要存储整个数据序列。

2. 卡尔曼滤波的基本数学原理

卡尔曼滤波的过程可以分为两步:预测(Prediction)和更新(Update)。

  1. 预测步骤:根据当前状态估计和控制输入,预测下一个时刻的状态和不确定性。

    • 状态预测:\hat{x}_{k|k-1} = A \hat{x}_{k-1|k-1} + B u_k
    • 误差协方差预测:P_{k|k-1} = A P_{k-1|k-1} A^T + Q

    其中:

    • A 是状态转移矩阵。
    • B 是控制输入模型。
    • u_k​ 是控制输入。
    • Q 是过程噪声的协方差矩阵。
  2. 更新步骤:结合测量值更新状态估计。

    • 卡尔曼增益计算:K_k = P_{k|k-1} H^T (H P_{k|k-1} H^T + R)^{-1}
    • 状态更新:\hat{x}_{k|k} = \hat{x}_{k|k-1} + K_k (z_k - H \hat{x}_{k|k-1})
    • 误差协方差更新:P_{k|k} = (I - K_k H) P_{k|k-1}

    其中:

    • H 是测量矩阵。
    • z_k​ 是观测值。
    • R 是测量噪声的协方差矩阵。
    • K_k​ 是卡尔曼增益,它平衡了预测与观测之间的权重。

3. 卡尔曼滤波的优缺点

优点:

  • 实时更新:适合实时系统。
  • 噪声鲁棒性:能够有效滤除噪声,尤其适用于高斯噪声环境。
  • 资源效率:计算复杂度低,适合嵌入式系统实现。

缺点:

  • 模型依赖:卡尔曼滤波假设模型线性且噪声为高斯分布,在非线性或噪声不服从正态分布的系统中表现欠佳。
  • 初始状态敏感:初始状态和协方差的设定影响收敛速度。

4. 卡尔曼滤波的实际应用

  1. 导航和定位:卡尔曼滤波在GPS导航、飞机和导弹控制系统中广泛应用,用于实时跟踪物体的位置和速度。
  2. 金融领域:在股票价格预测、波动率估计等金融模型中,卡尔曼滤波可以用来平滑价格信号,估计价格趋势。
  3. 信号处理:在音频和视频的去噪处理中,卡尔曼滤波可以滤除观测信号中的随机噪声。

5. 实例:Python实现卡尔曼滤波

我们有一个资产价格序列 [101.2,102.5,98.5,100.8][101.2, 102.5, 98.5, 100.8][101.2,102.5,98.5,100.8],这个序列包含噪声(通常的金融数据就是这种情况),我们希望通过 Kalman 滤波器 来平滑这些噪声,以得到一个更稳定的价格估计。

import numpy as np
import matplotlib.pyplot as plt
from pykalman import KalmanFilter

# Given price series (observed prices)
observed_prices = [101.2, 102.5, 98.5, 100.8]

# Initialize the Kalman Filter
kf = KalmanFilter(initial_state_mean=observed_prices[0], n_dim_state=1, n_dim_obs=1)

# Transition matrix (Assuming simple constant value model)
kf.transition_matrices = np.array([[1]])

# Observation matrix (We observe the price directly)
kf.observation_matrices = np.array([[1]])

# Initial state covariance (How uncertain we are about the initial state)
kf.initial_state_covariance = 1

# Measurement noise covariance (Assume some noise in the observations)
kf.observation_covariance = 1  # You can tweak this to change the weight given to observations

# Process noise covariance (Assume some process noise)
kf.transition_covariance = 0.1  # This is the model's uncertainty about how the price evolves

# Apply Kalman Filter to the observed price series
filtered_state_means, filtered_state_covariances = kf.filter(observed_prices)

# Plot the observed prices and the Kalman Filter smoothed prices
plt.plot(observed_prices, label='Observed Prices', marker='o', linestyle='dashed', color='gray')
plt.plot(filtered_state_means, label='Filtered Prices (Kalman)', marker='x', color='blue')
plt.xlabel('Time Step')
plt.ylabel('Price')
plt.title('Kalman Filter Price Estimation')
plt.legend()
plt.show()

# Output the filtered price estimates
print("Filtered Price Estimates:")
for t, price in enumerate(filtered_state_means):
    print(f"Time Step {t+1}: Filtered Price = {price[0]:.2f}")

下图为运行结果:

6. 步骤解释

1. Kalman 滤波器的设置

首先,我们定义 Kalman 滤波器中的各个组件:

  1. 状态:在这里,状态是我们对真实价格的估计。我们用一个变量来表示它,即当前时刻的估计价格。

  2. 观测:这是我们实际观察到的价格数据,这些数据可能包含噪声。

  3. 状态转移模型:我们假设价格在每个时间步不会有剧烈变化,所以我们的状态转移矩阵是 1,意味着预测的价格与前一个估计值相同。

  4. 测量模型:由于我们直接观测到价格,所以观测矩阵也是 1

  5. 噪声模型

    • 过程噪声协方差 Q:表示价格随时间变化的内在不确定性,假设为 0.1
    • 观测噪声协方差 R:表示测量中可能的噪声,假设为 1
  6. 初始设置

    • 初始价格设为 101.2
    • 初始的不确定性协方差设为 1

2. 初始化

在开始时,初始状态为第一个观测值,即 101.2。初始的不确定性(即估计的方差)设为 1。在这一步,我们还没有进行预测或更新,因为这是滤波器的起点。

3. 时间 t=1:第一个预测和更新

在开始时,初始状态为第一个观测值,即 101.2。初始的不确定性(即估计的方差)设为 1。在这一步,我们还没有进行预测或更新,因为这是滤波器的起点。

预测步骤:

  • 预测值:假设价格在时间步之间保持不变,因此预测的价格和之前估计的价格一致。 
    • \hat{x}^-_1 = 101.2
  • 预测不确定性:基于过程噪声增加的不确定性,从 1 增加到 1 + Q(过程噪声为 0.1):
    • P^-_1 = 1 + 0.1 = 1.1

更新步骤:

  • 观察值:我们观察到时间 t=1 的价格是 102.5

  • 计算 Kalman 增益

        K_1 = \frac{P^-_1}{P^-_1 + R} = \frac{1.1}{1.1 + 1} \approx 0.524

    Kalman 增益 K_1 告诉我们在预测值和观测值之间我们有多少信任。

  • 更新估计:使用 Kalman 增益来调整预测值:

       \hat{x}_1 = \hat{x}^-_1 + K_1 \cdot (z_1 - \hat{x}^-_1) = 101.2 + 0.524 \cdot (102.5 - 101.2) \approx 101.69

    这里,预测值和观测值的差值是 102.5 - 101.2 = 1.3,调整后的估计为 101.69

  • 更新不确定性

       P_1 = (1 - K_1) \cdot P^-_1 = (1 - 0.524) \cdot 1.1 \approx 0.524

4. 时间 t=2:第二次预测和更新

预测步骤:

  • 预测值:使用上一步的估计 101.69 作为下一步的预测: \hat{x}^-_2 = 101.69
  • 预测不确定性:由于模型噪声增加,预测的不确定性为  P^-_2 = 0.524 + 0.1 = 0.624

更新步骤:

  • 观察值:时间 t=2 的价格观测值是 98.5

  • 计算 Kalman 增益

        K_2 = \frac{P^-_2}{P^-_2 + R} = \frac{0.624}{0.624 + 1} \approx 0.384
  • 更新估计

        \hat{x}_2 = \hat{x}^-_2 + K_2 \cdot (z_2 - \hat{x}^-_2) = 101.69 + 0.384 \cdot (98.5 - 101.69) \approx 100.66

    这里,预测值和观测值的差值是 98.5 - 101.69 = -3.19,调整后的估计为 100.66

  • 更新不确定性

        P_2 = (1 - K_2) \cdot P^-_2 = (1 - 0.384) \cdot 0.624 \approx 0.384

5. 时间 t=3:第三次预测和更新

预测步骤:

  • 预测值:使用上一步的估计 100.66 作为下一步的预测:\hat{x}^-_3 = 100.66
  • 预测不确定性:由于过程噪声,预测的不确定性变为 0.384 + 0.1:    P^-_3 = 0.384 + 0.1 = 0.484

更新步骤:

  • 观察值:时间 t=3 的观测价格是 100.8

  • 计算 Kalman 增益

        K_3 = \frac{P^-_3}{P^-_3 + R} = \frac{0.484}{0.484 + 1} \approx 0.326
  • 更新估计

        \hat{x}_3 = \hat{x}^-_3 + K_3 \cdot (z_3 - \hat{x}^-_3) = 100.66 + 0.326 \cdot (100.8 - 100.66) \approx 100.7

    这里,预测值和观测值的差值是 100.8 - 100.66 = 0.14,调整后的估计为 100.7

  • 更新不确定性

      P_3 = (1 - K_3) \cdot P^-_3 = (1 - 0.326) \cdot 0.484 \approx 0.326

7. 总结

在应用 Kalman 滤波器时,需要定义三个关键矩阵来控制价格的预测和更新过程。具体来说,这三个矩阵是:

1. 状态转换矩阵 A

  • 作用:状态转换矩阵用来描述系统状态的变化情况。在我们的例子中,它表示价格在时间步之间如何变化。
  • 解释:这个矩阵决定了如何从一个时间步的状态(价格估计)预测下一个时间步的状态。比如,如果你假设价格在短期内保持稳定,可以将 A设置为 1(这表示预测的价格和前一个时间步相同)。如果有更复杂的模型(如价格可能随着时间线性增加),你可以在 A中引入更多参数。
  • 示例:在价格平滑的例子中,简单情况下 A=1。

2. 过程噪声协方差矩阵 Q

  • 作用:过程噪声矩阵 Q 描述的是系统内在的不确定性,表示我们对模型如何演变的不完全信任程度。
  • 解释:Q 用来表示系统本身的随机性或模型的简化程度。更高的 Q值意味着我们认为系统有更多的随机波动,较低的 Q值表示对系统的信任度较高。在金融时间序列中,这种不确定性可能来自市场的内在波动。
  • 示例:在我们的例子中,Q 设置为 0.1,表示我们对每个时间步的价格变化有一定的随机波动预期。

3. 观测噪声协方差矩阵 R

  • 作用:观测噪声矩阵 R 表示外部的测量不确定性,即观测数据中的噪声。
  • 解释:这是观测数据中可能存在的随机误差,例如由于市场的短期波动、交易异常或其他外部因素导致的观测误差。一个较高的 R值表示观测数据的噪声较大,较低的 R值表示观测数据比较可靠。
  • 示例:在我们的例子中,R 设置为 1,表示市场观测中可能存在的波动。

卡尔曼滤波是一种强大的估计工具,在动态系统的状态估计中表现出色。它通过递归更新,将预测和测量结合,从而在各种噪声环境中提供稳定、准确的估计结果。在未来的发展中,卡尔曼滤波还将与非线性滤波和机器学习方法相结合,进一步拓宽其应用领域。

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

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

相关文章

学习日志011--模块,迭代器与生成器,正则表达式

一、python模块 在之前学习c语言时,我们学了分文件编辑,那么在python中是否存在类似的编写方式?答案是肯定的。python中同样可以实现分文件编辑。甚至还有更多的好处: ‌提高代码的可维护性‌:当代码被分成多个文件时…

CSS 语法规范

基本语法结构 CSS 的基本语法结构包含 选择器 和 声明块,两者共同组成 规则集。规则集可以为 HTML 元素设置样式,使页面结构和样式实现分离,便于网页的美化和布局调整。 CSS 规则集的结构如下: selector {property: value; }选择器(Selector) 选择器用于指定需要应用…

Bag Graph: Multiple Instance Learning Using Bayesian Graph Neural Networks文献笔记

基本信息 原文链接:[2202.11132] Bag Graph: Multiple Instance Learning using Bayesian Graph Neural Networks 方法概括:用图(贝叶斯GNN框架)来建模袋之间的相互作用,并使用图神经网络(gnn&#xff09…

Spark 共享变量:广播变量与累加器解析

Spark 的介绍与搭建:从理论到实践_spark环境搭建-CSDN博客 Spark 的Standalone集群环境安装与测试-CSDN博客 PySpark 本地开发环境搭建与实践-CSDN博客 Spark 程序开发与提交:本地与集群模式全解析-CSDN博客 Spark on YARN:Spark集群模式…

前海华海金融创新中心的工地餐点探寻

​前海的工地餐大部分都是13元一份的哈。我在前海华海金融创新中心的工地餐点吃过一份猪杂饭,现做13元一份。我一般打包后回公司吃或直接桂湾公园找个环境优美的地方吃饭。 ​我点的这份猪杂汤粉主要是瘦肉、猪肝、肉饼片、豆芽和生菜,老板依旧贴心问需要…

借助Excel实现Word表格快速排序

实例需求:Word中的表格如下图所示,为了强化记忆,希望能够将表格内容随机排序,表格第一列仍然按照顺序编号,即编号不跟随表格行内容调整。 乱序之后的效果如下图所示(每次运行代码的结果都不一定相同&#x…

【C语言指南】C语言内存管理 深度解析

💓 博客主页:倔强的石头的CSDN主页 📝Gitee主页:倔强的石头的gitee主页 ⏩ 文章专栏:《C语言指南》 期待您的关注 引言 C语言是一种强大而灵活的编程语言,为程序员提供了对内存的直接控制能力。这种对内存…

【Linux网络编程】简单的UDP网络程序

目录 一,socket编程的相关说明 1-1,sockaddr结构体 1-2,Socket API 二,基于Udp协议的简单通信 一,socket编程的相关说明 Socket编程是一种网络通信编程技术,它允许两个或多个程序在网络上相互通信&…

Kafka入门:Java客户端库的使用

在现代的分布式系统中,消息队列扮演着至关重要的角色,而Apache Kafka以其高吞吐量、可扩展性和容错性而广受欢迎。本文将带你了解如何使用Kafka的Java客户端库来实现生产者(Producer)和消费者(Consumer)的基…

STM32设计学生宿舍监测控制系统

目录 前言 一、本设计主要实现哪些很“开门”功能? 二、电路设计原理图 电路图采用Altium Designer进行设计: 三、实物设计图 四、程序源代码设计 五、获取资料内容 前言 随着科技的飞速发展和智能化时代的到来,学生宿舍的安全、舒适…

HTML5实现俄罗斯方块小游戏

文章目录 1.设计来源1.1 主界面1.2 皮肤风格1.2 游戏中界面1.3 游戏结束界面 2.效果和源码2.1 动态效果2.2 源代码 源码下载 作者:xcLeigh 文章地址:https://blog.csdn.net/weixin_43151418/article/details/143788449 HTML5实现俄罗斯方块小游戏&#x…

自由学习记录(22)

最后再总结一下吧 虽然过程里很多细节也许我没有去管,毕竟现在就已经存在更好的解决方案了 但大致思想是了解了 A星是一种网格上的遍历方式,为了找到一个目标点和起点之间的要经过的最短节点组 里面更像是动态规划 每一次的遍历,都是当前…

UNIX网络编程-TCP套接字编程(实战)

概述 TCP客户端/服务器程序示例是执行如下步骤的一个回射服务器: 客户端从标准输入读入一行文本,并写给服务器。服务器从网络输入读入这行文本,并回射给客户端。客户端从网络输入读入这行回射文本,并显示在标准输出上。 TCP服务器…

『VUE』27. 透传属性与inheritAttrs(详细图文注释)

目录 什么是透传属性(Forwarding Attributes)使用条件唯一根节点禁用透传属性继承总结 欢迎关注 『VUE』 专栏,持续更新中 欢迎关注 『VUE』 专栏,持续更新中 什么是透传属性(Forwarding Attributes) 在 V…

408模拟卷较难题(无分类)

模拟卷特别是大题还是很有难度的,而且有些题有错,还是先把真题吃透,后面没时间的话就不整理了。 一棵树转化为二叉树,那么这棵二叉树一定为右子树为空的树 计算不同种形态,即计算6个结点的二叉树有几种形态&#xff0c…

【JavaScript】LeetCode:96-100

文章目录 96 单词拆分97 最长递增子序列98 乘积最大子数组99 分割等和子集100 最长有效括号 96 单词拆分 动态规划完全背包:背包-字符串s,物品-wordDict中的单词,可使用多次。问题转换:s能否被wordDict中的单词组成。dp[i]&#x…

安全见闻1-5

涵盖了编程语言、软件程序类型、操作系统、网络通讯、硬件设备、web前后端、脚本语言、病毒种类、服务器程序、人工智能等基本知识,有助于全面了解计算机科学和网络技术的各个方面。 安全见闻1 1.编程语言简要概述 C语言:面向过程,适用于系统…

相亲小程序(源码+文档+部署+讲解)

最近我在挖掘一些优秀的开源项目时,无意间发现了一个相当给力的系统——相亲小程序管理系统。这个系统不仅功能实用,而且代码结构清晰,易于二次开发。作为一名技术爱好者,我觉得有必要把这个好东西推荐给我的读者们。接下来&#…

RabbitMQ介绍和快速上手案例

文章目录 1.引入1.1同步和异步1.2消息队列的作用1.3rabbitMQ介绍 2.安装教程2.1更新软件包2.2安装erlang2.3查看这个erlang版本2.4安装rabbitMQ2.5安装管理页面2.6浏览器测试2.7添加管理员用户 3.rabbitMQ工作流程4.核心概念介绍4.1信道和连接4.2virtual host4.3quene队列 5.We…

aws(学习笔记第十二课) 使用AWS的RDS-MySQL

aws(学习笔记第十二课) 使用AWS的RDS 学习内容: AWS的RDS-MySQL 1. 使用AWS的RDS 什么是RDS RDS就是Relation Database Service的缩写,是AWS提供的托管关系型数据库系统。让用户能够在 AWS Cloud 云中更轻松地设置、操作和扩展关系数据库。 数据库和we…