FPGA中系统运行频率计算方法
我们的设计需要多大容量的芯片?我们的设计能跑多快?这是经常困扰工程师的两个问题。对于前一个问题,我们可能还能先以一个比较大的芯片实现原型,待原型完成再选用大小合适的芯片实现。对于后者,我们需要一个比较精确的预估,我们的设计能跑50M,100M 还是133M?
首先让我们先来看看Fmax 是如何计算出来的。图(1)是一个通用的模型用来计算FPGA的。我们可以看出,Fmax 受Tsu , Tco , Tlogic 和 Troute 四个参数影响。( 由于使用FPGA 全局时钟,时钟的抖动在这里不考虑)。
时钟周期 T = Tco + Tlogic + Troute + Tsu
时钟频率 Fmax = 1/Tmax
其中:
Tco : D 触发器的输出延时
Tlogic : 组合逻辑延时
Troute : 布线延时
Tsu : D 触发器的建立时间
图( 1 ) 时钟周期的计算模型
由图(1)可以看出,在影响Fmax 的四个参数中,由于针对某一个器件Tsu 和Tco 是固定的,因此我们在设计中需要考虑的参数只有两个Tlogic 和Troute.通过良好的设计以及一些如Pipeline 的技巧,我们可以把Tlogic 和Troute 控制在一定的范围内。达到我们所要求的Fmax.
经验表明一个良好的设计,通常可以将组合逻辑的层次控制在4 层以内,即( Lut Levels 《=4 ) 。而Lut Levels( 组合逻辑的层次 )将直接影响Tlogic 和Troute 的大小。 组合逻辑的层次多,则Tlogic 和Troute 的延时就大,反之, 组合逻辑的层次少,则Tlogic 和Troute 的延时就小。
让我们回过头来看看Xilinx 和Altera 的FPGA 是如何构成的。是由Logic Cell ( Xilinx )或 Logic Element( Altera )这一种基本结构和连接各个Logic Cell 或Logic Element 的连线资源构成。无论是Logic Cell 还是 Logic Element ,排除其各自的特点,取其共性为一个4 输入的查找表和一个D 触发器。如图(2)所示。而任何复杂的逻辑都是由此基本单元复合而成。图(3)。上一个D 触发器的输出到下一个D 触发器的输入所经过的LUT 的个数就是组合逻辑的层次( Lut Levels )。因此,电路中用于实现组合逻辑的延时就是所有Tlut 的总和。在这里取Lut Levels = 4 。故Tlogic = 4 * Tlut 。
图( 2 ) FPGA基本逻辑单元
图( 3 ) 复杂组合逻辑的实现
解决的 Tlogic 以后,我们来看看Troute 如何来计算。由于Xilinx 和Altera 在走线资源的设计上并不一样,并且Xilinx 没有给出布线延时的模型,因此更难于分析,不过好在业内对布线延时与逻辑延时的统计分析表明, 逻辑延时与布线延时的比值约为1:1 到1:2.由于我们所选用的芯片大量的已经进入0.18um 和0.13um 深亚微米的工艺,因此我们取逻辑延时与布线延时的比值为1:2.
Troute = 2 * Tlogic
Tmax = Tco + Tlogic + Troute + Tsu
= Tco + Tsu + 3 * Tlogic
= Tco + Tsu + 12 * Tlut
下表是我们常用的一些 Xilinx 和Altera 器件的性能估算。我们选取的是各个系列中的最低的速度等级。由于Altera 的APEX ,APEX II 系列器件的不同规模的参数不同,我们选取EP20K400E 和 EP2A15 作代表。
Tsu ( ns ) | Tco ( ns ) | Tlut ( ns ) | Fmax | |
Spartent II-5 | 0.7 | 1.3 | 0.7 | 96 M |
Virtex E-6 | 0.63 | 1.0 | 0.47 | 137M |
Virtex II-4 | 0.37 | 0.57 | 0.44 | 160M |
Virtex II Pro -5 | 0.29 | 0.40 | 0.37 | 193M |
APEX E-3 # | 0.23 | 0.32 | 1.01 | 79M |
APEX II-9## | 0.33 | 0.23 | 0.7 | 112M |
Stratix -7 | 0.011 | 0.202 | 0.527 |
153M |
# 以EP20K400E-3 的数据计算得出。
## 以 EP2A15-9 的数据计算得出。
FPGA中系统运行频率计算方法相关推荐
- FPGA中系统运行频率计算方法与组合逻辑的层级
我们的设计需要多大容量的芯片?我们的设计能跑多快?这是经常困扰工程师的两个问题.对于前一个问题,我们可能还能先以一个比较大的芯片实现原型,待原型完成再选用大小合适的芯片实现.对于后者,我们需要一个比较 ...
- Linux端日志加密,Linux学习--第十三天--日志、系统运行级别、grub加密
日志 rsyslogd取代了syslogd. /var/log/cron #定时任务相关日志 /var/log/cups #打印信息相关日志 /var/log/dmesg #开机内核自检相关日志,dm ...
- 解决在vscode使用webpack指令显示“因为在此系统中禁止运行脚本“问题
解决在vscode使用webpack指令显示"因为在此系统中禁止运行脚本"问题 参考文章: (1)解决在vscode使用webpack指令显示"因为在此系统中禁止运行脚本 ...
- 很多应用项目都有配置文件,这些配置文件里面定义一些应用需要的参数数据。 如果客户端使用这个类是通过new一个AppConfig的实例来得到一个操作配置 文件内容的对象,则在系统运行中,有 很多地方都需
很多应用项目都有配置文件,这些配置文件里面定义一些应用需要的参数数据. 如果客户端使用这个类是通过new一个AppConfig的实例来得到一个操作配置文件内容的对象,则在系统运行中,有很多地方 ...
- coreos安装php,window_win10系统运行wps无响应的解决方案,wps是我们在日常办公中经常会 - phpStudy...
win10系统运行wps无响应的解决方案 wps是我们在日常办公中经常会使用到的一款软件,其重要性不容小视.不过,很多用户在将wps升级到2016版后,发现在windows10系统下运行wps会出现无 ...
- 让系统在内存中高速运行
现在我们电脑内存越来越大,2GB已经成为标配,配置4GB内存用户也有不少.利用剩余内存制作虚拟磁盘加快系统操作,相信大家已经看过不少类似的文章.可是你想过要把一个完整的系统放在内存里运行吗?这种系统叫 ...
- win10计算机丢失msvcr,win10系统运行程序提示计算机中丢失msvcr110.dll的教程
有关win10系统运行程序提示计算机中丢失msvcr110.dll的操作方法想必大家有所耳闻.但是能够对win10系统运行程序提示计算机中丢失msvcr110.dll进行实际操作的人却不多.其实解决w ...
- 计算机安装msvcr110.dll,帮您还原win7系统运行程序提示计算机中丢失msvcr110.dll的解决方法...
许多win7系统用户在工作中经常会遇到win7系统运行程序提示计算机中丢失msvcr110.dll的情况,比如近日有用户到本站反映说win7系统运行程序提示计算机中丢失msvcr110.dll的问题, ...
- 无法启动此程序因为计算机中丢失d3dx9_36.dll,xp系统运行真三国无双游戏提示d3dx9_36.dll丢失的解决方法...
真三国无双是一款备受许多xp系统用户喜欢的游戏,然而在玩的过程中,有不少xp系统用户反映说遇到提示d3dx9_36.dll丢失的情况,导致无法继续玩真三国无双游戏,这是怎么回事呢,现在随系统城小编一起 ...
最新文章
- 多维矩阵/数组变成一维数组
- centos7下安装gcc7
- 安装nvm-nvm: command not found
- Oracle的FIXED_DATE参数
- java jsonobject.parse_JSON.parseObject的几种用法
- CSS3特效 - 会呼吸的button按钮
- 无法推动项目起步?试试麦当劳理论
- 【maven】No plugin found for prefix ‘install‘ in the current project
- 高通三频802.11ac平台:家庭WiFi新体验?
- 超级全面的MySQL优化面试解析
- 基于主成分分析的贵州省综合经济实力
- 怎样访问ftp服务器的文件,访问ftp服务器文件夹
- SQL学习笔记(01)_LIKE、IN、通配符
- MATLAB中minDiff,findpeaks,diff, intersect等函数详解
- 淘宝购物如何找优惠券_淘宝上买衣服怎么省钱
- CFD网格你应该了解的常识
- Chai.js断言库expect常用API
- 【scau算法分析设计】11075强盗分赃|17963 完美数(c)
- CheckListBox的一些用法!
- chinaren校友录xss漏洞
热门文章
- 第十六届全国大学生智能汽车竞赛--百度智慧交通(东部赛区)
- 2020年春季学期信号与系统课程作业参考答案-第十三次作业
- 信号转换 | 将对称方波转换成倍频PWM波形
- 小型直流电机内部结构
- java 多级级联菜单回显_详解element-ui级联菜单(城市三级联动菜单)和回显问题...
- char* 长度_leetcode之最后一个单词的长度
- android 是否允许打印debug级别日志的开关_Android学习——日志使用
- 新海诚没有参与制作的作品_下列哪部作品新海诚没有参与制作
- kafka不使用自带zk_kafka 安装部署教程
- eclipse中tomcat启动不了_Spring Boot中Tomcat是怎么启动的