⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pulse_level_g.v

📁 基于Verilog-HDL的硬件电路的实现 9.6 脉冲高电平和低电平持续时间的测量与显示   9.6.1 脉冲高电平和低电平持续时间测量的工作原理   9.6.2 高低电平持续时间测量模
💻 V
字号:

module  PULSE_LEVEL_G  (CLK, CLKX, RST, H_LEVEL, L_LEVEL);   
    input    CLK, CLKX, RST;
    output   [16:0] H_LEVEL;
    output   [7:0]  L_LEVEL; 
    wire     CLKX_N;
    wire     [16:0] L_LEVEL_M;
       
    assign  CLKX_N=~CLKX;
    assign  L_LEVEL=L_LEVEL_M[7:0];

    HIGN_LEVEL  HIGN_LEVEL (CLK, CLKX, RST, H_LEVEL);
    HIGN_LEVEL  LOW_LEVEL  (CLK, CLKX_N, RST, L_LEVEL_M);

endmodule

module  HIGN_LEVEL  (CLK, CLKX, RST, H_LEVEL);   
    input    CLK, CLKX, RST;
    output   [16:0] H_LEVEL;
    reg      [16:0] H_LEVEL;
    reg      [16:0] H_OUT; 
    reg      CNT_EN;
    wire     CNT_H_EN;
    wire     H_LOAD;
    wire     CNT_H_CLR;   

    always @ (posedge CLKX or negedge RST)
       begin
         if (!RST)
           begin
             CNT_EN=0;
           end
         else 
           begin
             CNT_EN=~CNT_EN;
           end
        end
    
    assign  CNT_H_EN=CLKX & CNT_EN;
    assign  H_LOAD=~CNT_H_EN;		
    assign  CNT_H_CLR=~(~CLKX & ~CNT_EN);   

    always @(posedge CLK or negedge CNT_H_CLR)
       begin
        if (!CNT_H_CLR)   
           H_OUT=0;
        else if (CNT_H_EN)
           begin
             if (H_OUT==99999)
                 H_OUT=99999;
             else 
                 H_OUT=H_OUT+1;
           end
       end
 
    always @ (posedge H_LOAD)
       begin
         H_LEVEL=H_OUT;
       end

endmodule



⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -