【数字信号去噪】粒子滤波器与FBS、MAP平滑方法数字信号去噪【含Matlab源码 2179期】

news2025/1/30 16:42:31

⛄一、平滑分解简介

根据奈奎斯特定理,采样频率必须大于等于有用信号最高频率的2倍。假设对心电信号的采样满足奈奎斯特采样定理,则实测信号采样频率的1/2为有用心电信号的最高频率。通过三点平滑滤波,可以将频率大于1/2采样频率的信号滤除,将滤除的信号定义为第1阶平滑分解分量(sdc1)。而剩余信号中的最高频率则为前一阶提取频率的下限。继续按剩余信号最高频率的1/2进行新的平滑滤波提取,平滑滤波点数为前一级平滑滤波点数的2倍减1。直到平滑点数大于1/2数据长度且小于数据长度时分解结束。平滑分解方法描述如下。

设实际检测到的心电信号为s(n),n=1,2,…,N为样本序号,N为信号长度。记第k阶平滑分解分量为sdck(n),剩余信号记为rk(n),k=1,2,…,M。M=int(lb2(N-1))为最大分解阶数。

1)当k=1时
在这里插入图片描述
2)当k≥2时
在这里插入图片描述
在以上各式中,当i<1或i>N时,s(i)和rk-1(i)取相应的数据端点值。

  1. 信号重构
    在这里插入图片描述

⛄二、部分源代码

close all
T=100; %Number of Time Steps
n=10; %Number of Particles
m=1; %Number of iterations

for iter=1:m
%Mean and standard deviation of state equation
a=.6; b=.2;
%Mean and standard deviation of state equation
c=2; d=.2;

%Simulate the dynamical system x and y, initializing x(1)=x0
x0=rand;
[x,y]=simulate(a,b,c,d,x0,T);

%Particle Filter, particles initialized at xf(:,1)=X0
X0=random(‘uniform’,0,1,n,1);
tic
[xf,wftilda]=pfilter(a,b,c,d,X0,y);
toc

%Particle Smoothing (FBS)
tic
[wstilda wstilda2,wstilda3]=fbssmoother(a,b,xf,wftilda);
toc

%Particle Smoother (Maximum A-posterior) initialized at xf(:,1)=X20
%Initialization
X20=zeros(n,1);
tic
[psi,delta,meanm,wstilda4,wstilda5]=mapsmoother(a,b,c,d,X20,xf,wftilda,y);
toc

%Estimation of filter and fbs smoother posterior means at time t
for t=2:T
meanf(t)=xf(:,t)‘*wftilda(:,t);
means(t)=xf(:,t)’*wstilda(:,t);
meansf(t)=xf(:,t)'*wstilda(:,t);
end

%Computes the MSE of filter, fbs, and map
FilterMSE(iter)=norm(x(2:end)-meanf(2:end),‘fro’)/norm(x(2:end),‘fro’)
FBSsmootherMSE(iter)=norm(x(2:end)-means(2:end),‘fro’)/norm(x(2:end),‘fro’)
MAPsmootherMSE(iter)=norm(x(2:end)-meanm(2:end),‘fro’)/norm(x(2:end),‘fro’)
%Computes the Likelihood of filter, fbs, and map
LL(iter)=likelihood(y,x,a,b,c,d)
FilterLL(iter)=likelihood(y,meanf,a,b,c,d)
FBSsmootherLL(iter)=likelihood(y,means,a,b,c,d)
MAPsmootherLL(iter)=likelihood(y,meanm,a,b,c,d)
end

if m==1
%Plots of simulated x vs the estimated xhat of filter, fbs, and map
hold on
plot(x(2:end),‘k’,‘linewidth’,2)
plot(meanf(2:end),‘:r*’,‘linewidth’,2)
plot(means(2:end),‘:go’,‘linewidth’,2)
plot(meanm(2:end),‘:bd’,‘linewidth’,2)
xlabel(‘time’)
ylabel(‘state’)
h = legend(‘True State’,‘Filter’,‘FBS-Smoother’,‘MAP-Smoother’);
else
fmean=mean(FilterMSE)
smean=mean(FBSsmootherMSE)
mmean=mean(MAPsmootherMSE)
fll=mean(FilterLL)
sll=mean(FBSsmootherLL)
mll=mean(MAPsmootherLL)
end

⛄三、运行结果

在这里插入图片描述

⛄四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]张淼,魏国.心电信号平滑分解阈值去噪方法[J].哈尔滨工程大学学报. 2020,41(09)

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除

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

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

相关文章

使用 IDEA 的 Dedis 插件连接 Redis 服务器

IDEA 中的 Redis 插件作为 Redis 的可视化工具&#xff0c;可以通过此插件连接 Redis 服务器&#xff0c;并且进行增删改查操作 【一】 IDEA 安装 Redis 插件 1. 点击 File >> Setting 2. 点击 Plugings 3. 点击 Marketplace 一栏的搜索框中输入 redis 4. 点击第一个 R…

yocto machine class解析-st-partitions-image

yocto machine class解析 stm32mp157 yocto的meta-st-stm32mp layer中提供了几个class,后续几篇文章重点分析这些class文件&#xff1a; 第一篇就从st-partitions-image.bbclass 开始&#xff0c;st所有创建image的bb文件都会引用st-partitions-image&#xff0c;包括bootfs u…

审计日志功能实现优化及测试记录(参照若依系统,以dolphinscheduler 2.0.5 为例,实现相关功能)

目录&#x1f42c;使用&#x1f420;若依-操作日志&#x1f420;引入海豚调度&#x1f41f;引入审计日志包&#xff0c;增加LogAnnotation注解&#x1f42c;问题记录及优化&#x1f420;service方法注解时而生效&#xff0c;时而不生效&#x1f41f;不生效原因&#x1f41f;修改…

基于springboot+mybatis+sqlserver+jsp运行会报名管理系统

基于springbootmybatissqlserverjsp运行会报名管理系统一、系统介绍二、功能展示1.用户登陆2.用户注册3.项目列表(运行员)4.报名列表&#xff08;运动员&#xff09;5.运动员项目列表&#xff08;管理员&#xff09;6.添加项目四、获取源码一、系统介绍 系统主要功能&#xff…

【计算机组成原理Note】2.4.2 加法器

文章目录加法器1. 一位全加器2. 串行加法器3. 串行进位加法器加法器4. 先行进位加法器加法器 1. 一位全加器 一位全加器&#xff0c;当前位输出&#xff1a;SiAi⨁Bi⨁Ci也就是输入中有奇数个1时输出为1&#xff08;异或&#xff09;向高位的进位&#xff1a;CiAiBi(Ai⨁Bi)Ci…

【目标检测】LLA: Loss-aware label assignment for dense pedestrian detection【标签分配】

总结 本文提出了一种用于行人目标检测的标签分配策略&#xff0c;具体来说&#xff0c;主要有以下几步流程。 构建代价矩阵。通过网络的前向传播得到网络的输出&#xff0c;CclsC^{cls}Ccls, CregC^{reg}Creg&#xff0c;构建代价矩阵CCclsλ∗CregCC^{cls}\lambda*C^{reg}CC…

小程序环境切换自定义组件

背景&#xff1a; 最近一直有参与小程序的项目&#xff0c;发现切换环境时经常要上传然后再设置为体验版&#xff0c;比较麻烦&#xff0c;所以尝试做了个切换环境的组件&#xff0c;分享给大家&#xff0c;希望大家能用得上&#xff0c;提点建议 组件长这个样子 展开后 功能&a…

JVM的垃圾回收机制(GC)

系列文章目录 JVM的内存区域划分_crazy_xieyi的博客-CSDN博客 JVM类加载&#xff08;类加载过程、双亲委派模型&#xff09;_crazy_xieyi的博客-CSDN博客 文章目录 一、什么是垃圾回收&#xff1f;二、java的垃圾回收&#xff0c;要回收的内存是哪些&#xff1f;三、回收堆上…

FPGA Base Xilinx跨时钟域宏XPM_CDC

FPGA Base Xilinx跨时钟域宏XPM_CDC最近看手底下的小伙子们写代码&#xff0c;对于跨时钟域的处理极度的不规范&#xff0c;还是放下这句话基础不牢&#xff0c;地动山摇 其实Xilinx公司已经为用户提供了宏定义&#xff0c;实现跨时钟域处理&#xff0c;见截图 XPM_CDC在命名上…

关于旅游景点主题的HTML网页设计——青岛民俗 7页 带登录注册

⛵ 源码获取 文末联系 ✈ Web前端开发技术 描述 网页设计题材&#xff0c;DIVCSS 布局制作,HTMLCSS网页设计期末课程大作业 | 游景点介绍 | 旅游风景区 | 家乡介绍 | 等网站的设计与制作| HTML期末大学生网页设计作业 HTML&#xff1a;结构 CSS&#xff1a;样式 在操作方面上运…

【C++】简化源码——vector的模拟实现

文章目录一、前言二、无参构造&析构三、基础接口1.empty和clear2.size和capacity3.[]和iterator四、resize和reserve五、尾插尾删六、其他构造七、迭代器失效1.insert2.erase八、memcpy问题九、vector.h一、前言 本篇的目的很简单&#xff0c;只有一个&#xff1a;模拟实现…

C语言刷题(一)

&#x1f412;博客名&#xff1a;平凡的小苏 &#x1f4da;学习格言&#xff1a;别人可以拷贝我的模式&#xff0c;但不能拷贝我不断往前的激情 目录 用递归法求一个整数一维数组a的最大元素 猴子吃桃问题 奇偶数换位问题 水仙花数&#xff08;0-100000&#xff09; 换啤酒…

web前端电影项目作业源码 大学生影视主题网页制作电影网页设计模板 学生静态网页作业成品 dreamweaver电影HTML网站制作

HTML实例网页代码, 本实例适合于初学HTML的同学。该实例里面有设置了css的样式设置&#xff0c;有div的样式格局&#xff0c;这个实例比较全面&#xff0c;有助于同学的学习,本文将介绍如何通过从头开始设计个人网站并将其转换为代码的过程来实践设计。 文章目录一、网页介绍一…

redis命令行操作库、键、和五大数据类型详解

一、数据库操作命令 redis默认有16个数据库&#xff0c;类似数组下标从0开始&#xff0c;初始默认使用0号库。 1.1 测试是否连通 ping测试服务器是否连通 返回pone就是连通了 1.2 切换数据库 select index1.3 数据移动 move key db1.4 显示数据总量 dbsize1.5 数据清除 …

Maven 跳过测试的几种方式

在 Maven 对项目进行编译的时候&#xff0c;我们通常可能会希望跳过复杂的测试。 尤其是在开始项目还不是非常稳定的阶段。 命令行中使用 -Dmaven.test.skiptrue 在命令行&#xff0c;只要简单的给任何目标添加 maven.test.skip 属性就能跳过测试&#xff1a; mvn install …

leetcode:6251. 统计回文子序列数目【dp + 统计xy子序列出现的个数】

目录题目截图题目分析ac code总结题目截图 题目分析 固定了中间的数i后从两边选xy 和 yx对于x y的情况&#xff0c;比较简单预处理每个数字出现的index为ids然后看看两边x各自的个数n1 n2n1和n2必须大于等于2左边可以选n1 * (n1 - 1) // 2右边可以选n2 * (n2 - 1) // 2两边乘…

【C++】通过哈希表实现map和set

前言 在前面&#xff0c;我们通过红黑树这一底层结构实现了map和set。它们是关联式容器。而现在&#xff0c;我们将通过哈希表这一数据结构重新实现map和set&#xff0c;即unordered系列的关联式容器。因为它们的遍历是无序的&#xff0c;和平衡二叉树不同&#xff0c;不能做到…

APOLLO UDACITY自动驾驶课程笔记——规划、控制

1、路径规划使用三个输入&#xff0c;第一个输入为地图&#xff0c;Apollo提供的地图数据包括公路网和实时交通信息。第二个输入为我们当前在地图上的位置。第三个输入为我们的目的地&#xff0c;目的地取决于车辆中的乘客。 2、将地图转为图形 该图形由“节点”(node)和“边缘…

直流潮流计算matlab程序

一、直流潮流计算原理 直流潮流发的特点是用电力系统的交流潮流&#xff08;有功功率和无功功率&#xff09;等值的直流电流来代替。甚至只用直流电路的解析法来分析电力系统的有功潮流&#xff0c;而不考虑无功分布对有功的影响。这样一来计算速度加快&#xff0c;但计算的准确…

Rocket MQ : 拒绝神化零拷贝

注: 本文绝非对零拷贝机制的否定笔者能力有限&#xff0c;理解偏差请大家多多指正不可否认零拷贝对于Rocket MQ的高性能表现有着积极正面的作用&#xff0c;但是笔者认为只是锦上添花&#xff0c;并非决定性因素。Rocket MQ性能卓越的原因绝非零拷贝就可以一言以蔽之。 笔者企图…