当前位置: 首页 > news >正文

FPGA设计 时空变换

1、时空变换基本概念

        1.1、时空概念简介

                时钟速度决定完成任务需要的时间,规模的大小决定完成任务所需要的空间(资源),因此速度和规模就是FPGA中时间和空间的体现。

                如果要提高FPGA的时钟,每个clk内组合逻辑所能做的事通常就越简单,因此实现同样的逻辑会造成资源的膨胀。

                由于clk的提高,对资源的排列关系的要求就越紧凑,可是资源的膨胀会导致资源占用率的提高,增大布线的难度。

        1.2、时空变换

                1.2.1、时域优化

                        逻辑化简

                                逻辑化简是最基本的冗余去除利器,无论是针对组合逻辑还是时序逻辑,亦或是针对时域或者空域,逻辑化简会给所有方面带来好处。因为逻辑简化了,实现该功能的逻辑门和触发器就会减少,因此组合逻辑和时序逻辑中的冗余都被剔除。

                        空域方面的颠倒现象

                                有时候逻辑上的化简并不会为最终的资源占用带来好处,例如以下逻辑:

F = ABC + AB\overline{C} + A\overline{B}C +\overline{ A}BC ,化简得到F = AB + AC + BC

化简后的组合逻辑显然会消耗更少的逻辑门,但对于4输入1输出LUT的FPGA而言,对资源的占用没有任何影响。

                                有时候,逻辑上的化简甚至会带来更多的资源消耗。

                        时域方面的颠倒现象

                                有时候逻辑的化简并不会为最终的FPGA时序带来好处,例如

F = (AB + BC)AC 化简为F = ABC

化简对于FPGA时序指标没有任何影响。

                        

                        结构调整

                                结构调整是提高时序性能的另一种方式,它是在不改变原有组合逻辑功能单元的前提下,通过改变其内部逻辑门之间的连接关系,来达到减少逻辑门级数的目的,进而提高时序。

        现在有同步输入总线A B C D         :

        HDL code

                

always@( posedge sys_clk )
beginSUM    <=    A + B + C + D    ;
end

                这样子电路会有三个串联的adder,时序延时就是3T;

always@( posedge sys_clk )
beginSUM    <=    (A + B) + (C + D)    ;
end

                这样子 A + B 和 C + D 就会同时运算,时序延时为 2T。

                        分布调整

                                分布调整又叫时间调整(retiming),通过移动工作的时间来提高完成的延时。

                1.2.2、空域优化

                1.2.3、时间换空间

                1.2.4、空间换时间

                        模块复制

                                同频模块复制

                                降频模块复制

                        流水线

                

相关文章:

  • 前端学习笔记
  • 系统架构师2025年论文《论软件三层结构的设计》
  • Ubuntu24.04安装ROS2问题
  • 服务器上安装maven
  • 题解:P11185 奖牌排序
  • linux下内存地址数学运算
  • HTTP状态码有哪些常见的类型?
  • 搭建 Spark - Local 模式:开启数据处理之旅
  • 推荐一个简单又好用的在线视频编辑工具,在线免费使用,便捷高效!
  • ​​批发商商城小程序制作哪家强?开启高效批发新模式!
  • Python爬虫从入门到实战详细版教程Char01:爬虫基础与核心技术
  • 在 master 分支上进行了 commit 但还没有 push,怎么安全地切到新分支并保留这些更改
  • STL常用算法——C++
  • Unity 跳转资源商店,并打开特定应用
  • C# 事件知识文档
  • Vue2 el-checkbox 虚拟滚动解决多选框全选卡顿问题 - 高性能处理大数据量选项列表
  • 如何给文件增加拓展名
  • 1️⃣5️⃣three.js_GUI辅助调试器
  • Qt进阶开发:鼠标及键盘事件
  • AOSP Android14 Launcher3——RectFSpringAnim窗口动画类详解
  • 共绘“彩色上海”,IP SH艺术共创沙龙首期圆满举办
  • 央行4月开展12000亿元买断式逆回购操作
  • 制定出台民营经济促进法有何重大意义?全国人大常委会法工委回应
  • 排除燃气爆炸、人为放火可能,辽宁辽阳火灾事故起火原因正在调查
  • 中国人民解放军南部战区位南海海域进行例行巡航
  • 运动健康|不同能力跑者,跑步前后营养补给差别这么大?