抽取_内插_半带滤波器_多相滤波器

news2024/12/23 15:34:20

文章目录

  • 半带滤波器
  • 多相抽取滤波器
  • 多相内插滤波器
    • 半带抽取器和半带内插器

参考资料:Xilinx FIR Compiler v7.2 LogiCORE IP Product Guide PG149

半带滤波器

半带滤波器的阶数为偶数,系数长度为奇数,且除了中间系数为0.5外,其余偶数序号系数都为0。
系数长度 = 抽头数 = FIR滤波器的阶数 + 1 。
半带滤波器的幅频响应如下图。半带滤波器主要用于2倍的抽取前的滤波。
在这里插入图片描述
通带截止频率 Ω p \Omega_p Ωp和阻带起始频率 Ω s t \Omega_{st} Ωst关于 π 2 \frac{\pi}{2} 2π(或 f s 4 ) \frac{f_s}{4}) 4fs)对称,且通带纹波等于阻带纹波,即满足如下表达式。
Ω p = π − Ω s t ,    δ p = δ s \Omega_p = \pi - \Omega_{st},\ \ \delta_p = \delta_{s} Ωp=πΩst,  δp=δs

针对一个抽头数为11的半带滤波器其脉冲响应和FPGA实现结构如下图。
在这里插入图片描述

在这里插入图片描述
针对滤波器系数的对称性还可以优化实现结构。第一幅图针对奇数抽头,第二幅图针对偶数抽头。

以AD9361的接收信号链路中用于2倍抽取的Rx HB1为例。其系数为[-8, 0, 42, 0, -147, 0, 619, 1013, 619, 0, -147, 0, 42, 0, -8]。

h = [-8, 0, 42, 0, -147, 0, 619, 1013, 619, 0, -147, 0, 42, 0, -8];
[H,W] = freqz(h);
Hf = abs(H);% 幅频响应
Hx = angle(H);% 相频响应
plot(W,Hf/max(Hf));% 归一化幅频响应

在这里插入图片描述
AD9361中用于3倍抽取时的Rx DEC3系数为 [55, 83, 0, -393, -580, 0, 1914, 4041, 5120, 4041, 1914, 0, -580, -393, 0, 83, 55]。同样画出其归一化幅频响应,标记出关键点。
在这里插入图片描述
有数字信号处理理论:
x ( n ) → H D ( e j ω ) → ↓ D → x D ( m ) x(n) \to H_D(e^{j\omega}) \to \downarrow D \to x_D(m) x(n)HD(ejω)DxD(m)
其中 ∣ H D ( e j ω ) ∣ = { D ∣ ω ∣ < π / D 0 π / D ⩽ ∣ ω ∣ < π \left|H_{\mathrm{D}}\left(\mathrm{e}^{\mathrm{j} \omega}\right)\right|=\left\{\begin{array}{ll} D & |\omega|<\pi / D \\ 0 & \pi / D \leqslant|\omega|<\pi \end{array}\right. HD(ejω)={D0ω<π/Dπ/Dω<π

多相抽取滤波器

下图为一个M倍抽取的多相抽取滤波器结构示意图。
在这里插入图片描述
其中 N N N个原滤波器系数 a ( 0 ) , a ( 1 ) , ⋯   , a ( N − 1 ) a(0),a(1),\cdots,a(N-1) a(0),a(1),,a(N1)被映射到 M M M个多相子滤波器系数 h 0 ( n ) , h 1 ( n ) , ⋯   , h M − 1 ( n ) h_{0}(n), h_{1}(n), \cdots, h_{M-1}(n) h0(n),h1(n),,hM1(n),两者关系如以下公式。
h i ( r ) = a ( i + M r )     i = 0 , 1 , ⋯   , M − 1     r = 0 , 1 , ⋯   , N M h_i(r) = a(i+Mr)\ \ \ i =0,1,\cdots,M-1\ \ \ r=0,1,\cdots,\frac{N}{M} hi(r)=a(i+Mr)   i=0,1,,M1   r=0,1,,MN
例如 h = [ a , b , c , d , e , f , g , h , g , f , e , d , c , b , a ] , M = 3 h 0 = [ a , d , g , f , c ] h 1 = [ b , e , h , e , b ] h 2 = [ c , f , g , d , a ] \begin{matrix} \\h=[a,b,c,d,e,f,g,h,g,f,e,d,c,b,a],M=3 \\h_0=[a,d,g,f,c] \\h_1=[b,e,h,e,b] \\h_2=[c,f,g,d,a] \end{matrix} h=[a,b,c,d,e,f,g,h,g,f,e,d,c,b,a]M=3h0=[a,d,g,f,c]h1=[b,e,h,e,b]h2=[c,f,g,d,a]
多相抽取滤波器通过输入换向器将输入样本 x ( n ) x(n) x(n)送入多相子滤波器,换向器索引从 M − 1 M-1 M1递减到 0 0 0。在换向器执行了一个周期并向滤波器组提供了 M M M个输入样本后,各多相子滤波器的输出之和作为一个输出样本 y ( n ) y(n) y(n)。则 y ( n ) y(n) y(n)的输出采样率为 f s / M f_s/M fs/M

多相内插滤波器

下图为一个P倍内插的多相内插滤波器结构示意图。
在这里插入图片描述
其中 N N N个原滤波器系数 a ( 0 ) , a ( 1 ) , ⋯   , a ( N − 1 ) a(0),a(1),\cdots,a(N-1) a(0),a(1),,a(N1)被映射到 P P P个多相子滤波器系数 h 0 ( n ) , h 1 ( n ) , ⋯   , h P − 1 ( n ) h_{0}(n), h_{1}(n), \cdots, h_{P-1}(n) h0(n),h1(n),,hP1(n),两者关系如以下公式。
h i ( r ) = a ( i + P r )     i = 0 , 1 , ⋯   , P − 1     r = 0 , 1 , ⋯   , N P h_i(r) = a(i+Pr)\ \ \ i =0,1,\cdots,P-1\ \ \ r=0,1,\cdots,\frac{N}{P} hi(r)=a(i+Pr)   i=0,1,,P1   r=0,1,,PN
多相内插滤波器的每一个输入样本 x ( n ) x(n) x(n)都要送入到各个多相子滤波器,一个输入样本 x ( n ) x(n) x(n)经过多相内插滤波器后对应 P P P个输出样本 y ( n ) y(n) y(n)。输出采样率为 P × f s P\times f_s P×fs

半带抽取器和半带内插器

结合前面所述,半带抽取器和内插器就将半带滤波器与多相滤波器结合起来。具体结构如下图。
在这里插入图片描述
在这里插入图片描述
以前面所用的Rx HB1系数为例,其系数为[-8, 0, 42, 0, -147, 0, 619, 1013, 619, 0, -147, 0, 42, 0, -8]。

close all; clear;
x = round(rand(1,1000)*5);
h = [-8, 0, 42, 0, -147, 0, 619, 1013, 619, 0, -147, 0, 42, 0, -8];
n = length(h);
h0 = h(1:2:end);
h1 = h(2:2:end);
y1 = conv(x,h);% 先滤波后抽取
y1 = y1(n/2:end-n/2);
y1 = y1(1:2:end);
x_a = x(1:2:end);% 先抽取再滤波
y2_a = conv(x_a,h0); 
y2_a = y2_a(n/4:end-n/4);
x_b = x(2:2:end);
y2_b = conv(x_b,h0);
y2_b = y2_b(n/4:end-n/4);
y2 = y2_a + y2_b;
x = x/max(x);% 归一化
y1 = y1/max(y1);
y2 = y2/max(y2);

通过Matlab信号分析工具箱画出两种方法输出y1和y2的时域图和频域图,可以看到两种方法均可实现2倍的抽取操作,且两者的频域波形相差不大。
在这里插入图片描述

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

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

相关文章

mybatisplus 使用mybatis中的配置、mapper配置文件

1、在application.properties中配置mybatis的配置文件路径&#xff0c;例如&#xff1a; #指定mybatis-config.xml的位置 mybatis-plus.config-location classpath:mybatis/mybatis-config.xml 即在和application.properties同级目录下的mybatis目录中创建mybatis的配置文件m…

数制编码详解:二进制八进制十六进制的转换,原码、补码、反码、移码的定义

参考资料&#xff1a;《深入理解计算机网络&#xff08;王达&#xff09;》 文章目录一&#xff0c;数制1.1 基本数制1.2 不同数制之间的相互转换二&#xff0c;编码一&#xff0c;数制 1.1 基本数制 “数制”是“数据进制”的简称&#xff0c;也就是表示数据逢几进位的意思&a…

chatGPT的体验,是不是真智能?

目录 &#x1f3c6;一、前言 &#x1f3c6;二、安装 &#x1f3c6;三、普通对话 &#x1f6a9;1、chatGPT的ikun性 &#x1f6a9;2、chatGPT的日常对话 &#x1f3c6;四、实用能力 &#x1f3c6;五、代码改正 &#x1f3c6;六、写代码 &#x1f3c6;七、讲解代码 &#x1f3c6;…

ESXI精简thin磁盘迁移存储位置保留磁盘类型不变-无vc方式

运行2年了ESXI的SSD存储上很多VM并带多层快照&#xff0c;最近磁盘速度异常&#xff0c;迁移到新存储&#xff0c;都是thin磁盘&#xff1b;如有vCenter条件&#xff0c;采用“迁移”即可完美解决&#xff0c;既使磁盘类型thin不变又保留快照结构。如无vCenter条件的操作方式细…

Unity-iOS工程导出Xcode自动构建方法

Unity-iOS发布基本流程首先在Unity中导出Xcode工程&#xff0c;然后在Xcode工程中设置IOS打包的一些流程&#xff0c;诸如引入lib、framework或其他资源、设置签名及其他编译设置、加入编译脚本等等操作。 这些操作如果每次都是在导出Xcode后手动操作&#xff0c;一来浪费时间…

【C++ STL】-- 红黑树的插入实现

目录 红黑树的概念 二叉树搜索树的应用 红黑树节点的定义 红黑树结构 insert 需调整的多情况的核心思维&#xff1a; 需调整的多情况分类讲解&#xff1a; 情况一: 情况二: 情况三: 总结&#xff1a; 代码实现&#xff1a; 对于红黑树是否建立成功的检查 升序打印…

C++--类型转换--1128

1.C语言中的类型转换 分为隐式类型转化、显示强制类型转化。 隐式类型转化用于意义相近的类型&#xff0c;比如int,double,short都是表示数值的类型 int i1; double di; //编译、结果无问题 这里是隐式类型转换。 显示强制类型转换 显示强制类型用于意义不相近的类型&…

Redis Sentinel

高可用架构-Redis Sentinel Replication 缺点 接着之前的Redis Replication 主从复制架构&#xff0c;看似解决了主节点并发过大时&#xff0c;master节点处理繁忙的问题。将一部分读数据的请求交给从节点处理&#xff0c;从而将请求进行分散处理。但是该架构却存在很明显的缺…

基于LEACH的随机网络生成无线传感器网络路由协议的仿真比较(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…

【深度学习】超详细的 PyTorch 学习笔记(上)

文章目录一、PyTorch环境检查二、查看张量类型三、查看张量尺寸和所占内存大小四、创建张量4.1 创建值全为1的张量4.2 创建值全为0的张量4.3 创建值全为指定值的张量4.4 通过 list 创建张量4.5 通过 ndarray 创建张量4.6 创建指定范围和间距的有序张量4.7 创建单位矩阵&#xf…

【力扣算法简单五十题】23.环形链表

给你一个链表的头节点 head &#xff0c;判断链表中是否有环。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置&#xff08;索…

基于多种优化算法及神经网络的光伏系统控制(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️❤️&#x1f4a5;&#x1f4a5;&#x1f4a5; &#x1f389;作者研究&#xff1a;&#x1f3c5;&#x1f3c5;&#x1f3c5;本科计算机专业&#xff0c;研究生电气学硕…

NNDL 实验八 网络优化与正则化(3)不同优化算法比较

文章目录7.3 不同优化算法的比较分析7.3.1 优化算法的实验设定7.3.1.1 2D可视化实验7.3.1.2 简单拟合实验7.3.1.3 与Torch API对比&#xff0c;验证正确性7.3.2 学习率调整7.3.2.1 AdaGrad算法7.3.2.2 RMSprop算法7.3.3 梯度估计修正7.3.3.1 动量法7.3.3.2 Adam算法7.3.4 不同优…

【并发】深度解析CAS原理与底层源码

【并发】深度解析CAS原理与底层源码 什么是 CAS&#xff1f; CAS全称是&#xff08;Compare And Swap&#xff0c;比较并交换&#xff09;&#xff0c;通常指的是这样一种原子操作&#xff08;针对一个变量&#xff0c;首先比较它的内存值与某个期望值是否相同&#xff0c;如…

不就是Redis吗?竟让我一个月拿了8个offer,其中两家都是一线大厂

在高并发的场景Redis是必须的&#xff0c;而 Redis非关系型内存存储不可谓不彪悍。 支持异步持久化达到容灾&#xff1a;速度快、并发高。官方号称支持并发11万读操作&#xff0c;并发8万写操作。惊了吗&#xff1f; 支持数据结构丰富&#xff1a;string&#xff08;字符串&a…

盘点5种最频繁使用的检测异常值的方法(附Python代码)

本文介绍了数据科学家必备的五种检测异常值的方法。 无论是通过识别错误还是主动预防&#xff0c;检测异常值对任何业务都是重要的。本文将讨论五种检测异常值的方法。 文章目录什么是异常值&#xff1f;为什么我们要关注异常值&#xff1f;技术提升方法1——标准差方法2——箱…

【OpenEnergyMonitor】开源的能源监控系统--项目介绍

OpenEnergyMonitor1. 系统框架2.项目组成2.1 emonPi模块:2.1.1 emonpi的安装&#xff1a;2.1.2 emonTx & emonBase 安装2.1.3 emonTx Wifi 安装&#xff1a;2.1.4 添加额外的 emonTx 节点&#xff1a;2.1.5 添加额外的emonTx-节点监控三项电源2.1.6 添加 emonTH 温度节点2.…

【Vue核心】8.计算属性

1. 定义: 要用的属性不存在,要通过已有属性计算得来。 2. 原理 底层借助了objcet.defineproperty方法提供的getter fllsetter. 3. get两数什么时候执行? (1),初次读取时会执行一次。 (2),当依赖的数据发生改变时会被再次调用。 4. 优势 与methods实现相比,内部有缓存机…

进厂手册:Git 学习笔记(详解命令)

文章目录git 对象通过git对象进行文件的保存git对象的缺点树对象构建树对象提交对象高层命令工作区的文件状态git reset hard 咋用以及用错了怎么恢复git checkout vs git resetGit存储后悔药工作区暂存区版本库reset三部曲checkout深入理解tag远程上的相关操作ssh登入一些个人…

[附源码]计算机毕业设计家庭整理服务管理系统Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…