Verilog学习笔记简单功能实现(六)...............计数分频电路

在分频器电路中最重要的概念有两个;1)奇分频/偶分频;2)占空比。

A)其中最简单的就是二分频电路,占空比为50%,其Verilog程序为

 1 module half_clk(clr,clk_in,clk_out,out2);
 2   input clr,clk_in;
 3   output clk_out,out2; 
 4   reg clk_out,out2;
 5   
 6   always @(posedge clk_in)
 7   begin
 8   if (clr==0) begin clk_out=0; out2=1;end
 9     else begin clk_out<=~clk_out; out2=~out2;end
10   end
11 endmodule 

波形图如下所示:

 

B)采用计数器实现计数分频(偶数)占空比为50%,如实现40分频,程序如下:

 1 module fdivision(rst,clkin,clkout);
 2   input rst,clkin;
 3   output clkout;
 4   reg clkout;
 5   reg [4:0]i;
 6   always @(posedge clkin)
 7   begin
 8   if(!rst) begin clkout<=0; i<=0;end
 9     else begin
10          if(i==19)
11            begin clkout<=~clkout;i<=0;end
12            else
13           i<=i+1;
14          end
15   end
16 endmodule 

波形图:

 

C)采用相与/相或的方式实现奇分频,以及占空比可调分频器;如5分频,占空比分别为50%,40%

 1 module fdivision5(clkin,clkout);
 2   input  clkin;
 3   output clkout;
 4   wire clkout;
 5   reg [2:0]step,step1;
 6   always @(posedge clkin)
 7   begin
 8     case(step)
 9       3'b000:step<=3'b010;
10       3'b010:step<=3'b100;
11       3'b100:step<=3'b001;
12       3'b001:step<=3'b011;
13       3'b011:step<=3'b000;
14       default step<=3'b000;
15     endcase
16   end
17   always @(negedge clkin)
18   begin
19   case(step1)
20       3'b000:step1<=3'b010;
21       3'b010:step1<=3'b100;
22       3'b100:step1<=3'b001;
23       3'b001:step1<=3'b011;
24       3'b011:step1<=3'b000;
25       default step1<=3'b000;
26     endcase
27   end
28   assign clkout=(step[0]|step1[0]);
29 endmodule

顶层文件(testbench):

 1 `timescale 1ns/1ns
 2 `define half_period 20
 3 module fdivision5_test;
 4   reg  clkin;
 5   wire clkout;
 6   wire step,step1;
 7   initial
 8   begin
 9   clkin=0;
10   end
11   always #`half_period clkin=~clkin;
12   fdivision5 m(clkin,clkout);
13   assign step=m.step;
14   assign step1=m.step1;
15 endmodule

波形图:

 

也可以采用两个计数器分别对上升沿和下降沿进行计数来实现奇分频:

 

module div5(clkin,clkout,rst);
  input clkin,rst;
  output clkout;

  parameter N=5;
  wire clk1,clk2;
  reg [2:0]cnt1,cnt2;

  always @(posedge clkin or negedge rst)
  if (!rst) cnt1<=0;
  else if(cnt1<(N-1)) cnt1<=cnt1+1;
       else cnt1<=0;

  always @(negedge clkin or negedge rst)
  if (!rst) cnt2<=0;
  else if(cnt2<(N-1)) cnt2<=cnt2+1;
       else cnt2<=0;

  assign clk1=(cnt1<=((N-1)/2))?1'b1:1'b0;
  assign clk2=(cnt2<=((N-1)/2))?1'b1:1'b0;
  assign clkout=clk1&clk2;
endmodule

 

其testbench为:

`timescale 10ns/1ns
`define period 2
module div5_test;
  reg clkin,rst;
  wire clkout;
  wire clk1,clk2;
  
  initial 
  begin
  clkin=0;
  rst=1;
  #5 rst=0;
  #55 rst=1;
  end
always #`period clkin=~clkin;
assign clk1=m.clk1;
assign clk2=m.clk2;

div5 m(clkin,clkout,rst);

endmodule

 

波形图为:

posted @ 2016-11-08 21:46  SYoong  阅读(5731)  评论(0编辑  收藏  举报