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

卡尔曼滤波(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.rhkb.cn/news/472053.html

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

相关文章

tdengine学习笔记

官方文档:用 Docker 快速体验 TDengine | TDengine 文档 | 涛思数据 整体架构 TDENGINE是分布式,高可靠,支持水平扩展的架构设计 TDengine分布式架构的逻辑结构图如下 一个完整的 TDengine 系统是运行在一到多个物理节点上的,包含…

ROS进阶:使用URDF和Xacro构建差速轮式机器人模型

前言 本篇文章介绍的是ROS高效进阶内容,使用URDF 语言(xml格式)做一个差速轮式机器人模型,并使用URDF的增强版xacro,对机器人模型文件进行二次优化。 差速轮式机器人:两轮差速底盘由两个动力轮位于底盘左…

VPI photonics的一些使用经验(测相位 快速搜索)持续更新

1.使用FuncSinEl模块的注意事项: 2.在VPI player(示波器)测电信号相位时候,可以使用正则表达式,快速搜索。 比如我要搜索以30开头的数据,输入: ^30 其他的正则表达式不适用,比如以…

前端知识点---this的用法 , this动态绑定(Javascript)

文章目录 this动态绑定 , this的用法01. 全局作用域下的 this02. 函数中的 this2.1 普通函数调用2.2 构造函数调用2.3 箭头函数中的 this 03对象方法调用04. 事件处理中的 this05. 动态绑定的方式5.1 call 方法5.2 apply 方法5.3 bind 方法 06类中的 this07. 总结 this动态绑定…

【MySQL 保姆级教学】详细讲解视图--(15)

视图 1. 为什么要有视图?2.视图的定义和特点3. 创建视图4. 视图的使用举例4.1 创建表并插入数据4.2 举例 5. 视图和基表之间有什么联系呢? 1. 为什么要有视图? 当我们频繁地使用用多表查询和复合查询出的结果时,就需要频繁的使用…

聊聊Flink:Flink的分区机制

一、前言 flink任务在执行过程中,一个流(stream)包含一个或多个分区(Stream partition)。TaskManager中的一个slot的subtask就是一个stream partition(流分区),一个Job的流&#xf…

探索SAP财务管理软件:重塑企业财务管理新境界

在当今瞬息万变的商业环境中,企业对于财务管理的精准性、高效性和透明度要求日益增高。作为全球领先的企业管理软件解决方案提供商,SAP凭借其强大的财务管理软件,正引领着全球企业迈向财务管理的新纪元。 SAP 财务管理系统通过智能化技术&am…

数字孪生乡村:数字乡村智慧化营建思路

数字化技术已然成为全球理论和产业界关注的热点命题 ,并广泛应用于城市规划、交通管理、工业、医疗、教育等领域,已经成为文化遗产保护领域最主要方式 ,如数字非遗、数字文物、数字文旅等。 传统村落的数字化保护呈现由单一技术向多技术集成…

《FreeRTOS任务基础知识以及任务创建相关函数》

目录 1.FreeRTOS多任务系统与传统单片机单任务系统的区别 2.FreeRTOS中的任务(Task)介绍 2.1 任务特性 2.2 FreeRTOS中的任务状态 2.3 FreeRTOS中的任务优先级 2.4 在任务函数中退出 2.5 任务控制块和任务堆栈 2.5.1 任务控制块 2.5.2 任务堆栈…

SpringCloud基础 入门级 学习SpringCloud 超详细(简单通俗易懂)

Spring Cloud 基础入门级学习 超详细(简单通俗易懂) 一、SpringCloud核心组件第一代:SpringCloud Netflix组件第二代:SpringCloud Alibaba组件SpringCloud原生组件 二、SpringCloud体系架构图三、理解分布式与集群分布式集群 四、…

Photoshop(PS)——人像磨皮

1.新建一个文件,背景为白色,将图片素材放入文件中 2.利用CtrlJ 复制两个图层出来,选择第一个拷贝图层,选择滤镜---杂色---蒙尘与划痕 3.调整一下数值,大概能够模糊痘印痘坑,点击确定。 4.然后选择拷贝2图层…

core 文件

sysctl -a | grep core_pattern 查看core 的路径 linux下寻找段错误的方法 - 空水 - 博客园 /var/log/messages dmesg -T 一、dmesg命令 dmesg命令,用于获取程序出错时的堆栈地址,用grep过滤出发生崩溃的程序,以及对应的堆栈信息 [Thu Nov …

centos rich 美观打印日志

文章目录 步骤 1: 安装 Python 和 pip步骤 2: 安装 rich-cli步骤 3: 验证安装步骤 4: 使用 rich-cli参考 在 CentOS 上安装 rich-cli 工具,你可以按照以下步骤进行操作。rich-cli 是一个命令行工具,用于将 rich 库的功能(例如美化输出&#x…

《动手学深度学习》中d2l库的安装以及问题解决

当我们在按照《动手学深度学习》这本书或者网课学习时会有需要导入d2l库的使用。​d2I是一个与《动手学深度学习》(Dive into Deep Learning)一书配套的开源教学库,它包含了作者李沐设计的深度学习相关代码和示例。这个库旨在帮助读者通过实践经验来理解…

【大模型实战篇】vLLM的由来以及大模型部署、推理加速实践

1. 问题背景分析及vLLM的由来 大模型毫无疑问,在工作、生活中已经逐渐扮演越来越重要的角色。但大模型的尺寸一般都比较大,处理一个大模型请求的成本可能比传统关键字查询高出 10 倍。推理的成本代价较高,因此提高大模型服务系统的吞吐量&…

常用在汽车PKE无钥匙进入系统的高度集成SOC芯片:CSM2433

CSM2433是一款集成2.4GHz频段发射器、125KHz接收器和8位RISC(精简指令集)MCU的SOC芯片,用在汽车PKE无钥匙进入系统里。 什么是汽车PKE无钥匙进入系统? 无钥匙进入系统具有无钥匙进入并且启动的功能,英文名称是PKE&…

路由器基本原理与配置

一 , 路由是什么? 从源主机到目标主机的转发过程; 二 , 路由器 (1)路由器的工作原理 路由器是一种三层设备,是使用IP地址寻址,实现从源IP到达目标IP地址的端到端的服务&#xff0c…

NPOI 实现Excel模板导出

记录一下使用NPOI实现定制的Excel导出模板&#xff0c;已下实现需求及主要逻辑 所需Json数据 对应参数 List<PurQuoteExportDataCrInput> listData [{"ItemName": "电缆VV3*162*10","Spec": "电缆VV3*162*10","Uom":…

element plus的表格内容自动滚动

<el-table:data"tableData"ref"tableRef"borderstyle"width: 100%"height"150"><el-table-column prop"date" label"名称" width"250" /><el-table-column prop"name" label&…

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

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