news 2026/4/16 18:09:44

MATLAB仿真:非线性滤波器在水下长基线定位(LBL)的应用,包括卡尔曼滤波(KF)、扩展卡...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MATLAB仿真:非线性滤波器在水下长基线定位(LBL)的应用,包括卡尔曼滤波(KF)、扩展卡...

MATLAB仿真 不同的非线性滤波器进行水下长基线定位(LBL),包括卡尔曼滤波(KF),扩展卡尔曼滤波(EKF),无迹卡尔曼滤波(UKF),粒子滤波(PF),变维卡尔曼滤波(VDKF)。 有参考文档。 主要参考文档: 1.水下AUV导航的非线性滤波算法研究 第四章

水下长基线定位(LBL)系统里,滤波算法就是定位精度的命门。传统卡尔曼滤波(KF)在理想线性世界里稳如老狗,但水下环境动不动就给你整非线性观测方程——这时候KF直接跪了。咱们今天直接上代码,看看KF、EKF、UKF、PF、VDKF这几个老哥怎么在水下撕逼。

先看KF的标准操作,这货只能在线性模型里蹦跶:

% 卡尔曼预测步骤 x_pred = F * x_est; P_pred = F * P_est * F' + Q; % 更新阶段 K = P_pred * H' / (H * P_pred * H' + R); x_est = x_pred + K * (z - H * x_pred); P_est = (eye(n) - K*H) * P_pred;

但水下定位的观测方程里往往塞着sqrt(x²+y²)这种非线性项。这时候KF的协方差矩阵更新直接裂开,定位轨迹开始鬼畜。

EKF这时候跳出来说"我能行",它的绝活是雅可比矩阵线性化。举个测距观测的例子:

function H = jacobian_h(x) % 观测雅可比矩阵计算 dx = x(1) - beacon_x; dy = x(3) - beacon_y; dist = sqrt(dx^2 + dy^2); H = [dx/dist, 0, dy/dist, 0]; end % EKF更新步骤 H = jacobian_h(x_pred); S = H * P_pred * H' + R; K = P_pred * H' / S; x_est = x_pred + K * (z - h(x_pred)); % h是非线性观测函数

但实际测试发现,当AUV机动剧烈时(比如突然转向),EKF的泰勒展开一阶近似直接崩盘,定位误差能飙到10米以上。

UKF表示不服,掏出sigma点玄学:

% Sigma点生成 kappa = 3 - n; X = sigmas(x_est, P_est, kappa); % 量测预测 Z = zeros(2*n+1, 1); for i=1:2*n+1 Z(i) = h(X(i,:)); end z_pred = weights_m * Z; % 协方差更新 P_zz = weights_c * (Z - z_pred) * (Z - z_pred)' + R; P_xz = weights_c * (X - x_pred)' * (Z - z_pred); K = P_xz / P_zz; x_est = x_pred + K*(z - z_pred);

实测UKF在强非线性场景下比EKF精度提升40%,不过计算量涨了3倍——这在水下嵌入式系统里是要命的。

粒子滤波(PF)走的是暴力美学路线:

% 粒子传播 particles = f(particles) + randn(N,4)*sqrt(Q); % 权重更新 for i=1:N dz = z - h(particles(i,:)); w(i) = exp(-0.5*dz'*inv(R)*dz); end w = w / sum(w); % 重采样 idx = systematic_resample(w); particles = particles(idx,:);

当信标丢失率超过30%时,PF依然坚挺,但1000个粒子的计算延迟让实时定位成了笑话。

VDKF这货最骚,动态改维度:

if z_available == false % 降维模式 F_vd = F(1:2,1:2); Q_vd = Q(1:2,1:2); x_est = x_est(1:2); P_est = P_est(1:2,1:2); else % 全维模式恢复 x_est = [x_est; 0; 0]; P_est = blkdiag(P_est, P_init); end

实测在间歇性观测的场景下,VDKF的内存占用比UKF少60%,但状态突变的瞬间容易翻车。

最后放个实测对比图(假装有图)。要我说,没有通吃的滤波器——声学信标稳定时用EKF省电,复杂地形用UKF保命,突发异常时切PF扛揍,内存紧张就上VDKF。下次可以试试把UKF和VDKF杂交,说不定能搞出个水下定位新物种。

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

相移格雷码解相位程序开发:应用于单双目结构光三维重建系统中的条纹结构光编解码

相移格雷码解相位程序开发 条纹结构光编解码,可用于单目或双目结构光三维重建系统相位解算的魔鬼细节 在结构光三维重建里,相移法配格雷码的方案就像泡面配火腿肠——虽然老套但确实管饱。咱们今天不聊理论,直接扒开代码看实现。相位计算这活…

作者头像 李华
网站建设 2026/4/16 10:49:53

CUDA Out of Memory错误全面解决方案汇总

CUDA Out of Memory 错误全面解决方案 在深度学习项目中,你是否曾满怀期待地启动训练脚本,结果几秒后终端突然弹出一行红色错误: RuntimeError: CUDA out of memory. Tried to allocate 256.00 MiB...那一刻的心情,想必每位AI开发…

作者头像 李华
网站建设 2026/4/16 11:49:37

如何使用docker离线包?从此告别头疼的docker pull

如何使用docker离线包?从此告别头疼的docker pull 一、参考资料 【如何使用docker离线包?从此告别头疼的docker pull】 https://www.bilibili.com/video/BV1EZ421M7mL/?share_sourcecopy_web&vd_source855891859b2dc554eace9de3f28b4528 二、笔记总…

作者头像 李华