Physic Design:Floorplan算法概览
仅用于学习交流,转载请联系本人。
1 floorplan是什么
floorplan常被翻译成布图规划,是指在芯片级别上对模块进行布局,也就是哪个单元放在什么地方,但是单元内部的具体布局并不关心。该步骤为芯片版图设计中的关键步骤之一,因为在这一步会影响芯片的面积、能否成功布线以及布线线长等诸多关键指标和步骤。

图1. 布图规划就是确定这些Block的形状和相对位置,但是对Block内部不关注,一个Block可能是一个加法器或者其它什么。至于图中所示的三种类型(临接,通道、临界+通道),目前是不重要的。图片引用自 http://www.signoffsemi.com/floorplan-placement-2/
2 目标是什么
floorplan的首要目标就是给模块指定一个最佳的形状(如果需要指定的话),给出模块间的最佳的相对位置关系。这里需要先区分一个概念,module和block(这里对应的中文我记成模块和砖块)。一个加法器的原理图是一个模块,也就是我们知道一个加法器是由一个半加器和进位电路组成的,但是在版图中这个加法器长宽分别是多少,我们是不知道的。当其长宽确定下来之后,就称成为一个砖块(Block),就相当于砖,和建房子的砖没啥区别,就是说可以用这个砖块来构建版图啦,所以翻译成砖块。在设计好芯片的逻辑关系后,更具输入的是砖块还是模块可能面临三种状况:
(1)输入的对象都是砖块(block)。也就是说,构建版图时,使用的基本构图单元(加法器)已经被规定好了,只能使用,不能改变形状和大小。但是这些砖块间的位置是floorplan需要去确定的。
(2)输入的对象是模块(module)。也就是说,构建版图时,使用的基本构图单元(加法器)没有被规定死,可以指定其长宽比例(面积基本上变不了,因为加法器里的东西需要地方放)。这种情况下,floorplan需要为这些模块指定长宽比例使得模块变成砖块,然后还要指出这些砖块之间的相对位置。
(3)当然是混合型,输入既有砖块又有模块。略。
但是这里有一个问题就是什么样算是最佳?或者换一种说法,显然floorplan是一个优化问题,那么优化的目标是什么呢?一般来说有一下几点:
(1)使芯片面积最小;
(2)使得模块之间的连线最短,这也就意味着延迟小;
(3)模块之间拥塞尽可能小,也就是说,模块之间有足够的空间让互连线通过;
优化目标可能是其中一个也可能是其中的很多,如果要同时满足多个优化目标的话,可以为这些目标分配权重,形成一个综合的优化目标函数。(但笔者认为,这实在是一种有些天真但在一定程度上可接受的做法,相当于超参数)
f=a*area+b*wirelength+c*congestion (a+b+c=1)
3 常见的算法有哪些
在这里,再重述一遍floorplan的主要目标,(1)指定模块的形状,(2)给出模块间的相对位置。目前几乎所有的数字芯片设计都会使用物理设计EDA工具,其中自然就包含floorplan工具,既然是自动化工具,就比然有相应的算法。总体上来说,floorplan可以分为三类(Susmita Sur-Koay):
(1)构造型算法。这一类算法旨在指出砖块之间的相对位置。这一类算法有slicing embedding,hierarchical enumeration和dual graph等。
(2)迭代型算法。这一类算法旨在将模块变成砖块,也就是为模块确定长宽比。这一类算法有模拟退火,遗传算法,力导向等。
(3)基于特定知识的算法。这一类算法企图同时完成这两件事情。
参考文献
Susmita Sur-Koay. Handbook of Algorithms for Physical Design Automation. p140.
Physic Design:Floorplan算法概览的更多相关文章
- [0x00 用Python讲解数据结构与算法] 概览
自从工作后就没什么时间更新博客了,最近抽空学了点Python,觉得Python真的是很强大呀.想来在大学中没有学好数据结构和算法,自己的意志力一直不够坚定,这次想好好看一本书,认真把基本的数据结构和算 ...
- C/C++基础---算法概览
符号概念 beg和end表示元素范围的迭代器 beg2表示第二个序列开始位置迭代器,end2表示第二个序列末尾迭代器(如果有).如没有则假定系列2至少与beg end表示的范围一样大.beg和beg2 ...
- Android Design Support Library概览
尊重劳动成果.转载请注明出处:http://blog.csdn.net/growth58/article/details/47972467 关注新浪微博:@于卫国 邮箱:yuweiguocn@gmai ...
- 从 SGD 到 Adam —— 深度学习优化算法概览(一) 重点
https://zhuanlan.zhihu.com/p/32626442 骆梁宸 paper插画师:poster设计师:oral slides制作人 445 人赞同了该文章 楔子 前些日在写计算数学 ...
- learn from collection framework design
最难忍受的痛苦,也许是想干一件事情而又不去干.--罗曼·罗兰 前言 本篇文章算是拾人牙慧吧,偶尔谷歌到一个能很好把collection framework design讲好的文档,一是为了总结提升,也 ...
- js排序算法汇总
JS家的排序算法 十大经典算法排序总结对比 一张图概括: 主流排序算法概览 名词解释: n: 数据规模k:“桶”的个数In-place: 占用常数内存,不占用额外内存Out-place: 占用额外 ...
- Backpropagation 算法的推导与直观图解
摘要 本文是对 Andrew Ng 在 Coursera 上的机器学习课程中 Backpropagation Algorithm 一小节的延伸.文章分三个部分:第一部分给出一个简单的神经网络模型和 B ...
- 一文搞懂Raft算法
raft是工程上使用较为广泛的强一致性.去中心化.高可用的分布式协议.在这里强调了是在工程上,因为在学术理论界,最耀眼的还是大名鼎鼎的Paxos.但Paxos是:少数真正理解的人觉得简单,尚未理解 ...
- js十大排序算法收藏
十大经典算法排序总结对比 转载自五分钟学算法&https://www.cnblogs.com/AlbertP/p/10847627.html 一张图概括: 主流排序算法概览 名词解释: n: ...
随机推荐
- OpenWrt R2020.03.05 去广告 抗污染 加速 UnPnP NAS
固件版本已经更新,新版本链接:https://www.cnblogs.com/zlAurora/p/12500932.html 容我啰嗦一下,为什么会有这个固件. 从KoolShare LED ...
- RabbitMQ的使用(二)- RabbitMQ服务在单机中做集群
RabbitMQ的使用(二)- RabbitMQ服务在单机中做集群 作者:markjiang7m2 原文地址:https://www.cnblogs.com/markjiang7m2/p/128371 ...
- 设计模式之GOF23组合模式
组合模式Composite 使用组合模式的场景:把部分和整体的关系用树形结构表示,从而使客户端可以使用统一的方式处理对象和整体对象(文件和文件夹) 组合模式核心: -抽象构件(Component)角色 ...
- burpsuite抓包无法识别POST参数问题
直接拿一道bugkuctf中的题目进行测试 这道题目就是用POST方法上传what=flag 我们利用burpsuite进制抓包 需要更改三个部分,这样就可以解决burpsuite无法识别POST参数 ...
- 黑马程序员_毕向东_Java基础视频教程——变量(随笔)
变量 变量 就是将不确定的数据进行存储.也就是需要在内存中开辟一块空间. 内存就是一块运算区域.内存越大.内存中装的数位就越多.运算就越快 ============================== ...
- 终于,帮开发写了一个bug
写在文章的开头 最近项目比较紧,尤其前端的的需求比较多,作为一名测试,也会些vue,本着加快项目进度的美好想法,就自告奋勇的向组长承接了一部分开发的任务,其中有个需求需要在我们的广告管理后台新增一个上 ...
- javaScript ES7 ES8 ES9 ES10新特性
参考文献: https://tuobaye.com/2018/11/27/%E7%BB%86%E8%A7%A3JavaScript-ES7-ES8-ES9-%E6%96%B0%E7%89%B9%E6% ...
- Java集合类: Set、List、Map
Set.List.Map都是集合接口 set --其中的值不允许重复,无序的数据结构 list --其中的值允许重复,因为其为有序的数据结构 map--成对的数据结构,健值必须具有唯一 ...
- DRF认证组件
1.DRF认证组件之视图注册用法(自定义简单使用) settings.py配置 INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.a ...
- django之CORS跨域请求
对于想要利用django框架实现前后端分离,首要的问题是解决跨域请求的问题,什么是跨域请求?简单来说就是当前发起的请求的域与该请求指向的资源所在的域不一致.当协议+域名+端口号均相同,那么就是同一个域 ...