verilog学习(11)实战之计数器

一:纹波计数器

1:纹波计数器的面积最小,易于结构化实现。这种计数器的触发器是前一级输出数据的边沿作为时钟来驱动。前一级的输出连在后一级的时钟端,每当时钟的输入端口的数据产生了上升沿,输出就会翻转。这个计数器必须从一个确定的状态开始工作,这要求我们要对它复位,否则,计数器的翻转则没有意义。3比特的纹波计数器如下图所示,输出位Q[0],Q[1],Q[2](图中未标出)

  

2:代码(4bit纹波计数器)

   

  vcs dump的波形

  

  可见,毛刺很大;这是因为纹波计数器中高阶触发器没有时钟,只有等到低阶触发器的输出变化后才能变化,所以当计数器的位宽增大时,这是个线性渐慢器件。在每个时钟上升沿之后,触发器的输出端会出现很多毛刺。然而,各阶的进位不会立刻由时钟传输下去,因此和同步计数器相比,功耗和噪声都减小了。

  改进:慢一拍输出,使用锁存器将输出锁存一拍,再输出

  

  vcs dump的波形

  

  可见,减少了毛刺,计数正常。

二:同步(超前进位)计数器

1:这类计数器增加了超前进位逻辑,在每个时钟有效沿对所有寄存器比特进行更新。

  同步计数器偶尔会产生极大的瞬时功率,而这种尖峰功率会生成噪声。

  如下图,每个寄存单元的输入端口都是由1比特加法器(异或门)驱动;做设计的时候也应该遵循这个原则,组合逻辑后应该跟上寄存器以保证电路的时序。

  时钟连在每个触发器的时钟端上,前面寄存器输出Q‘端进行或操作,然后用异或门进行隔离,直到进位溢出该比特。

  

2:代码(4bit同步计数器)

 

  vcs dump波形

三:行为级计数器

1:4bit行为级计数器代码

  

  vcs dump波形

  

四:使用pll时钟,将以上三个计数器放在一起,看计数快慢

  

原文地址:https://www.cnblogs.com/xh13dream/p/8994371.html

时间: 2024-10-12 04:31:06

verilog学习(11)实战之计数器的相关文章

【c语言学习-11】

/*指针*/ #include void charPointFunction(){ //字符型数组 char *x="I like code",y[10];//使x[]初始化,使y[]未初始化 //计数器 int i; x=x+2; //移动数组元素指针 printf("%s",x); //循环 /* for(i=0;*(x+i)!='\0';i++) *(y+i)=*(x+i); *(y+i)='\0'; printf("%s\n",x); f

ios网络学习------11 原生API文件上传之断点续传思路

#import "MainViewController.h" @interface MainViewController () @end @implementation MainViewController - (void)viewDidLoad { [super viewDidLoad]; //下载文件 [self download]; } -(void)download { //1. NSURL NSURL *url = [NSURL URLWithString:@"ht

NGUI 学习笔记实战——制作商城

Unity3D的uGUI听说最近4.6即将推出,但是目前NGUI等UI插件大行其道并且已经非常成熟,所以我们还是先看眼前吧. 一.实现思想 商城的功能是很多游戏都拥有的,按下一个界面按钮,弹出一个窗体. 然后是商城中的商品可以拖动,既可以用手,也可以用滑条等等,至于点击购买就不单单是UI层的事了.等到实现NDate的时候再进行讨论. 二.实现背景 1.NGUI->Open->Prefab tool bar ,拖一个black widget进去 2.之后布局如下,这些应该没什么难度,弄好锚点,d

ThinkPhp学习11

原文:ThinkPhp学习11 一.常用连贯操作 1.where  帮助我们设置查询条件 2.order   对结果进行排序  $arr=$m->order('id desc')->select();  $arr=$m->order(array('id'=>'desc','sex'=>'asc'))->select(); 3.limit   限制结果  limit(2,5)  limit('2,5')  limit(10)//limit(0,10) 4.field   

JavaScript学习11 数组排序实例

JavaScript学习11 数组排序实例 数组声明 关于数组对象的声明,以前说过:http://www.cnblogs.com/mengdd/p/3680649.html 数组声明的一种方式: var array = new Array(); array.push(1); array.push(2); array.push(3); alert(array.length) 数组声明的第二种方式,并排序: var array = [1, 3, 25]; array.sort(); //对数组排序,

深度学习Caffe实战笔记(19)Windows平台 Faster-RCNN 制作自己的数据集

"-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 深度学习Caffe实战笔记(19)Windows平台 Faster-RCNN 制作自己的数据集 - gybheroin的博客 - 博客频道 - CSDN.NET gybheroin的博客 目录视图 摘要视图 订阅 [活动]2017 CSDN博客专栏评选 &nbsp [

d3.js学习11

单元素动画transition().duration(duration) var body = d3.select("body"), duration = 5000; body.append("div") .classed("box",true) .style("background-color","#e9967a") .transition() .duration(duration) .style(&qu

python基础学习11(核心编程第二版)部分

# -*- coding: utf-8 -*- # ==================== #File: python #Author: python #Date: 2014 #==================== __author__ = 'Administrator' #执行环境 #可调用对象 """ 许多的python 对象都是我们所说的可调用的,即是任何能通过函数操作符“()”来调用的对象.要调用可调用对象, 函数操作符得紧跟在可调用对象之后.Python 有4

STM32单片机学习(11) DS18B20温度传感器实验

STM32单片机学习(11) DS18B20温度传感器实验 本程序主要实现 DS18B20温度传感器数据获取,并利用串口通信把温度数据传至计算机 注:使用普中科技开发板测试时,需要拔掉Boot1插口,因为用到的是PA15管脚, 由开发板电路图可知,需要改变PA15 管脚的映射,将其设置成普通IO口 参考资料 DS18B20中文手册.pdf   http://download.csdn.net/detail/leytton/7742193 STM32-外设篇 视频教程(Cortex-M3)-主讲人

爬虫学习 11.scrapy框架持久化存储

爬虫学习 11.scrapy框架持久化存储 基于终端指令的持久化存储 基于管道的持久化存储 今日详情 1.基于终端指令的持久化存储 保证爬虫文件的parse方法中有可迭代类型对象(通常为列表or字典)的返回,该返回值可以通过终端指令的形式写入指定格式的文件中进行持久化操作. 执行输出指定格式进行存储:将爬取到的数据写入不同格式的文件中进行存储 scrapy crawl 爬虫名称 -o xxx.json scrapy crawl 爬虫名称 -o xxx.xml scrapy crawl 爬虫名称