news 2026/4/23 15:55:53

用一个简单模型推导卡尔曼滤波理论

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
用一个简单模型推导卡尔曼滤波理论

尔曼滤波理论由鲁道夫·卡尔曼于1960年提出,随后在解决“阿波罗计划”中航天器的导航问题时获得成功。

卡尔曼滤波理论可以高效地处理测量误差。广泛的测量需求和测量误差的客观存在使它备受关注,从控制科学到电子信息,从航空航天到人工智能,很多领域都有它的身影。

然而仅凭“应用广泛”还不足以说明它的价值,事实上,它常出现在众多领域的高阶部分。有评论说,它是20世纪重要的数学发现之一。

我们用一个简单模型,逐步推导经典卡尔曼滤波理论,体会它的思想方法。

渐入佳境

今有秦岭冷杉,

次测量的树高为

,,,,

,通常的做法是取平均数作为测量结果。

下面通过方程变形,把

分离出来:

其中

,是通过前

次测量对树高的估计。

继续把

分离出来:

其中

,是通过前

次测量对树高的估计。

以此类推,有通式:

方程甲

即第

次的估计

,可由第

次的估计

融合第

次的测量

后得出。

这就形成了一种不断融合新数据、进行迭代优化的计算方法。

参数

可以用来调节“上次估计”与“本次测量”的采用比例。

接下来我们寻求一个最优的

画龙点睛

定义两个随机变量:

令随机变量

为“上次估计”的误差,即

的误差(

真实值

)。

令随机变量

为“本次测量”的误差,即

的误差(

真实值

)。

假设

相互独立。这意味着“上次估计(之前测量)的误差”与“本次测量的误差”不相关。

假设

均服从高斯分布。这意味着其线性组合

也服从高斯分布。

这两条假设是对数学模型的理想化,也是整个推导过程中的关键。

一方面我们可以据此得到一个简洁的方程,另一方面从现实世界的情况来看,这样的假设往往是合理的。

根据这两条假设,计算随机变量的方差:

简记为:

其中

为“本次估计”的误差方差,

为“上次估计”的误差方差,

为“本次测量”的误差方差。

这是一个开口向上的一元二次函数,在顶点(导数为零)处取得最小值。

为使“本次估计”的误差方差最小(估计最可靠),令:

解得:

方程乙

余霞成绮

此时,

即:

方程丙

至此,我们的推导结束了。

实践已经证明,这个基于假设得出的理论表现不俗。

文末附一段 java 程序,看一下“卡尔曼滤波器”的高效与简洁。

/**

* 一个简单的卡尔曼滤波器

*/

public class Filter {

private double x; // 估计值

private double p; // 估计误差方差

private final double q; // 测量误差方差

// 初始化

public Filter(double x, double p, double q) {

this.x = x;

this.p = p;

this.q = q;

}

// 优化估计

public void calc(double newX) {

double k = p / (p + q); // 对应 方程乙

x = (1 - k) * x + k * newX; // 对应 方程甲

p = (1 - k) * p; // 对应 方程丙

}

// 输出结果

@Override

public String toString() {

return "x=" + x + ", p=" + p + ", q=" + q;

}

}

/**

* 程序入口

*/

public static void main(String[] args) {

Scanner scanner = new Scanner(System.in);

System.out.println("请输入估计值:");

double x = scanner.nextDouble();

System.out.println("请输入估计误差方差:");

double p = scanner.nextDouble();

System.out.println("请输入测量误差方差:");

double q = scanner.nextDouble();

// 初始化滤波器

Filter filter = new Filter(x, p, q);

System.out.println("请依次输入测量值(小于零时退出):");

// 迭代计算

while (true) {

double newX = scanner.nextDouble();

if (newX < 0) break;

// 优化估计

filter.calc(newX);

// 实时输出

System.out.println(filter);

}

scanner.close();

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 13:39:19

无人车上路的“安全底线”怎么定?聊城细则给出了答案

低速无人车这两年跑得越来越多&#xff0c;但很多人心里一直打鼓&#xff1a;到底能不能上路&#xff1f;出了事算谁的&#xff1f;聊城这次给了一个很清晰的答案——规则先立起来&#xff0c;再谈规模化运营。聊城市在11月下旬正式出台了《低速无人驾驶装备道路测试与商业示范…

作者头像 李华
网站建设 2026/4/23 12:21:51

Qt共享内存疑难解析:从创建失败到完美解决

1.Qt共享内存疑难解析&#xff1a;从创建失败到完美解决在Qt中使用QSharedMemory时遇到create成功后续操作失败的问题&#xff0c;需从共享内存生命周期管理、键值唯一性、系统级限制三个维度深入排查。以下是具体分析及解决方案&#xff1a;1. 共享内存生命周期管理缺陷问题本…

作者头像 李华
网站建设 2026/4/23 13:44:26

必看!方形与圆形油炸机挑选,这几个关键要点你得知道

《油炸机哪家好&#xff1a;排名前五深度测评》开篇&#xff1a;定下基调在餐饮行业不断发展的今天&#xff0c;油炸机作为重要的厨房设备&#xff0c;其性能和品质备受关注。本次测评旨在为对油炸机感兴趣的人群提供专业、客观的参考&#xff0c;帮助大家挑选到适合自己的油炸…

作者头像 李华
网站建设 2026/4/23 12:14:00

读懂大模型备案流程,开启技术安全应用新征程

《生成式人工智能服务管理暂行办法》提出利用生成式人工智能技术向境内公众提供生成文本、图片、音频、视频等内容的服务&#xff0c;需要进行大模型备案。 一、大模型的核心定义 不是参数大就是大模型。真正需要备案的&#xff0c;是基于深度学习技术、具备强语义理解与生成能…

作者头像 李华
网站建设 2026/4/23 13:39:19

2025国产操作系统排行榜TOP5麒麟软件持续领跑国产桌面操作系统

2025国产操作系统排行榜TOP5&#xff1a;麒麟软件持续领跑国产桌面操作系统在全球科技竞争日趋激烈的背景下&#xff0c;操作系统作为数字生态的基石与核心&#xff0c;已成为国家实现科技自主可控的关键战略领域。长期以来&#xff0c;全球市场由国外主流系统主导&#xff0c;…

作者头像 李华
网站建设 2026/4/23 12:21:36

主办方狂喜!声网STT零门槛集成,虚拟展会内容复用率飙升

前阵子参加全球行业虚拟展会&#xff0c;我简直急到抓耳挠腮&#xff01;开放办公区得静音观看&#xff0c;嘉宾分享全靠猜&#xff0c;分心就漏重点&#xff1b;跨国论坛上欧洲专家全程英文发言&#xff0c;没字幕只能靠翻译软件&#xff0c;等翻完早跟不上节奏&#xff0c;提…

作者头像 李华