fpga系列 HDL:跨时钟域同步 shift register同步(CDC)毛刺滤除&解码前去抖动滤波模块

bash 复制代码
`timescale 1ns / 1ps

module FilterSig( 
    Clk, 
    nRst, 
    FiltSigIn, 
    FiltSigOut 
    );

input Clk, nRst;
input FiltSigIn;
output FiltSigOut;

reg [4:0] FiltSigInReg ;

always @(posedge Clk or negedge nRst)
if (!nRst) begin
    FiltSigInReg <= 'd0 ;
end
else begin
    FiltSigInReg <= {FiltSigInReg[3:0], FiltSigIn} ;
end

reg FiltSigOut ;
always @(posedge Clk or negedge nRst)
if (!nRst) 
    FiltSigOut <= 1'b0 ;
else if (FiltSigInReg[4:3] == 2'b11)
    FiltSigOut <= 1'b1 ;
else if (FiltSigInReg[4:3] == 2'b00)
    FiltSigOut <= 1'b0 ;

endmodule
  • 以上的滤波位移寄存器时钟和解码滤波结果的时钟之间的关系:
    • 最大滤除毛刺宽度
      在连续 3 周期判定的逻辑下,如果输入信号上的高电平或低电平脉冲宽度小于 3 个 Clk 周期,它就绝不可能填满判定窗口,从而会被系统完全滤除。
    • 时钟不能太快:如果时钟周期太短(频率太高),1个微小的毛刺就能维持 3 个时钟周期,滤波器就会把毛刺误当作有效信号放过去。 时钟不能太慢:如果时钟周期太长(频率太低),有效的信号可能还没来得及维持 3 个周期就结束了,系统会把有效信号当成毛刺滤掉。
    • 时钟周期的定量关系 :设输入信号中需要滤除的电气噪声/机械抖动的最大持续时间为 T n o i s e T_{noise} Tnoise,输入信号的有效最小脉冲宽度为 T s i g T_{sig} Tsig。
      T n o i s e 2 < T c l k < T s i g 3 \frac{T_{noise}}{2} < T_{clk} < \frac{T_{sig}}{3} 2Tnoise<Tclk<3Tsig

CG

相关推荐
坏孩子的诺亚方舟17 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐17 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐17 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH18 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
zlinear数据采集卡18 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安18 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐19 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯19 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客19 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c
Hello-FPGA19 天前
Xilinx KU040 FPGA Camera Link 图像采集
c++·fpga开发