HDLbits counters 12 hour clock

这篇具有很好参考价值的文章主要介绍了HDLbits counters 12 hour clock。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目前在HDLbits网站上比较难的一道题,记录和分享一下文章来源地址https://www.toymoban.com/news/detail-831520.html

module top_module(
    input clk,
    input reset,
    input ena,
    output pm,
    output [7:0] hh,
    output [7:0] mm,
    output [7:0] ss); 

    wire en,en1;
    reg [3:0]ss_one,ss_ten,mm_one,mm_ten,hh_one,hh_ten;
    always@(posedge clk)
        begin
            if(reset)
                begin
                    ss_one <= 4'd0;
                end
            else if(ena == 4'd1 && ss_one <= 4'd8)
                begin
                    ss_one <= ss + 4'd1;           
                end
            else if (ena == 4'd1 && ss_one == 4'd9)
                begin
                    ss_one <= 4'd0;     
                end
        end
    
    always@(posedge clk)
        begin
            if(reset)
                begin
                    ss_ten <= 4'd0;
                end
            else if (ena == 4'd1 && ss_ten <= 4'd4 && ss_one == 4'd9)
                begin
                    ss_ten <= ss_ten + 4'd1;
                end
            else if (ena == 4'd1 && ss_ten == 4'd5 && ss_one == 4'd9 )
                begin
                    ss_ten <= 4'd0;                   
                end
        end
  
    always@(posedge clk)
        begin
            if(reset)
                begin
                    mm_one <= 4'd0;
                end
            else if (en == 1 && mm_one <= 4'd8)
                begin
                    mm_one <= mm_one + 4'd1;                    
                end
            else if (en == 1 && mm_one == 4'd9)
                 begin
                    mm_one <= 4'd0;                    
                end
        end

    always@(posedge clk)
        begin
            if(reset)
                begin
                    mm_ten <= 4'd0;
                end
            else if (en == 1 && mm_ten <= 4'd4&& mm_one == 4'd9)
                begin
                    mm_ten <= mm_ten + 4'd1;
                end
            else if (en == 1 && mm_ten == 4'd5 && mm_one == 4'd9)
                begin
                    mm_ten <= 4'd0;
                end
                
        end

    always@(posedge clk )
        begin
            if(reset)
                begin
                    hh_one <= 4'd2;
                end
            else if (en1 == 1  && hh_ten ==4'd0 && hh_one <=4'd8)
                begin
                    hh_one <= hh_one + 4'd1;
                end
            else if (en1 == 1  && hh_ten ==4'd0 && hh_one ==4'd9)
                begin
                    hh_one <= 4'd0;                    
                end
            else if (en1 == 1 && hh_ten ==4'd1 &&  hh_one <=4'd1 )
                begin
                    hh_one <= hh_one + 4'd1;
                end
            else if (en1 == 1 && hh_ten ==4'd1 &&  hh_one ==4'd2)
                begin
                    hh_one <= 4'd1;        
                end

        end
    
    always@(posedge clk )
        begin
            if(reset)
                begin
                    hh_ten <= 4'd1;                    
                end
            else if(en1 == 1 && hh_one == 4'd9 && hh_ten == 4'd0)
                begin
                    hh_ten <=  4'd1;                         
                end
            else if (en== 1 && en1 == 1 && hh_one == 4'd2 && hh_ten == 4'd1)
                begin
                    hh_ten <= 4'd0;                       
                end
            else 
                begin
                    hh_ten <= hh_ten;                       
                end
        end
    
    always@(posedge clk)
        begin
            if(reset)
                begin
                    pm <= 1'd0;
                end
            else if (hh_ten == 4'd1 && hh_one == 4'd1 &&mm_ten == 4'd5 && mm_one == 4'd9 && ss_ten == 4'd5 && ss_one == 4'd9)
                begin
                    pm <= ~pm;                    
                end
            else  
                begin
                    pm<= pm;
                end
        end
                    
    assign ss = {ss_ten,ss_one};
    assign mm = {mm_ten,mm_one};
    assign hh = {hh_ten,hh_one};
    assign en = (ss_ten == 4'd5 && ss_one == 4'd9 )?1:0;
    assign en1 = (mm_ten == 4'd5 && mm_one == 4'd9 && ss_ten == 4'd5 && ss_one == 4'd9)?1:0;

endmodule

到了这里,关于HDLbits counters 12 hour clock的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【ug903】FPGA时序约束学习(4)-如何约束跨时钟域(Clock domain crossing,CDC)

    时序约束系列: 如何约束时钟 主时钟、虚拟时钟、生成时钟、时钟组、时钟不确定性 如何约束输入输出延迟 输入延迟、输出延迟 如何约束时序例外 多周期路径、输入输出延迟、虚假路径、最大最小延迟 如何约束跨时钟域 总线偏斜 跨时钟域(Clock Domain Crossing,CDC)约束适用

    2024年02月08日
    浏览(38)
  • Exams/ece241 2014 q7a(Counter1-12)

    Design a 1-12 counter with the following inputs and outputs: Reset Synchronous active-high reset that forces the counter to 1 Enable Set high for the counter to run Clk Positive edge-triggered clock input Q[3:0] The output of the counter c_enable, c_load, c_d[3:0] Control signals going to the provided 4-bit counter, so correct operation can be verified. You

    2024年02月09日
    浏览(39)
  • FPGA设计时序约束十六、虚拟时钟Virtual Clock

    目录 一、序言 二、Virtual Clock 2.1 设置界面 三、工程示例 3.1 工程设计 3.2 工程代码 3.3 时序报告 3.4 答疑 四、参考资料     在时序约束中,存在一个特殊的时序约束,虚拟时钟Virtual Clock约束,根据名称可看出时钟不是实际存在的,主要是在STA分析时序时提供一个参考。  

    2024年01月17日
    浏览(43)
  • 【FPGA 约束:set_clock_groups 之异步时钟】——详细解析

    【FPGA 约束:set_clock_groups 之异步时钟】——详细解析 FPGA 设计中,设置正确的时钟约束是非常重要的。在设计中,不同的时钟域之间都需要进行一定的同步和互锁,以保证系统能够正常工作。而异步时钟则是其中一个比较特殊的情况,其时序关系相对较为复杂,需要采用专门

    2024年02月09日
    浏览(43)
  • FPGA设计时序约束三、设置时钟组set_clock_groups

    目录 一、背景 二、时钟间关系 2.1 时钟关系分类 2.2 时钟关系查看 三、异步时钟组 3.1 优先级 3.2 使用格式 3.3 asynchronous和exclusive 3.4 结果示例 四、参考资料     Vivado中时序分析工具默认会分析设计中所有时钟相关的时序路径,除非时序约束中设置了时钟组或false路径。使

    2024年02月02日
    浏览(45)
  • 【学习记录】服务器上用Python代码下载ERA5 Hourly 数据

    需要下载至少20年的多个变量不同pressure level的ERA5 hourly数据,其中单一变量31层、4个时刻的数据约为245MB,所有数据下下来约有8T。在对比了网上现有的下载ERA5数据的方法考虑到储存问题,决定借助服务器利用python脚本下载数据,将单个变量的每日的结果存成一个文件。 ERA

    2024年02月02日
    浏览(60)
  • FPGA原理与结构(12)——FIFO IP核原理学习

    系列文章目录:FPGA原理与结构(0)——目录与传送门         FIFO是英文First-In-First-Out的缩写,是一种先入先出的数据缓冲器,与一般的存储器的区别在于没有地址线, 使用起来简单,缺点是只能顺序读写数据,其数据地址由内部读写指针自动加1完成,不能像普通存储器

    2024年02月08日
    浏览(42)
  • FPGA:ila core clock has stopped. unable to arm ila

    现象:         在调试JESD204B时,为了观察204B的输出信号,采用204B输出的时钟作为ILA的抓数时钟,结果提示ila core clock has stopped. unable to arm ila 分析: 1. 先确定204B的core时钟是否输出,将core时钟进行LED灯的驱动,LED正常闪动,这说明core时钟是出来了的。 2. ILA用其他时钟进行

    2024年03月21日
    浏览(45)
  • 【FPGA零基础学习之旅#12】三线制数码管驱动(74HC595)串行移位寄存器驱动

    🎉欢迎来到FPGA专栏~三线制数码管驱动 ☆* o(≧▽≦)o *☆ 嗨 ~我是 小夏与酒 🍹 ✨ 博客主页: 小夏与酒的博客 🎈该系列 文章专栏: FPGA学习之旅 文章作者技术和水平有限,如果文中出现错误,希望大家能指正🙏 📜 欢迎大家关注! ❤️ 🥝 ISSP调试演示: 程序配置完成:

    2024年02月09日
    浏览(46)
  • Linux设备驱动开发 - 虚拟时钟Clock驱动示例

    By: fulinux E-mail: fulinux@sina.com Blog: https://blog.csdn.net/fulinus 喜欢的盆友欢迎点赞和订阅! 你的喜欢就是我写作的动力! 很多设备里面系统时钟架构极其复杂,让学习Clock驱动的盆友头大。这里我参考S3C2440的clock驱动写了一个virtual clock,即虚拟时钟驱动,分别包含clock的provider和

    2023年04月21日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包