【CIC滤波器】基于MATLAB/FPGA的数字CIC滤波器的设计

article/2025/10/6 7:25:04

FPGA代码:

module down(i_clk,//输入时钟i_rst,//输入复位信号i_M,  //抽取值i_data,//输入信号o_data,//输出信号r_clk);input              i_clk;//输入时钟
input              i_rst;//输入复位信号
input       [7:0]  i_M;  //抽取值          
input signed[31:0] i_data;//输入信号
output signed[31:0]o_data;//输出信号
output             r_clk;//输出信号
reg       [7:0] r_cnt =8'd0;
reg signed[31:0]o_data=32'd0;
reg             r_clk =1'b0;always @(posedge i_clk)
beginif(!i_rst)//系统复位beginr_cnt<=8'd0;r_clk<=1'b0;end
else beginif(r_cnt==i_M/2-1)//分频beginr_clk<=~r_clk;r_cnt<=8'd0;endelse beginr_cnt<=r_cnt+1'b1;r_clk<=r_clk; end end
end always @(posedge r_clk)
beginif(!i_rst)//系统复位begino_data<=32'd0;end
else begino_data<=i_data;//抽取end
end endmodule           

MATLAB代码:

clc;
clear;
close all;%CIC又称为梳状滤波器,所以这里首先给出其梳状波形。。。。
%积分滤波器的响应
b1=1;
a1=[1 -1];
D=9;
b2=[1 zeros(1,D-1) -1];
a2=1;
b3=b2;
a3=a1;
b4=conv(b3,b3);
a4=conv(a3,a3);
b5=conv(b4,b3);
a5=conv(a4,a3);
b6=conv(b4,b4);
a6=conv(a4,a4);
b7=conv(b6,b3);
a7=conv(a6,a3);
figure(1);
freqz(b7/D^5,a7,'whole');%CIC抽取滤波器
% 抽取因子
r = 2;                 
hm = mfilt.cicdecim(r);  
%原始的采样率 44.1kHz.
fs = 44.1e3; 
%10240个采样点
n = 0:10239;           
%原始信号
x  = sin(2*pi*1e3/fs*n);  
%得到抽取后的5120个采样点
y_fi = filter(hm,x);        
x = double(x);
y = double(y_fi);
y = y/max(abs(y));
figure(2);
stem(n(1:44)/fs,x(2:45)); hold on;  
stem(n(1:22)/(fs/r),y(3:24),'r','filled'); 
xlabel('时间(sec)');ylabel('信号值');
title('CIC抽取滤波器');%CIC内插滤波器
%插值因子
R = 2;                    
hm = mfilt.cicinterp(R);
% 原始采样频率:22.05 kHz.
fs = 22.05e3;           
% 5120个采样点
n = 0:5119;              
%原始信号
x = sin(2*pi*1e3/fs*n);    
y_fi = filter(hm,x);  
x = double(x);
y = double(y_fi);
y = y/max(abs(y));
figure(3);
stem(n(1:22)/fs,x(1:22),'filled'); hold on;
stem(n(1:44)/(fs*R),y(4:47),'r');  
xlabel('时间(sec)');ylabel('信号值');
title('CIC内插滤波器');

仿真与说明

1.1 MATLAB设计说明

这个CIC滤波器的频率特性,如果上图,上图和梳子比较相似。所以称为梳状滤波器。

    这个是CIC抽取滤波器,如图可以看到,每2个点抽取一个点,达到抽取效果。

    这个是CIC内插滤波器,如图可以看到,每2个点插入一个点,达到抽取效果。

1.2 FPGA设计说明

    一般在实际应用中,我们多半设计抽取滤波器用的更多,一般抽取滤波器如下所示:

在这里,我们将其中一些参数具体化,设计一个具体参数的CIC滤波器。

我们将这个系统模块话,然后在实际应用的时候,我们只要改变其中的参数就可以了。

系统分为如下三个模块。

       

模块一的设计:

delay_one(

                i_clk,//输入时钟

                i_rst,//输入复位信号

                i_data,//输入信号

                o_data//输出信号

                );

模块二的设计:

down(

           i_clk,//输入时钟

           i_rst,//输入复位信号

           i_M,  //抽取值

           i_data,//输入信号

           o_data//输出信号

           );

模块三的设计:

delay_M(

              i_clk,//输入时钟

              i_rst,//输入复位信号

              i_data,//输入信号

              o_data//输出信号

              );

那么其在顶层,我们只要调用这些模块就行了。

其中CIC积分器输出结果如下所示:

系统滤波输出结果如下所示:

可以看到,滤波后的效果。

当改变CIC级数的时候,就能得到不同效果的CIC滤波器

      检验CIC滤波器最快的方法就是输入一个阶跃信号,这里我们输入的阶跃信号是00FFFFFF,最终通过CIC滤波器的效果如dataout,通过查看相关文献资料,阶跃信号信号通过CIC滤波器后的效果为:

     

  

其效果和我们FPGA设计得到的效果基本相同。

 以上是输入随机信号后滤波效果,显然,其波形特性得到了改善。

A01-23


http://chatgpt.dhexx.cn/article/Y6waBofB.shtml

相关文章

CIE RGB、CIE XYZ、 Lab空间转换

颜色空间转换 CIE RGB转化到CIE XYZCIE XYZ到Lab空间 CIE RGB转化到CIE XYZ 由于CIE RGB空间在描述色彩时会出现负值&#xff0c;因此为了方便计算&#xff08;1931年&#xff09;&#xff0c;CIE提出了一种新的色彩空间 CIE XYZ。 转换公式如下&#xff1a; 可见&#xff0c;…

【Matlab 图像】LAB 色彩空间分析

名称 在开始之前&#xff0c;先明确一下Lab颜色空间&#xff08;Lab color space&#xff09;的名字&#xff1a; Lab的全称是CIELAB&#xff0c;有时候也写成CIE Lab*这里的CIE代表International Commission on Illumination&#xff08;国际照明委员会&#xff09;&#xf…

C计算CIELAB、CIELUV均匀颜色空间中两种颜色的色差

C计算CIELAB、CIELUV均匀颜色空间中两种颜色的色差 ** 如何利用C语言计算两种颜色在CIELAB、CIELUV的总色差&#xff1f;例如&#xff1a;已知两颜色样品的色度值为&#xff1a;Y176.79&#xff0c;x10.4480&#xff0c; y10.3478&#xff1b;Y275.67&#xff0c;x20.4621&…

CIE颜色空间LCh、Lab、XYZ-sRGB介绍与转换关系(包含源码)

项目场景&#xff1a; 提示&#xff1a;在颜色科学中&#xff0c;LCh和Lab是比较常用的 LCh是由MATLAB计算出的数据&#xff0c;但是我所需要在Qt的q3dsurface绘制出这个切面&#xff0c;看了Qt官方Examples&#xff0c;墨西哥草帽算法的3D模型就是由XYZ组成的。所以我需要LC…

RGB和CIELAB颜色空间转换及偏色检测

RGB转为CIELAB 首先RGB是不可以直接转为CIELAB颜色空间的&#xff0c;RGB需要先转为CIEXYZ颜色空间&#xff0c;然后再由CIEXYZ颜色空间转为CIELAB颜色空间。关于这2个颜色空间的互转&#xff0c;主要参考了http://www.cnblogs.com/Imageshop/archive/2013/02/02/2889897.html…

sRGB转CIEXYZ转CIELAB,以及色彩距离

sRGB是标准色彩空间 是一个微软和惠普于1996年定义的标准色彩空间 如果想从sRGB转到CIEXYZ空间&#xff0c;要乘以这个矩阵&#xff1a; 得到CIEXYZ之后&#xff0c;可以再转成CIELAB&#xff1a; 其中 X 0 , Y 0 , Z 0 X_0, Y_0, Z_0 X0​,Y0​,Z0​是定义的参考白点&#…

深入理解color model(颜色模型)

什么是颜色 Wiki是这样说的&#xff1a;颜色或色彩是通过眼、脑和我们的生活经验所产生的一种对光的视觉效应。嗯&#xff0c;简单点说&#xff0c;颜色就是人对光的一种感觉&#xff0c;由大脑产生的一种感觉。感觉是一个很主观的东西&#xff0c;你怎么确定你看到的红色和我…

深度学习AI美颜系列---肤色相似度计算(CIELAB色差计算)

深度学习AI美颜系列---肤色相似度计算&#xff08;CIELAB色差计算&#xff09; 在AI美颜中&#xff0c;经常会用到肤色相似度计算&#xff0c;如何实现这个算法&#xff1f; 步骤如下&#xff1a; 1&#xff0c;人脸皮肤分割&#xff1b; 2&#xff0c;对人脸皮肤分割结果进…

彩色图像--色彩空间 CIELAB、CIELUV

学习DIP第65天 转载请标明本文出处&#xff1a;http://blog.csdn.net/tonyshengtan &#xff0c;出于尊重文章作者的劳动&#xff0c;转载请标明出处&#xff01;文章代码已托管&#xff0c;欢迎共同开发&#xff1a;https://github.com/Tony-Tan/DIPpro 更多图像处理机器学习内…

【视觉基础篇】10 # 图形系统如何表示颜色?

说明 【跟月影学可视化】学习笔记。 RGB 和 RGBA 颜色 RGB 和 RGBA 的颜色表示法 #RRGGBB 是 RGB 颜色的十六进制表示法&#xff0c;其中 RR、GG、BB 分别是两位十六进制数字&#xff0c;表示红、绿、蓝三色通道的色阶。 色阶可以表示某个通道的强弱。 每个通道一共有 25…

CIELab图像的通道分解与合成

import cv2 import numpy as np lotus cv2.imread(lotus.jpg) showImgByPlot(lotus,10,6) lotus_lab cv2.cvtColor(lotus, cv2.COLOR_BGR2LAB) l, a, b cv2.split(lotus_lab) #! featureMat cv2.merge([l, a, b]) #! merge失败 featureMat np.dstack((l, a, b)).astype(np…

CIELab和LCH的色彩空间图

资料来源&#xff1a;http://www.18show.cn/share_news/599547.html CIE Lab&#xff1a; LAB色空间是基于一种颜色不能同时既是蓝又是黄这个理论而建立。所以CIE Lab&#xff0c;单一数值可用于描述红/绿色及黄/蓝色特徽。当一种颜色用CIE L*a*b*时&#xff0c;L* 表示明度值…

CIELAB色差计算

CIE色差计算就是在之前Lab颜色空间进行的。色差一般指的是由于位置不同或者放大率不同所造成的颜色差异。而在图像处理领域&#xff0c;尤其是针对色彩的处理中&#xff0c;很重要的一点就是消除色差。那么接下来我们就讨论CIE色差公式的改进过程&#xff0c;每次改进的意义&am…

彩色空间-CIELAB和LAB的关系

CIELAB和LAB的关系 CIELab是CIE的一个颜色系统&#xff0c;表色体系&#xff0c;基于CIELab的意思是基于这个颜色系统之上&#xff0c;基本是用于确定某个颜色的数值信息。 Hunter 1948 L, a, b色彩空间的坐标是L, a和b。但是&#xff0c;Lab经常用做CIE 1976 (L*, a*, b*)色彩…

MATLAB GUI设计如何弹出新界面?

本意是想要设计一个图像处理系统&#xff0c;在该系统中点击按钮可以跳转到另一个GUI界面&#xff0c;在该界面设计后将所设置参数引回到原有的GUI界面&#xff0c;并在该界面进行显示处理好的图像。各位如果有好的结果的话麻烦江湖救急&#xff01;或者可以加我QQ&#xff1a;…

Matlab GUI编程

在matlab命令行上输入guide或者从菜单中选择New GUI可以创建matlab的图形用户界面。 创建空白的GUI界面&#xff08;默认&#xff09;&#xff0c;其界面如下&#xff1a; 未命名情况下matlab将会在当前工作目录下&#xff0c;同时将会生成untitled.fig和untitled.m文件。其中…

学习matlab(十四)——GUI

1.编程方法 在本章首先详细的介绍了MATLAB的图形句柄,通过对图形对象的属性进行设置,可以是实现图形的底层控制和设置。然后介绍了用户接口对象,用于建立各种按钮、菜单和工具条等。最后介绍了常用的对话框,这些对话框是GUI编程常用的基本元件。 在MATLAB中,各种句柄图形对象…

matlab制作GUI界面(1)

matlab制作GUI界面 概述创建GUI界面界面设置静态文本最后 概述 图形用户界面&#xff08;Graphical User Interface&#xff0c;简称 GUI&#xff0c;又称图形用户接口&#xff09;是指采用图形方式显示的计算机操作用户界面。 图形用户界面是一种人与计算机通信的界面显示格式…

matlab GUI编程入门

转载请注明来自&#xff1a;黄朝辉的博客 1.前言 这里我们来实现一个加法器&#xff0c;功能比较简单&#xff0c;主要用于了解matlab中的代码是如何与控件进行交互。 2.绘制界面 在命令行窗口中输入&#xff1a; >> guide 直接“确定”即可。 将需要的控件从左边托…

MATLAB GUI学习———简易计算器

暑假快要过完了才想起来学习&#xff0c;最近刚好接触到MATLAB中的GUI&#xff0c;觉得还挺有意思的&#xff0c;今天就用GUI产生了一个简易的计算器&#xff0c;实现了基本的加、减、乘、除运算。由于是新手小白&#xff0c;所以刚刚开始的时候&#xff0c;我是在网上去找了一…