【【萌新的FPGA学习之分频器的介绍】】

2023-10-24 05:45

本文主要是介绍【【萌新的FPGA学习之分频器的介绍】】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

萌新的FPGA学习之分频器的介绍

分频器的介绍
分频就是生成一个新时钟,该新时钟的频率是原有时钟频率的整数分之一倍,新周期是原有周期的整数倍。再简单来说,让你手撕一个四分频电路,就是写代码生成一个周期是原来四倍的时钟,如果手撕一个三分频电路,就是写代码生成一个周期是原来三倍的时钟。但是奇数分频会比偶数分频复杂一些。
实现分频一般有两种方法,一种方法是直接使用 PLL 进行分频,比如在 FPGA 或者 ASIC 设计中,都
可以直接使用 PLL 进行分频。但是这种分频有时候受限于 PLL 本身的特性,比如输入 100Mhz 时钟,很多
PLL 都实现不了 1Mhz 的时钟分频,这个就是 PLL 本身特性限制的。另外一种方法是直接使用代码来实现
分频,本节就是带领大家使用 Verilog 代码进行分频器电路的设计。
根据分频器的分频比例(分频前的频率和分频后的频率比值)是偶数还是奇数,将分频器分为偶数分
频器和奇数分频器。接下来,我们先看下偶数分频设计。
偶数分频,顾名思义就是分频前的频率和分频后的频率比值是偶数,比如一个 50Mhz 的晶振时钟,进
行二分频后,就是 50Mhz/2=25Mhz。
下面我们先来看一下偶数分频实现原理,假设为 N(偶数)分频,只需计数到 N/2-1,然后时钟翻
转、计数器清零,如此循环就可以得到 N(偶)分频。举个例子,比如晶振时钟是 100Mhz 时钟,想得到
一个 25Mhz 的时钟,那么这个是一个 100/25=4 的四分频设计,按照我们刚说的计数到 4/2-1=1,然后时钟
翻转、计数器清零,就可以得到一个 25Mhz 的时钟。根据偶数分频的原理,可以绘制出偶数分频的波形
图:

在这里插入图片描述

下面我们再来看下奇数分频,奇数分频顾名思义就是分配前的频率和分频后的频率比值是奇数。比如一个 50Mhz 的晶振时钟,进行三分频后,就是 50Mhz/3=16.667Mhz。实现偶数分频可通过一个简单计数器实现,而如果需要进行三分频、五分频以及七分频等奇数分频而言,一个寄存器肯定时不够的,接下来我们再来看一下奇数分频的原理。同样假设我们需要分频的倍数为 N(奇数)分频,就需要定义一个个数为 N 的 cnt。当 cnt=0 时out_clk1 在 sys_clk 的上升沿拉低,当 cnt 计数到 N/2-1 时 out_clk1 在 sys_clk 的上升沿进行翻转;而out_clk2 则在 cnt=0 时的 sys_clk 下降沿进行拉低,当 cnt 计数到 N/2-1 时,out_clk2 在 sys_clk 下降沿进行翻转。最后将 out_clk1 和 out_clk2 的波形相与,就得到了我们分频后输出的 out_clk。这样我们只需要通过修改 N 的值和计数器的位宽就可以实现其他奇数分频,根据这一原理同样可以绘制出奇数分频器的波形图:
在这里插入图片描述

这个是5分频 除一下 每个各占原来的2.5
我们交错一下 取上升沿 下降沿 就能完成如此实验

偶数分频 相对于 奇数分频较为简单
下面先介绍 4分频

module divider_4(
input sys_clk ,input sys_rst_n ,output reg out_clk);reg [1:0] cnt;always@(posedge sys_clk or negedge sys_rst_n) beginif(!sys_rst_n)cnt <= 2'd0;else if(cnt == 2'd1)cnt <= 2'd0;elsecnt <= cnt + 2'd1;endalways@(posedge sys_clk or negedge sys_rst_n) begin if(!sys_rst_n)out_clk <= 1'b0;else if(cnt == 2'd1)out_clk <= ~out_clk;end

下面编写 tb文件

 `timescale 1ns / 1nsmodule tb_divider_4();reg sys_clk ;reg sys_rst_n ;wire out_clk ;initial beginsys_clk = 1'b1;sys_rst_n <= 1'b0;#201sys_rst_n <= 1'b1;endalways #10 sys_clk <= ~sys_clk;divider_4 divider_4_inst(.sys_clk (sys_clk ),.sys_rst_n (sys_rst_n ),.out_clk (out_clk )
);endmodule

我觉得计数应该技术到 (n-1)/2 -1
但是他们写的都是 N/2-1
算了照着写吧
我知道了 奇数除2会向下取整

下面介绍 七分频

module divider_7(
input sys_clk , //系统时钟input sys_rst_n , //系统复位output out_clk //输出时钟);parameter N = 7; //分频系数parameter EDGE = N/2-1; //取沿数reg [2:0] cnt ; //3 位计数器reg out_clk1; reg out_clk2; //计数器模块always@(posedge sys_clk or negedge sys_rst_n) beginif(!sys_rst_n)cnt <= 3'd0;else if(cnt == N - 1'b1)cnt <= 3'd0;elsecnt <= cnt + 'd1;end//out_clk1 在上升沿进行翻转always@(posedge sys_clk or negedge sys_rst_n) beginif(!sys_rst_n)out_clk1 <= 1'b0;else if(cnt <= EDGE)
out_clk1 <= 1'b0;elseout_clk1 <= 1'b1;end //out_clk2 在下降沿进行翻转always@(negedge sys_clk or negedge sys_rst_n) beginif(!sys_rst_n)out_clk2 <= 1'b0;else if(cnt <= EDGE)out_clk2 <= 1'b0;else
out_clk2 <= 1'b1;endassign out_clk = out_clk1 & out_clk2;endmodule

这篇关于【【萌新的FPGA学习之分频器的介绍】】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Java中HashMap的用法详细介绍

《Java中HashMap的用法详细介绍》JavaHashMap是一种高效的数据结构,用于存储键值对,它是基于哈希表实现的,提供快速的插入、删除和查找操作,:本文主要介绍Java中HashMap... 目录一.HashMap1.基本概念2.底层数据结构:3.HashCode和equals方法为什么重写Has

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

setsid 命令工作原理和使用案例介绍

《setsid命令工作原理和使用案例介绍》setsid命令在Linux中创建独立会话,使进程脱离终端运行,适用于守护进程和后台任务,通过重定向输出和确保权限,可有效管理长时间运行的进程,本文给大家介... 目录setsid 命令介绍和使用案例基本介绍基本语法主要特点命令参数使用案例1. 在后台运行命令2.

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

zookeeper端口说明及介绍

《zookeeper端口说明及介绍》:本文主要介绍zookeeper端口说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、zookeeper有三个端口(可以修改)aVNMqvZ二、3个端口的作用三、部署时注意总China编程结一、zookeeper有三个端口(可以

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h