iEDA项目代码实践
iEDA工程代码实践—布局合法化(LG)
开源项目iEDA链接:https://gitee.com/oscc-project/iEDA.git
一、理论知识
布局合法化是全局布局以后的一个过程,在全局布局过后,规划版图中的宏单元会放置在相应的位置并保持不再移动,于此同时,对于标准单元的规划,也会通过一些相关算法完成大致位置的摆放,这些摆放是基于相关优化目标下进行的,例如线长,面积等,但是在全局布局中并不会考虑标准单元之间的非法情况,即标准单元重叠的问题,因此在布局合法化中,需要完成的任务就是在尽可能的不破坏全局布局的布局结构的情况下,使得所有标准单元不再重叠。核心算法用到的是Abacus算法和Tetris算法。
二、Abacus算法
同一时间只放置一个单元
算法伪代码

核心代码
1 | |
placeRow解析
这个函数是
AbacusLegalizer中的一个函数,它用于在布局合法化过程中放置一个实例(instance)到一个行(row)中。函数的输入参数包括一个LGInstance实例指针、行的索引row_idx和一个标志is_trial,用于指示是否是试验性放置。
该函数主要完成了以下工作:
- 在给定的行中找到合适的间隔来放置实例。
- 计算放置实例的移动代价,包括实例在
x和y方向上的移动代价以及超过最大移动约束的处罚。 - 进行非试验性放置时,更新簇的信息和间隔的剩余长度。
1 | |
三、Tetris算法
Abacus是在Tetris算法上的改进,在Tetris中,对于placeRow的选择是一个单次即可完成的过程,即在当前行中找到了能够合适的位置以后即将该instance放置到该行。因此整体算法流程相似,但复杂度会降低很多。
1 | |

因此对iEDA原始代码Abacus算法调整成Tetris只需要确定两个策略即可:1、如何选择当前instance初始行的策略。2、若初始行无法放置当前instance后,选择其它行的调整策略。
选择初始行策略
合法化是在全局布局过后的步骤,应尽可能的减少相关单元的移动,且尽可能地保证单元移动后和移动前地位置相近,因此最好是在该单元所在行的附近行进行移动
1、加上
_row_height后做除法
1 | |
2、直接使用y坐标与_row_height做整数相除
1 | |
- 换行策略
1 | |
四、结果
- 使用原始的
Abacus算法
- 初始行策略使用:加上
_row_height后做除法
- 初始行策略使用:直接使用
y坐标与_row_height做整数相除
- 使用手册上
Tetris的方法
- 对比
| Abacus | 1 | 2 | Tetris | |
|---|---|---|---|---|
| 全局布局HPWL | 8703921 | 8703921 | 8703921 | 8703921 |
| 合法化移动总Movement | 781382 | 1410142 | 865332 | 11052260(14.144) |
| 合法化运行时间 | 0.010062s | 0.000919s | 0.000944s | 0.086068s |
| 布局合法化HPWL | 10798293 | 10786671 | 10749832 | 21674741(2.007) |
| 详细布局HPWL | 10069766 | 10105715 | 10070071 | 13192372 |
| Average Congestion of Edges | 0.728164 | 0.718681 | 0.713207 | 0.713207 |
| Total Overflow | 10.000000 | 10.000000 | 10.000000 | 10.000000 |
| Maximal Overflow | 2.000000 | 2.000000 | 2.000000 | 2.000000 |
| Peak BinDensity | 1 | 1 | 1 | 1 |
| Total HPWL | 10069766 | 10105715 | 10070071 | 13192372 |
| Total STWL | 10862347 | 10863122 | 10864139 | 14100332 |
| Max STWL | 437405 | 442445 | 460685 | 518305 |
结果分析
将
Abacus换成Tetris后,在同样的全局布局的版图中Movement会增加因为在
Abacus中计算的是每一个单元在所有行中的最小cost,而Tetris中则是计算的是周围行内,会存在差异性,这样的差异性在较为密集的全局布局中体现更为明显。合法化运行时间会减少
很显然,
Abacus算法能够降低Movement就是以牺牲时间复杂度作为代价的,每一次instance的放置,平摊下来都会多出_row_nums-1轮次布局合法化
HPWL存在不确定性在实验中表现出来的是减少的特性,但实际上是表现出的不确定性,因为
Abacus算法中的cost仅仅是以当前能够移动的最少的x和y的总和作为基准,并没有将线长给加进去,所以对于线长来说使用Abacus算法仅仅是一个贪心策略,不一定能够达到全局最优的效果
个人感觉
Abacus算法还是有点暴力
PS:在重新复盘Tetris算法过后
最开始并没有完全理解要求完成的任务所描述的Tetris算法,仅仅是在Abacus的基础上置换了一个选择初始行和换行的策略,所以在最开始的代码当中调用的依然是原始的placeRow函数,在这个函数中的操作依然选择的是距离当前instance当中最近的internel,所以能够达到在时间减小的情况之下能够使得HPWL也减小的情况,这样的结果显然是存在偶然性的,因为找到的解都不一定都是最优解,与全局布局的结果有关。
当使用手册上描述的Tetris算法后,最终运行期间的Movement变为原来的14倍多,而HPWL也是原来的2倍左右。






