Verilog基础之十二、分频器实现

该文介绍了使用Verilog进行数字电路设计,实现不同占空比的奇数和偶数分频器。工程代码包括了50%占空比的奇数分频和非50%占空比的奇数分频,以及偶数分频的实现。测试文件用于验证设计,综合结果显示采用了LUT2实现相与操作,仿真结果展示了不同分频器的输出信号特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

一、前言

二、工程设计

2.1 工程代码

2.2 测试文件代码

2.3 综合结果

2.4 仿真结果


一、前言

    分频器即将高频率的信号转化为更低频率的信号,常用的分频可使用锁相环PLL来实现,也可自己编写RTL代码来实现。根据分频的系数N(假设信号频率为M,分频系数为N,则分频后的信号频率为M/N)分为奇数分频和偶数分频,奇数分频根据占空比可分为50%占空比和非50%占空比。

二、工程设计

2.1 工程代码

    ​代码文件中包含了偶数分频,占空比为50%的奇数分频,占空比为非50%的奇数分频。待分频的信号频率为周期1ns的方波信号,偶数分频的分频系数为10,奇数分频的分频系数为7.

奇数分频占空比为50%的实现为一个上升沿触发的奇数分频信号与一个下降沿触发的偶数分频信号相与获得

module Divider(clk,rst,odd_out,even_out,odev_out );
input clk,rst;
output reg odd_out,even_out;
reg clktemp1,clktemp2;
output odev_out;
reg [3:0] counter_o,counter_e,counter_oe1,counter_oe2;
parameter N=10;  //分频系数为10
parameter N1=7;  //分频系数为7
//偶数分频
always@(posedge clk,negedge rst)
begin
if(!rst)
even_out<=0;
else if(counter_e==N/2-1)
begin
even_out<=~even_out;
counter_e<=0;
end
else 
counter_e<=counter_e+1;
end

//奇数分频,占空比非50%
always@(posedge clk,negedge rst)
begin
if(!rst)
begin
odd_out<=0;
counter_o<=0;
end
else if(counter_o==(N1-1)/2)
begin
odd_out<=~odd_out;
counter_o<=counter_o+1'b1;
end
else if(counter_o==N1-1)
begin
odd_out<=~odd_out;
counter_o<=0;
end
else
counter_o<=counter_o+1'b1;
end

//奇数分频,占空比为50%
always@(posedge clk,negedge rst)
begin
if(!rst)
begin
clktemp1<=0;
counter_oe1<=0;
end
else if(counter_oe1==(N1-1)/2)
begin
clktemp1<=~clktemp1;
counter_oe1<=counter_oe1+1'b1;
end
else if(counter_oe1==N1-1)
begin
clktemp1<=~clktemp1;
counter_oe1<=0;
end
else 
counter_oe1<=counter_oe1+1'b1;
end

always@(negedge clk,negedge rst)
begin
if(!rst)
begin
clktemp2<=0;
counter_oe2<=0;
end
else if(counter_oe2==(N1-1)/2)
begin
clktemp2<=~clktemp2;
counter_oe2<=counter_oe2+1'b1;
end
else if(counter_oe2==N1-1)
begin
clktemp2<=~clktemp2;
counter_oe2<=0;
end
else
counter_oe2<=counter_oe2+1'b1;
end
assign odev_out=clktemp1|clktemp2;
endmodule

2.2 测试文件代码

`timescale 1ns / 1ps
module Divider_tb( );
reg clk,rst;
wire odd_out,even_out,odev_out;
initial
begin
clk=0;
rst=1;
#100 rst=0;
#50 rst=1;
#1000 $stop;   //仿真到1000ns时停止仿真
end
always #1 clk=~clk;  //clk信号周期为2ns
Divider divider_test(.clk(clk),.rst(rst),.odd_out(odd_out),.even_out(even_out),.odev_out(odev_out));
endmodule

2.3 综合结果

途中odev_out为占空比50%的奇数分频输出,由综合结果可知采用了一个LUT2来实现clktemp1和clktemp2的相与操作,clktemp1和clktemp2即为相同奇数分频的信号,区别是一个一个上升沿触发,一个下降沿触发

信号反向的操作,以信号even_out输出为例,即将FDCE的输出Q反馈连接到LUT5的输入,再传输到FDCE的数据输入端口D。

2.4 仿真结果

图中红色为偶数分频的输出,周期为20ns,黄色为基数分频信号,占空比非50%,紫色为基数分频信号,占空比为50%

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FPGA芯中的小蚂蚁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值