久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

標(biāo)題: 基于fpga的輸入信號(hào)邊沿濾波(上升沿/下降沿)微秒 veilog [打印本頁(yè)]

作者: 51hei圓圓    時(shí)間: 2024-1-23 00:56
標(biāo)題: 基于fpga的輸入信號(hào)邊沿濾波(上升沿/下降沿)微秒 veilog
濾波效果如圖所示


直接上代碼

veilog源碼
module my_filter_us(
        input clk,//200Mhz
        input rst,
        input pulse_in,
        input[7:0] pulse_delay,//濾波數(shù)值輸入,單位us  1-100
        output reg pulse_out=1



);
reg[19:0] cnt_delay=0;
reg[3:0] filter_satae=3;

wire[19:0] data;
assign data=pulse_delay*200;
reg[19:0] cnt_rst=0;
reg rst_n=0;

always @(posedge clk)
        begin
                if(cnt_rst<100000)
                        begin
                                cnt_rst<=cnt_rst+1;
                        end
                else
                        begin
                                rst_n<=1;
                        end
        end

always @(posedge clk or negedge rst_n)
        begin
                if(!rst_n)
                        begin

                        end
                else
                        begin
                                case(filter_satae)
                                        0:        begin
                                                        if(pulse_out==0)
                                                                begin
                                                                        filter_satae<=filter_satae+1;
                                                                end
                                                        else if(cnt_delay<data)
                                                                        begin
                                                                                if(pulse_in==0)
                                                                                        begin
                                                                                                cnt_delay<=cnt_delay+1;
                                                                                        end
                                                                                else
                                                                                        begin
                                                                                                cnt_delay<=0;
                                                                                                //data<=pulse_delay*200;
                                                                                        end
                                                                        end
                                                        else if(pulse_in==0)
                                                                begin
                                                                        pulse_out<=0;
                                                                        cnt_delay<=0;
                                                                end
                                                end
                                        1:        begin
                                                        filter_satae<=filter_satae+1;
                                                end
                                        2:        begin
                                                        if(pulse_out==1)
                                                                begin
                                                                        filter_satae<=filter_satae+1;
                                                                end
                                                        else if(cnt_delay<data)
                                                                        begin
                                                                                if(pulse_in==1)
                                                                                        begin
                                                                                                cnt_delay<=cnt_delay+1;
                                                                                        end
                                                                                else
                                                                                        begin
                                                                                                cnt_delay<=0;
                                                                                                //data<=pulse_delay*200;
                                                                                        end
                                                                        end
                                                        else if(pulse_in==1)
                                                                begin
                                                                        pulse_out<=1;
                                                                        cnt_delay<=0;
                                                                end

                                                end
                                        3:        begin
                                                        filter_satae<=0;
                                                        //data<=pulse_delay*200;
                                                end

                                endcase
                        end
        end


endmodule


仿真
`timescale 1ns/1ps
module my_filter_us_tb(
);
reg clk=0;
reg pulse_in=0;
reg [7:0]pulse_delay=10;
wire pulse_out;

my_filter_us u1(
        .clk(clk),
        .pulse_in(pulse_in),
        .pulse_delay(pulse_delay),
        .pulse_out(pulse_out)
);

initial begin
forever
        begin
                clk=0; #2 clk=1; #3;//200Mhz      

        end
end

initial begin
forever
        begin



                pulse_in=0; #60000;
                pulse_in=0; #3000 pulse_in=1; #3000;
                pulse_in=0; #3000 pulse_in=1; #3000;
                pulse_in=0; #3000 pulse_in=1; #3000;
                pulse_in=0; #3000 pulse_in=1; #3000;

                pulse_in=1; #60000;
                pulse_in=0; #3000 pulse_in=1; #3000;
                pulse_in=0; #3000 pulse_in=1; #3000;
                pulse_in=0; #3000; pulse_in=1; #3000;
                pulse_in=0; #3000; pulse_in=1; #3000;

        end
end
endmodule






歡迎光臨 (http://m.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 欧美精品二区三区四区免费看视频 | 一极黄色片 | 国产专区在线播放 | 欧美专区在线观看 | 久久国产一区二区三区 | 国产福利小视频 | 国产精品久久久久久久久久辛辛 | 免费成人结看片 | 超碰免费人人 | 草草福利影院 | 国产成人免费视频 | 欧美在线小视频 | 欧美成人精品一区二区三区 | 黄色片免费观看 | 日本视频在线免费观看 | www.sihu| av在线播放免费 | 日韩性生活视频 | 视频一二区 | 欧美激情综合五月色丁香 | av高清在线 | 在线视频亚洲 | 久久天堂网 | 中文字幕在线资源 | 欧美性生交xxxxx久久久 | 黄色片免费网站 | 亚洲欧美综合 | 精品久久精品 | 免费观看黄色av | 99爱视频| 免费特级毛片 | 亚洲成人a v| 国产精品美女在线观看 | 亚洲精品999 | 亚州一区二区 | 岛国av在线播放 | 福利在线播放 | 久久免费看片 | 久久精品视频一区二区 | 国产一区在线看 | 国产91在线看|