[问答] 基于FPGA的电子日历设计——闰年的判断

[复制链接]

实习生

发表于 2016-4-1 14:51:30   962 查看 1 回复 显示全部楼层 倒序浏览
分享
本人菜鸟一个,要设计一款基于FPGA电子日历,利用verilog语言编写计时程序的时候,闰年的判断总是出问题,找不到解决方案,求大神指导!
代码:
module year(cn5,y,cn6,rst_n);
input cn5,rst_n;                              //cn5,月向年的进位符
output[15:0] y;
output cn6;
reg[15:0] y;
wire cn6;
parameter a=1;
parameter b=0;
assign cn6=(((y[15:0]%4==0)&&(y[15:0]%100!=0))||(y[15:0]%400==0))? a:b;   //闰年标志位
always@(posedge cn5 or negedge rst_n)
begin
    if(!rst_n)
                y[15:0]=16'b0001_1001_1001_0100;       //复位时显示1994年
         else
           begin         
                    if(y[3:0]>=4'd9) begin
                            if(y[7:4]>=4'h9) begin
                                    if(y[11:8]>=4'h9) begin
                                            if(y[15:12]>=4'd9)
                                                   y[15:0]=16'b0001_0000_0000_0000;
                                                 else
                                                   begin
                                                y[11:0]=0;
                                                     y[15:12]=y[15:12]+1;
                                                        end          end
                                         else
                                            begin
                                                   y[7:0]=0;
                                                   y[11:8]=y[11:8]+1;
                                                 end        end
                                  else
                                    begin
                                     y[3:0]=0;
                                          y[7:4]=y[7:4]+1;
                                         end        
                                                     end
                    else
                                  y[3:0]=y[3:0]+1;
      end         
end

endmodule仿真图如下:

year中闰年的错误显示.jpg

标签:verilog FPGA

等待验证会员

发表于 2017-3-19 23:52:16  
学习/学习/学习
回复

点赞 举报

高级模式
您需要登录后才可以回帖 登录 | 注册

关闭

站长推荐 上一条 /8 下一条

快速回复 返回顶部 返回列表
-

推荐专区

技术干货集中营

专家问答

用户帮助┃咨询与建议┃版主议事

工程师杂谈

工程师创意

工程师职场

论坛电子赛事

社区活动专版

发烧友活动

-

嵌入式论坛

ARM技术论坛

Android论坛

Linux论坛

单片机/MCU论坛

FPGA|CPLD|ASIC论坛

DSP论坛

嵌入式系统论坛

-

电源技术论坛

电源技术论坛

无线充电技术

-

硬件设计论坛

PCB设计论坛

电路设计论坛

电子元器件论坛

控制|传感

总线技术|接口技术

-

测试测量论坛

LabVIEW论坛

Matlab论坛

测试测量技术专区

仪器仪表技术专区

-

EDA设计论坛

multisim论坛

PADS技术论坛

Protel|AD|DXP论坛

Allegro论坛

proteus论坛|仿真论坛

EasyEDA-中国人自已的EDA工具

Orcad论坛

-

综合技术与应用

电机控制

智能电网

光电及显示

参考设计中心

汽车电子技术论坛

医疗电子论坛

-

开源硬件

-

无线通信论坛

无线通信技术专区

天线|RF射频|微波|雷达技术

-

IC设计论坛

芯片测试与失效分析

Mixed Signal/SOC[数模混合芯片设计]

Analog/RF IC设计

设计与制造封装测试

-

厂商专区

TI论坛

TI Deyisupport社区

-

检测技术与质量

电磁兼容(EMC)设计与整改

安规知识论坛

检测与认证

-

消费电子论坛

手机技术论坛

平板电脑/mid论坛

音视/视频/机顶盒论坛

-

电子论坛综合区

聚丰众筹官方社区

新人报道区

聚丰供应链

-

论坛服务区

-

供求信息发布

供需广告

招聘┃求职发布区

电子展览展会专区