多级IIR滤波效果(BIQUAD),system verilog验证

news2024/12/26 9:40:00

MATLAB生成IIR系数

采用率1k,截止频率30hz,Matlab生成6阶对应的biquad3级系数
在这里插入图片描述

Verilog测试代码

// fs=1khz,fc=30hz
initial begin
    real Sig_Orig, Noise_white, Mix_sig;
    real fs = 1000;
    Int   T= 1;   //周期
    int   N= T*fs;    //1s的采样点数
    // 数组声明
    real Mix_sig_arr[1000];
    real Sig_0rig_arr[1000]; 
    real Sig_result_i_arr[1000];
    real Sig_result_i_arrl[1000]; 
    real Sig_result_i_arr2[1000];
    // 中间变量声明
    real Sig_result_i, Sig_result_ii, Sig_result_i2, Sig_result_i_end;
    // 滤波器系数矩阵声明
    real NUM[3][3] = {
        {1, 2.007504948495, 1.007523744426},
        {1, 1.999983159466, 1.000001892   }, 
        {1, 1.992511892039, 0.9925305617226}
    };
    real DEN[3][3] = {
        {1, -1.663488912079, 0.6934851906154},
        {1, -1.734725768632, 0.7660066007869},   
        {1, -1.873703886013, 0.9074907921583}
    };
    real gain = 0.0000004953522354214;
    #100;
    @(posedge rstn);
    // 循环处理2024个点
    for (int t = 0; t < N; t++) begin  
        @(posedge CLK_REG);
        // 生成原始信号(10Hz的正弦波)
        Sig_Orig = 0.5 * sin(2 * PI * 10 * (t / 1000.0)); // 
        Sig_0rig_arr[t] = Sig_Orig;  
        // 生成白噪声
        Noise_white = 0.25 * sin(2 * PI * 80 * (t / 1000.0)) +
                      0.15 * cos(2 * PI * 150 * (t / 1000.0)) +
                      0.05 * sin(2 * PI * 800 * (t / 1000.0) + 0.33 * PI);
        // 混合原始信号和白噪声
        Mix_sig = Sig_Orig + Noise_white;
        Mix_sig_arr[t] = Mix_sig;
        // 直接I型的IIR
        Sig_result_i = NUM[0][0] * Mix_sig_arr[t] +
                       NUM[0][1] * Mix_sig_arr[t-1] +
                       NUM[0][2] * Mix_sig_arr[t-2] -
                       DEN[0][1] * Sig_result_i_arr[t-1] -
                       DEN[0][2] * Sig_result_i_arr[t-2];
        Sig_result_i_arr[t] = Sig_result_i;
        Sig_result_il = NUM[1][0] * Sig_result_i_arr[t] +
                        NUM[1][1] * Sig_result_i_arr[t-1] +
                        NUM[1][2] * Sig_result_i_arr[t-2] -
                        DEN[1][1] * Sig_result_i_arrl[t-1] -
                        DEN[1][2] * Sig_result_i_arrl[t-2];
        Sig_result_i_arrl[t] = Sig_result_il;
        Sig_result_i2 = NUM[2][0] * Sig_result_i_arrl[t] +
                        NUM[2][1] * Sig_result_i_arrl[t-1] +
                        NUM[2][2] * Sig_result_i_arrl[t-2] -
                        DEN[2][1] * Sig_result_i_arr2[t-1] -
                        DEN[2][2] * Sig_result_i_arr2[t-2];
        Sig_result_i_arr2[t] = Sig_result_i2;
        // 计算最终结果并应用增益
        Sig_result_i_end = Sig_result_i2 * gain;
    end

多级biquad滤波器滤波效果

verdi波形,第一级还有明显的杂波,第二级后就基本还原了原始信号,每级滤波后都会有一定的相位滞后,最终增益后的幅值有细微放大(原始信号最大值500滤波后变为502.5)。
在这里插入图片描述

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

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

相关文章

MySQL索引(三):选错索引

优化器选择索引的目的&#xff0c;是找到一个最优的执行方案&#xff0c;并用最小的代价去执行语句。 思考 假设有表结构&#xff1a; -- T表结构&#xff1a; CREATE TABLE t (id int(11) NOT NULL,a int(11) DEFAULT NULL,b int(11) DEFAULT NULL,PRIMARY KEY (id),KEY a (…

区块链学习笔记(2)--区块链的交易模型part1

模型基础 区块链的tx分为两种模型&#xff0c;分别是比特币为代表的UTXO&#xff08;Unspent Transaction Output&#xff09;模型&#xff0c;和以太坊为代表的Account模型。前者适用于货币记账&#xff0c;后者适用于链上应用。 UTXO模型 类似于现金的交易模型 一个tx包含…

Redis 基础、Redis 应用

Redis 基础 什么是 Redis&#xff1f; Redis &#xff08;REmote DIctionary Server&#xff09;是一个基于 C 语言开发的开源 NoSQL 数据库&#xff08;BSD 许可&#xff09;。与传统数据库不同的是&#xff0c;Redis 的数据是保存在内存中的&#xff08;内存数据库&#xf…

php7.4安装pg扩展-contos7

今天接到一个需求&#xff0c;就是需要用thinkphp6链接pg(postgresql)数据库。废话不多说&#xff0c;直接上操作步骤 一、安装依赖 yum install -y sqlite-devel libxml2 libxml2-devel openssl openssl-devel bzip2 bzip2-devel libcurl libcurl-devel libjpeg libjpeg-dev…

Linux中的常用基本指令(下)

Linux常用基本指令 Linux中的基本指令12.head指令13.tail指令简单解释重定向与管道(重要) 14.date指令(时间相关的指令)15.cal指令(不重要)16.find指令(灰常重要&#xff09;17.grep指令(重要)18.which指令和alias指令19.zip/unzip指令&#xff1a;20.tar指令&#xff08;重要&…

Android 还在使用LogCat打日志?XLog框架;日志打印到控制台,打印到文件中。

目录&#xff1a; 为什么要打印日志&#xff1f;XLog是什么XLog如何使用 一、为什么要打印日志&#xff1f; 日志是我们系统出现错误时&#xff0c;最快速有效的定位工具&#xff0c;没有日志给出的错误信息&#xff0c;遇到报错你就会一脸懵逼&#xff1b;而且日志还可以用来…

zabbix“专家坐诊”第266期问答

问题一 Q&#xff1a;zabbix编译升级主要工作是不是将PHP,nginx,zabbix都重新编译安装一遍&#xff0c;细节的先不说 A&#xff1a;升级zabbix就可以 Q&#xff1a;这个OID是哪个OID A&#xff1a;mib文件里面有个snmp oid的值 那个就是oid。https://blog.csdn.net/qq_508853…

第八课 Unity编辑器创建的资源优化_特效篇(Particle System)详解

无论是CPU还是GPU&#xff0c;粒子系统对其的影响面都是不容小觑的。随着项目的重度化和3A化&#xff0c;玩家的口味变挑剔了、游戏玩法复杂度变高了、画面的特效表现变复杂了......所以我们还是更加谨慎地对待粒子系统。 特效&#xff08;Particle System&#xff09; 游戏效…

王道考研编程题总结

我还在完善中&#xff0c;边复习边完善&#xff08;这个只是根据我自身总结的&#xff09; 一、 线性表 1. 结构体 #define MaxSize 40 typedef struct{ElemType data[MaxSize]&#xff1b;int length; }SqList 2. 编程题 1. 删除最小值 题意 &#xff1a;从顺序表中删除…

ubuntu20.04安装OpenPcdet,CUDA版本11.8,显卡4090

本文参考这2篇文章的内容&#xff1a;https://blog.csdn.net/jin15203846657/article/details/122735375#comments_25352667 https://zhuanlan.zhihu.com/p/642158810 记录了自己安装OpenPcdet的过程。 OpenPcdet的安装需要cuda和pytorch版本严格关联。本例的CUDA版本&#xf…

初识EasyFramework

一、获取EF Git地址&#xff1a;https://github.com/HiWenHao/EFrameworkGitee地址&#xff1a;https://gitee.com/wang_xiaoheiiii/EFramework视频合集&#xff1a;EasyFramework介绍_哔哩哔哩_bilibiliQQ群: 711540505 二、 下载并初步了解 1. 下载完成后&#xff0c;可以看…

爬虫获取的数据如何用于市场分析

目录 一、网络爬虫基础 HTML解析器 API接口 数据库抓取 二、数据预处理 数据清洗 数据转换 数据整合 三、市场分析应用 消费者行为分析 竞争对手分析 市场趋势预测 四、案例分析 数据获取 数据预处理 市场分析 总结 在当今数据驱动的商业环境中&#xff0c;市…

C++小碗菜之二:软件单元测试

“没有测试的代码重构不能称之为重构&#xff0c;它仅仅是垃圾代码的到处移动” ——Corey Haines 目录 前言 什么是单元测试&#xff1f; 单元测试的组成 单元测试的命名 单元测试的独立性 Google Test 单元测试的环境配置与使用 1. Ubuntu下安装 Google Test 2. 编写…

Kubernetes架构原则和对象设计

云原生学习路线导航页&#xff08;持续更新中&#xff09; 快捷链接 Kubernetes常见问题解答 本文从 Google Borg系统的架构设计开始&#xff0c;深入讲解Kubernetes架构及组件的基本原理 1.什么是云计算 1.1.传统行业应用 假设有10台服务器&#xff0c;两个应用。小规模管…

力扣-图论-1【算法学习day.51】

前言 ###我做这类文章一个重要的目的还是给正在学习的大家提供方向和记录学习过程&#xff08;例如想要掌握基础用法&#xff0c;该刷哪些题&#xff1f;&#xff09;我的解析也不会做的非常详细&#xff0c;只会提供思路和一些关键点&#xff0c;力扣上的大佬们的题解质量是非…

学习笔记056——Docker日志的清理问题

文章目录 Docker日志的清理问题1、Docke日志所在位置2、日志清理 Docker日志的清理问题 Ubuntu上部署Docker&#xff0c;运行一段时间后&#xff0c;会累计很多的日志量。 如果不及时处理&#xff0c;会占用系统空间&#xff0c;影响系统性能。 如何处理日志累计过大的问题&…

Python3:Pytest框架parametrize报错in “parametrize“ the number of names (4)

Python3&#xff1a;Pytest框架parametrize报错in “parametrize“ the number of names (4) 排查原因&#xff1a;是pytest入参时&#xff0c;需要4个参数&#xff0c;但是提供了3个参数 test_tenant_list:- ["http://xx:8081/scheduler/v1/tenancy/list",{"co…

Linux 35.6 + JetPack v5.1.4之RTP实时视频Python框架

Linux 35.6 JetPack v5.1.4之RTP实时视频Python框架 1. 源由2. 思路3. 方法论3.1 扩展思考 - 慎谋而后定3.2 扩展思考 - 拒绝拖延或犹豫3.3 扩展思考 - 哲学思考3.4 逻辑实操 - 方法论 4 准备5. 分析5.1 gst-launch-1.05.1.1 xvimagesink5.1.2 nv3dsink5.1.3 nv3dsink sync05…

GIt (一) Git的安装,项目搭建,远程仓库,分支

文章目录 一、 版本控制1.1 集中式版本控制1.2 分布式版本控制 二、 Git的安装及配置2.1 安装2.2 Git的配置2.2 查看配置 三、 Git基本理论3.1 工作区域3.2 文件状态 四、Git项目的搭建与操作4.1 初始化Git仓库4.2 常见的操作4.2.1 文件添加到暂存区4.2.2 文件提交更新4.2.3 查…

iview upload clearFiles清除回显视图

iview upload 上传完文件之后清除内容&#xff0c;打开会回显视图&#xff0c;清除不掉 关闭弹框时主动清除回显内容即可this.$refs.uploads.clearFiles() <FormItem label"上传附件:" :label-width"formNameWidth"><Upload action"/fms/ap…