题解 | #格雷码计数器#

格雷码计数器

https://www.nowcoder.com/practice/311754bcd45d42eb8d981eeddbdf1e43

`timescale 1ns/1ns

module gray_counter (
   input            clk     ,
   input            rst_n   ,
   output reg [3:0] gray_out
);

reg  [3:0] cnt;
reg        flag;

always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
        cnt  <= 0;
        flag <= 1;
    end else begin
        if (flag) cnt <= cnt + 1;
        flag <= ~flag;
    end
end

always @(posedge clk or negedge rst_n) begin
    if (!rst_n) begin
        gray_out <= 0;
    end else begin
        gray_out <= cnt ^ (cnt >> 1);
    end
end

endmodule

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-25 17:46
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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