题解 | #Johnson Counter#

Johnson Counter

http://www.nowcoder.com/practice/7ee6e9ed687c40c3981d7586a65bc22d

简析

环形计数器

电路图

状态图

扭环形计数器

电路图

状态图

FF3FF_3的反相输出接回到FF0FF_0就构成了扭环形计数器,也被称为约翰逊计数器Johnson Counter。它比环形计数器增加了有效循环的状态数量。

可自启动的扭环形计数器

电路图

状态图

扭环形计数器仍然有很多状态是无效的,一旦计数器进入这些状态就会陷入死循环,无法正常工作。计数器的初始状态必须位于有效循环的几种状态之中才能启动。通过添加门电路可以拆掉无效循环,也就是可以自启动的扭环形计数器。

图片来自《数字电子技术基础(第六版)》阎石主编。

代码

`timescale 1ns/1ns

module JC_counter(
   input                clk ,
   input                rst_n,
 
   output reg [3:0]     Q  
);
    always@(posedge clk or negedge rst_n) begin
        if(~rst_n)
            Q <= 0;
        else if(~Q[0])
            Q <= {1'b1, Q[3:1]};
        else if(Q[0])
            Q <= {1'b0, Q[3:1]};
    end
  
  	// 参考答案中更简洁的写法
  	//always@(posedge clk or negedge rst_n) begin
    //    if(~rst_n)
    //        Q <= 0;
    //    else
    //        Q <= {~Q[0], Q[3:1]};
    //end
endmodule
Verilog篇题解 文章被收录于专栏

本人对牛客网verilog篇题目一些理解

全部评论

相关推荐

找工作勤劳小蜜蜂:自我描述部分太差,完全看不出想从事什么行业什么岗位,也看不出想在哪个地区发展,这样 会让HR很犹豫,从而把你简历否决掉。现在企业都很注重员工稳定性和专注性,特别对于热爱本行业的员工。 你实习的工作又太传统的it开发(老旧),这部分公司已经趋于被淘汰,新兴的互联网服务业,比如物流,电商,新传媒,游戏开发和传统的It开发有天然区别。不是说传统It开发不行,而是就业岗位太少,基本趋于饱和,很多老骨头还能坚持,不需要新血液。 工作区域(比如长三角,珠三角,成渝)等也是HR考虑的因素之一,也是要你有个坚定的决心。否则去几天,人跑了,HR会被用人单位骂死。
点赞 评论 收藏
分享
评论
4
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务