【IC设计】奇数分频与偶数分频 电路设计(含讲解、RTL代码、Testbench代码)

文章目录

  • 原理分析
  • 实现和仿真
    • 偶数分频的电路RTL代码
    • 偶数分频的电路Testbench代码
    • 偶数分频的电路仿真波形
    • 占空比为50%的三分频电路RTL代码
    • 占空比为50%的三分频电路Testbench代码
    • 占空比为50%的三分频电路仿真波形
  • 参考资料

原理分析

分频电路是将给定clk时钟信号频率降低为div_clk的电路,假设原时钟的频率为M Hz,分频后的时钟为N Hz,那么就称该分频电路为M/N分频。

如果M/N是奇数,实现该功能的电路就是奇数分频电路;
如果M/N是偶数,实现该功能的电路就是偶数分频电路。

频率和周期的对应关系:
由于频率f=1/T,因此二分频电路即M/N=(1/T1)/(1/T2) = T2/T1 = 2 ,即一个二分频后的时钟周期是原时钟周期的两倍。
同理,一个N分频后的时钟周期是原时钟的M/N倍。

偶数分频举例:
以两分频电路为例,由于周期为原先的两倍,那么只需要在clk每个上升沿到来时,div_clk翻转,就可以了。
以四分频电路为例,由于周期为原先的四倍,那么需要在clk每两个周期div_clk翻转一次。需要使用计数器来数clk过了几个周期。
同理,一个K分频电路,K为偶数,那么由于周期为原先的K倍,那么需要在clk每K/2个周期div_clk翻转一次

奇数分频举例:
以三分频电路为例,周期为原先的三倍。
如果对占空比(高电平占整个周期的比例)没有要求,我们可以令out_clk在clk的一个周期为高,两个周期为低,如此反复。

如果占空比为一半,那么就是每1.5个周期翻转一次,无法通过检测上升和下降沿来翻转,那么应该怎么做?
如图所示,我们的目标是每1.5个周期翻转一次,那么可以这样做,得到一个占空比为50%的奇数分频。

  1. 构造out_clk1和out_clk2信号,高电平都是1个周期,低电平都是2个周期,两个信号的区别是相差半个周期的相位。
  2. assign out_clk = out_clk1 | out_clk2
  3. out_clk就是分频的结果
    在这里插入图片描述
    同理,任意奇数分频都可以用类似的思路实现。因为3 5 7 9 11…总是可以分解成3=1+2,5=2+3,7=3+4,9=4+5…

实现和仿真

偶数分频的电路RTL代码

`timescale 1ns / 1psmodule divide_even
(rst_n,clk,div_clk,
);input rst_n;input clk;output reg div_clk;//位宽一般用系统函数来确定reg [5:0] cnt;parameter DIVIDE_NUM = 4;always@(posedge clk or negedge rst_n) beginif( ~rst_n ) begincnt <= 0;div_clk <= 0;end else if( cnt == DIVIDE_NUM / 2 - 1 ) begindiv_clk <= ~div_clk;cnt <= 0;end else begincnt <= cnt + 1;endend
endmodule

偶数分频的电路Testbench代码

`timescale 1ns / 1psmodule tb_divide_even();reg clk;reg rst_n;wire div_clk;initial beginclk = 0;rst_n = 0;#48;rst_n = 1;#203;        $stop;end    divide_even divide_even_u0(.clk(clk),.rst_n(rst_n),.div_clk(div_clk)    );always #5 clk = ~clk;
endmodule

偶数分频的电路仿真波形

在这里插入图片描述

占空比为50%的三分频电路RTL代码

`timescale 1ns / 1psmodule divide_3(clk,rst_n,div_clk
);input clk;input rst_n;output div_clk;reg out_clk1;reg out_clk2;reg [1:0] cnt1;reg [1:0] cnt2;//第一个always负责out_clk1的值always@(posedge clk or negedge rst_n) beginif(~rst_n) begincnt1     <= 2'b0;out_clk1 <= 0;endelse if(out_clk1 == 1) begin             cnt1 <= 2'b0;out_clk1 <= ~out_clk1;      end else if(out_clk1 == 0) beginif(cnt1 == 1) begincnt1 <= 2'b0;out_clk1 <= ~out_clk1;end else begincnt1 <= cnt1 + 1;endendend//第二个always负责out_clk2的值always@(negedge clk or negedge rst_n) beginif(~rst_n) begincnt2     <= 2'b0;out_clk2 <= 0;endelse if(out_clk2 == 1) begin cnt2 <= 2'b0;out_clk2 <= ~out_clk2;end else if(out_clk2 == 0) beginif(cnt2 == 1) begincnt2 <= 2'b0;out_clk2 <= ~out_clk2;end else begincnt2 <= cnt2 + 1;endendendassign div_clk = out_clk1 | out_clk2;endmodule

占空比为50%的三分频电路Testbench代码

`timescale 1ns / 1psmodule tb_divide_3();reg clk,rst_n;wire div_clk;initial beginrst_n = 0;clk = 0;#48;rst_n = 1;#202;$stop;enddivide_3 divide_3_u0(.clk(clk),.rst_n(rst_n),.div_clk(div_clk));//10ns一个周期,100MHzalways #5 clk = ~clk;endmodule

占空比为50%的三分频电路仿真波形

在这里插入图片描述

参考资料

  1. 正点原子逻辑设计指南
  2. B站 FPGA探索者 牛客Verilog刷题 奇数分频

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/645189.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

内容平台加码旅游:谁是下一个网红城市

“姐妹们&#xff0c;你们五一啥安排&#xff1f;”早在3月中旬&#xff0c;小威就在询问两个好朋友的行程&#xff0c;“不早早问&#xff0c;怕约不上你们。” 去年以来&#xff0c;国人的旅游需求快速复苏&#xff0c;像小威的朋友一样&#xff0c;之前爱玩的、不爱玩的似乎…

3月8日是星期六

突然有查询特殊条件日期的需求。 <html> <title>3月8日是星期六</title> <center> <h1 id"h1"></h1> <div id"div"></div> </center> <script> var weekday [星期日, 星期一, 星期二, 星期…

pyTorch框架部署实践

相关代码链接见文末 1.所需基本环境配置 首先&#xff0c;我们需要一个预先训练好的模型以及相应的配置。接下来&#xff0c;为了实际应用这个模型&#xff0c;我们必须搭建一个功能强大的服务器。这台服务器的核心任务是加载我们的模型&#xff0c;并能够接收用户上传的图片。…

线程池嵌套导致的死锁问题

1、背景 有一个报告功能&#xff0c;报告需要生成1个word&#xff0c;6个excel附件&#xff0c;总共7个文件&#xff0c;需要记录报告生成进度&#xff0c;进度字段jd初始化是0&#xff0c;每个文件生成成功进度加1&#xff0c;生成失败就把生成状态置为失败。 更新进度语句&…

基于深度学习网络的十二生肖图像分类matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 ............................................................... for i 1:16subplot(4,4,…

HubSpot功能有哪些?

HubSpot是一个功能丰富的平台&#xff0c;主要涵盖市场营销、销售、客户服务和客户关系管理&#xff08;CRM&#xff09;等领域。以下是HubSpot的一些主要功能&#xff1a; 市场营销自动化&#xff1a;HubSpot允许用户制定和执行多渠道的市场营销活动&#xff0c;包括创建和管…

为什么光电测径仪质量更稳定可靠?

光电测径仪与激光扫描式测径仪都是目前常用的外径自动化测量设备&#xff0c;他们能实现的功能相同&#xff0c;但为什么说光电测径仪更稳定可靠&#xff0c;下面一起来看一下。 光电测径仪测量原理 测头部件是测径仪的核心部件&#xff0c;它的作用是将被测物在CCD芯片上清晰…

redisson分布式锁的单机版应用

package com.redis;/*** author linn* date 2024年04月23日 15:31*/ import org.redisson.Redisson; import org.redisson.api.RedissonClient; import org.redisson.config.Config; import org.springframework.context.annotation.Bean; import org.springframework.context.…

怎样压缩jpg文件体积?分享一个极速压缩的方法

在工作中我们经常会遇到图片体积过大需要压缩处理。想要快速压缩jpg格式体积还不想下载软件要怎么操作呢&#xff1f;下面&#xff0c;给大家分享一款小白也能轻松使用的Jpg压缩&#xff08;https://www.yasuotu.com/&#xff09;工具-压缩图。支持上传单张100M以内&#xff0c…

常见大厂面试题(SQL)01

知乎问答最大连续回答问题天数大于等于3天的用户及其对应等级 1.描述 现有某乎问答创作者信息表author_tb如下(其中author_id表示创作者编号、author_level表示创作者级别&#xff0c;共1-6六个级别、sex表示创作者性别)&#xff1a; author_id author_level sex 101 …

命令行vue-cli-service不是内部或外部命令

没有安装vue/cli-service导致的 npm install -g vue/cli-service

背靠TON公链的Notcoin游戏项目,能否杀出GameFi的红海?

4月15日消息&#xff0c;Telegram生态中的游戏及Meme项目Notcoin&#xff0c;最近在X平台公布了令市场瞩目的代币经济学方案。据悉&#xff0c;NOT的总供应量高达1027亿枚&#xff0c;其中78%将分配给矿工和Voucher持有者&#xff0c;余下的22%预留给未来新用户、交易者及各类上…