• 采用流水线结构的CIC 抽取滤波器结构如下:
  • // 三级CIC抽取器实例:cic3_decimator.V
  • module cic3_decimator(clk, x_in, y_out);
  • parameter        STATE_HOLD = 1'b0, STATE_SAMPLE = 1'b1;
  • input                   clk;                                // 输入时钟
  • input         [7:0]   x_in;                        // 输入8位数据
  • output [25:0] y_out;                // 输出26位数据
  • reg              state, derived_clk;
  • reg [4:0] counter;
  • // 有限状态机,用于实现下采样
  • always @(negedge clk) begin: FSM_DECIMATOR
  • case(state)
  • STATE_HOLD: begin
  • if(counter == 31)
  • state <= STATE_SAMPLE;
  • end
  • STATE_SAMPLE: begin
  • ComReg0[0] <= IntReg[2];
  • state <= STATE_HOLD;
  • end
  • default:
  • state <= STATE_HOLD;
  • endcase
  • if((counter>8)&&(counter<16))        // 生成下采样后的时钟
  • derived_clk <= 1;
  • else
  • derived_clk <= 0;
  • counter <= counter + 1;
  • end
  • wire [25:0] sxtx;                // Sign extended input
  • assign sxtx = {{18{x[7]}},x};        // 符号扩展
  • reg  [7:0]  x;                                        // Registered input
  • reg [25:0] IntReg[2:0];                        // I section 0,1 and 2
  • // 积分器实现模块
  • always @(posedge clk) begin: INTEGRATOR
  • x  <= x_in;
  • IntReg[0] <= IntReg[0] + sxtx;
  • IntReg[1] <= IntReg[1] + IntReg[0];
  • IntReg[2] <= IntReg[2] + IntReg[1];
  • end
  • reg [25:0] ComReg0[2:0],ComReg1[2:0],ComReg2[2:0],ComReg3;
  • //梳状器实现模块
  • always @(posedge derived_clk)begin:COMB
  • ComReg0[1] <= ComReg0[0];
  • ComReg0[2] <= ComReg0[1];
  • ComReg1[0] <= ComReg0[0] - ComReg0[2];
  • ComReg1[1] <= ComReg1[0];
  • ComReg1[2] <= ComReg1[1];
  • ComReg2[0] <= ComReg1[0] - ComReg1[2];
  • ComReg2[1] <= ComReg2[0];
  • ComReg2[2] <= ComReg2[1];
  • ComReg3     <= ComReg2[0] - ComReg2[2];
  • end
  • assign y_out = ComReg3;                //输出
  • endmodule

CIC 抽取滤波器 Verilog Code的更多相关文章

  1. matlab 与 modelsim 联调 cic抽取滤波器

    注:本设计的参数为:D=2,R=5,N=3:时钟频率为50mhz,输入信号为有符号8位,根据公式bmax=bin+N*log(2,R*D):可以得到bmax=18: 1,cic抽取滤波器原理 网上资料 ...

  2. Verilog code

    1.计数,用于对精度不高的计数 always @(posedge clk or negedge rst_n) begin if(!rst_n) div_cnt <= 'd0; else div_ ...

  3. 直流滤波器 verilog

    // dc filter- y(n) = c*x(n) + (1-c)*y(n-1) `timescale 1ps/1ps module ad_dcfilter #( // data path dis ...

  4. Verilog Tips and Interview Questions

    Verilog Interiew Quetions Collection :  What is the difference between $display and $monitor and $wr ...

  5. verilog流水线加法器

    四位加法器 两级加法实现 verilog code module pipeliningadder( output reg [3:0] s, output reg co, input [3:0] a, ...

  6. verilog 实现加法器

    半加器 如果不考虑来自低位的进位将两个1二进制数相加,称为半加. 实现半加运算的逻辑电路称为半加器. 真值表 逻辑表达式和 \begin{align}\notag s = a{b}' + {a}'b ...

  7. verilog FAQ(zz)

    1. What is the race condition in verilog? Ans :The situation when two expressions are allowed to exe ...

  8. ∑–△型模数转换器(ADC)简介

    ∑–△型模数转换器(ADC) 1.概述 近年来,随着超大规模集成电路制造水平的提高,Σ-Δ型模数转换器正以其分辨率高.线性度好.成本低等特点得到越来越广泛的应用.Σ-Δ型模数转换器方案早在20世纪60 ...

  9. i.MX RT600之DMIC外设介绍及应用

    恩智浦的i.MX RT600是跨界处理器产品,同样也是i.MX RTxxx系列的开山之作.不同于i.MX RT1xxx系列单片机,i.MX RT600 采用了双核架构,将新一代Cortex-M33内核 ...

随机推荐

  1. Java Evaluate Reverse Polish Notation(逆波兰式)

    表情:: ["2", "1", "+", "3", "*"] -> ((2 + 1) * 3) ...

  2. 静态方法使用bean

    java类中的代码 public class BidMsgUtil { private static Logger log = Logger.getLogger(BidMsgUtil.class); ...

  3. Gradle 多渠道打包的使用和错误分析(转)

    刚接触到android的开发,对什么都陌生的,本文是自己在项目中使用的技术要点总结,大咖遇到可直接飘过..... 1.Gradle 打包(不废话了直接来脚本),将下列脚本放到build.gradle文 ...

  4. 修改系统启动项 grub2配置的方法 ubuntu[转]

    在 早期的Ubuntu中,使用Grub作为系统的启动引导程序,想修改系统启动项非常简单,只要用gedit打开系统菜单设定文件( sudo gedit /boot/grub/menu.lst ),修改该 ...

  5. JS window.open()财产

    一. Window 对象 Window 对象是 JavaScript 顶级对象层次. Window 对象表示一个浏览器窗口或帧. Window 在对象 <body> 或 <frame ...

  6. 使用crontab创建 linux 系统定时任务#

    任务1: 每隔1分钟,运行一次 /home/sn/yeelink.sh文件 ,用于上传数据到www.yeelink.net 1. 先在当时目录里面创建一个cronfile文件 vim cronfile ...

  7. easyui动力头 &amp;&amp; 动态加入tabs

    今天,在实现了业务时的,我们需要根据后台操作,以产生多个数据tab页,而且每一个tab页表格根据需要动态生成的标题数据. 返回后台数据格例如,下面的公式: 实现方法例如以下: //$("#c ...

  8. Xamarin.Android 在VS下调试时提示 In mgmain JNI_OnLoad 程序“Mono”已退出 解决办法

    原因是使用了破解版的 Xamarin,调试时不能使用共享库

  9. 英特尔® 硬件加速执行管理器安装指南 — Microsoft Windows*

    介绍 本文将指导您安装英特尔® 硬件加速执行管理器(英特尔® HAXM),这是一款可以使用英特尔® 虚拟化技术(VT)加快 Android* 开发速度的硬件辅助虚拟化引擎(管理程序). 前提条件 英特 ...

  10. 构建工具maven

     构建工具maven  =UTF-8''Gradle Effective Implementation Guide.pdf: http://www.t00y.com/file/76854506 b ...