我们的设计需要多大容量的芯片?我们的设计能跑多快?这是经常困扰工程师的两个问题。对于前一个问题,我们可能还能先以一个比较大的芯片实现原型,待原型完成再选用大小合适的芯片实现。对于后者,我们需要一个比较精确的预估,我们的设计能跑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. 多维矩阵/数组变成一维数组
  2. centos7下安装gcc7
  3. 安装nvm-nvm: command not found
  4. Oracle的FIXED_DATE参数
  5. java jsonobject.parse_JSON.parseObject的几种用法
  6. CSS3特效 - 会呼吸的button按钮
  7. 无法推动项目起步?试试麦当劳理论
  8. 【maven】No plugin found for prefix ‘install‘ in the current project
  9. 高通三频802.11ac平台:家庭WiFi新体验?
  10. 超级全面的MySQL优化面试解析
  11. 基于主成分分析的贵州省综合经济实力
  12. 怎样访问ftp服务器的文件,访问ftp服务器文件夹
  13. SQL学习笔记(01)_LIKE、IN、通配符
  14. MATLAB中minDiff,findpeaks,diff, intersect等函数详解
  15. 淘宝购物如何找优惠券_淘宝上买衣服怎么省钱
  16. CFD网格你应该了解的常识
  17. Chai.js断言库expect常用API
  18. 【scau算法分析设计】11075强盗分赃|17963 完美数(c)
  19. CheckListBox的一些用法!
  20. chinaren校友录xss漏洞

热门文章

  1. 第十六届全国大学生智能汽车竞赛--百度智慧交通(东部赛区)
  2. 2020年春季学期信号与系统课程作业参考答案-第十三次作业
  3. 信号转换 | 将对称方波转换成倍频PWM波形
  4. 小型直流电机内部结构
  5. java 多级级联菜单回显_详解element-ui级联菜单(城市三级联动菜单)和回显问题...
  6. char* 长度_leetcode之最后一个单词的长度
  7. android 是否允许打印debug级别日志的开关_Android学习——日志使用
  8. 新海诚没有参与制作的作品_下列哪部作品新海诚没有参与制作
  9. kafka不使用自带zk_kafka 安装部署教程
  10. eclipse中tomcat启动不了_Spring Boot中Tomcat是怎么启动的