从零开始动手做Verilog实验--02--模为60的BCD加法器

一、什么是模为60的BCD加法器?

1.模为60的BCD加法器本质上是一个专门用于处理六十进制(Sexagesimal)计数的数字逻辑电路。

2.它从 0 计数到 59。当输入再加 1 时,结果不是 60,而是归零,并产生一个进位信号给高位。

3。采用8位的res作为结果。高四位表示十位,范围从0到5;低四位表示个位,范围从0到9.

二、代码

BCD_60counter.v代码如下:

c 复制代码
`timescale 1ns / 1ps

module BCD_60counter(

    input                    clk                                  ,
    input                    rst                                  ,
    input                    load                                 ,
    input       [7:0]             load_data                            ,
    input                    cin                                  ,
    output reg[7:0]res                         ,
    output                 cout 

    );
    
    always @(posedge clk) begin
        if(!rst) res<=0;
        else if(load) res <= load_data;
        else
            if(cin) begin
                if(res[3:0] == 4'h9) 
                begin
                 res[3:0] <= 4'h0;
                 if(res[7:4] == 4'h5) res[7:4] <= 4'h0; else res[7:4] <= res[7:4] +1'b1;
                 end
                 else
                 res[3:0] <= res[3:0] + 1'b1;
                 end
end


assign cout =  (res ==8'h59)&&(cin ==1'b1 ) ? 1'b1:1'b0;             
                    
endmodule

BCD_60counter_tb.v仿真文件代码如下:

c 复制代码
`timescale 1ns / 1ps


module BCD_60counter_tb;

reg   clk                           ;
reg   rst                           ;
reg   load                          ;
reg  [7:0]  load_data                     ;
reg   cin                           ;
wire [7:0] res;               
wire cout;

BCD_60counter u_counter(
                
   .  clk                      ( clk)        ,                
   .  rst                      (  rst)       ,                
   .  load                     (  load)       ,                
   .  load_data                (     load_data)   ,                
   .  cin                      (   cin)      ,             
   .res (res),                
   .cout                       (cout)
                
    );                
  
  parameter cycle = 20;
                
 always #(cycle/2) clk=~clk;               
                
  initial begin
  
  clk =0;rst=0;cin =0; load =0; load_data=0;
  #cycle rst =1'b1; cin =1'b1;
  
  #(cycle*100 )   load=1;load_data=8'h58;
  #cycle load =0; load_data=0;
  
  #(cycle*50)      $finish;
  
  end             



endmodule

三、仿真截图如下:

1.从tb文件可知:时钟周期是20ns

2.看懂initial块的的执行动作:

0ns,赋值为0

20ns,rst置为1,取消复位;cin置为1,使能计数器计数累加

再过2000ns,加载数据

下一个周期,取消加载,不取消的话会一直加载,res一直是58

再过50个周期,停止运行。

3.判断仿真结果正确的两个点

第一个是59之后是否变为00

第二个是加载58是否成功

从图中看到,都是成功的。

四、原理图:

相关推荐
坏孩子的诺亚方舟6 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐6 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐6 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH7 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
zlinear数据采集卡7 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安7 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐8 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯8 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客8 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c
Hello-FPGA8 天前
Xilinx KU040 FPGA Camera Link 图像采集
c++·fpga开发