我们的设计需要多大容量的芯片?我们的设计能跑多快?这是经常困扰工程师的两个问题。对于前一个问题,我们可能还能先以一个比较大的芯片实现原型,待原型完成再选用大小合适的芯片实现。对于后者,我们需要一个比较精确的预估,我们的设计能跑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中系统运行频率计算方法与组合逻辑的层级相关推荐

  1. FPGA中系统运行频率计算方法

    我们的设计需要多大容量的芯片?我们的设计能跑多快?这是经常困扰工程师的两个问题.对于前一个问题,我们可能还能先以一个比较大的芯片实现原型,待原型完成再选用大小合适的芯片实现.对于后者,我们需要一个比较 ...

  2. Linux端日志加密,Linux学习--第十三天--日志、系统运行级别、grub加密

    日志 rsyslogd取代了syslogd. /var/log/cron #定时任务相关日志 /var/log/cups #打印信息相关日志 /var/log/dmesg #开机内核自检相关日志,dm ...

  3. 解决在vscode使用webpack指令显示“因为在此系统中禁止运行脚本“问题

    解决在vscode使用webpack指令显示"因为在此系统中禁止运行脚本"问题 参考文章: (1)解决在vscode使用webpack指令显示"因为在此系统中禁止运行脚本 ...

  4. 很多应用项目都有配置文件,这些配置文件里面定义一些应用需要的参数数据。 如果客户端使用这个类是通过new一个AppConfig的实例来得到一个操作配置 文件内容的对象,则在系统运行中,有 很多地方都需

      很多应用项目都有配置文件,这些配置文件里面定义一些应用需要的参数数据.   如果客户端使用这个类是通过new一个AppConfig的实例来得到一个操作配置文件内容的对象,则在系统运行中,有很多地方 ...

  5. coreos安装php,window_win10系统运行wps无响应的解决方案,wps是我们在日常办公中经常会 - phpStudy...

    win10系统运行wps无响应的解决方案 wps是我们在日常办公中经常会使用到的一款软件,其重要性不容小视.不过,很多用户在将wps升级到2016版后,发现在windows10系统下运行wps会出现无 ...

  6. 让系统在内存中高速运行

    现在我们电脑内存越来越大,2GB已经成为标配,配置4GB内存用户也有不少.利用剩余内存制作虚拟磁盘加快系统操作,相信大家已经看过不少类似的文章.可是你想过要把一个完整的系统放在内存里运行吗?这种系统叫 ...

  7. win10计算机丢失msvcr,win10系统运行程序提示计算机中丢失msvcr110.dll的教程

    有关win10系统运行程序提示计算机中丢失msvcr110.dll的操作方法想必大家有所耳闻.但是能够对win10系统运行程序提示计算机中丢失msvcr110.dll进行实际操作的人却不多.其实解决w ...

  8. 计算机安装msvcr110.dll,帮您还原win7系统运行程序提示计算机中丢失msvcr110.dll的解决方法...

    许多win7系统用户在工作中经常会遇到win7系统运行程序提示计算机中丢失msvcr110.dll的情况,比如近日有用户到本站反映说win7系统运行程序提示计算机中丢失msvcr110.dll的问题, ...

  9. 无法启动此程序因为计算机中丢失d3dx9_36.dll,xp系统运行真三国无双游戏提示d3dx9_36.dll丢失的解决方法...

    真三国无双是一款备受许多xp系统用户喜欢的游戏,然而在玩的过程中,有不少xp系统用户反映说遇到提示d3dx9_36.dll丢失的情况,导致无法继续玩真三国无双游戏,这是怎么回事呢,现在随系统城小编一起 ...

最新文章

  1. PHP数组实际占用内存大小的分析
  2. react七——react-redux
  3. Netty 实战:如何编写一个麻小俱全的 web 容器
  4. PS效果教程——冒充手绘效果
  5. java中String值为空字符串与null的判断方法
  6. 文章目录列表的字体颜色修改
  7. 第三次学JAVA再学不好就吃翔(part34)--多态的成员访问
  8. 我的处女作《设计模式之禅》——前言
  9. navigator.geolocation的应用 - 将定位信息显示在百度地图上
  10. 带你全面了解Http和Https
  11. github优秀前端项目分享(转)
  12. Beacon API
  13. 虚拟机从网卡路由问题
  14. Comparable 与 Comparator
  15. python自动下载图片_python简易爬虫来实现自动图片下载
  16. 微信小游戏实战--cocos creator实现wordle游戏(二)
  17. xxl-job 带参数执行和高可用部署
  18. 运用matlab求身高质量指数BMI值
  19. 雷电2接口_雷电3和TYPE-C都是干什么的?一文读懂全部
  20. Python-sklearn包中自动调参方法-网格搜索GridSearchCV

热门文章

  1. 疫情可以来,但比赛不能断
  2. 小型的ESP8266-01s WiFi串口模块是否可以下载MicroPython?
  3. STC8K28步进电机ULC2003触发器
  4. 使用STC8H1K28控制微型磁悬浮
  5. 有人工裁判,就会有争执
  6. Navicat中查询哪些表有指定的字段名(技巧)
  7. mysql大表修改表名原理_MySQL修改大表工具pt-online-schema-change原理
  8. 服务器项目带文件名,tomcat服务器上webapps里的文件名和项目名称不一样,修改方法...
  9. 计算机教师资格证报考科目,还在纠结报考教师资格证该选哪个科目呢?看完这篇,你不再迷茫...
  10. SCAPY pcap文件数据分析 python3