找回密码
 注册
关于网站域名变更的通知
查看: 774451|回复: 101
打印 上一主题 下一主题

阿毛调侃(13)---【原创】史上最强悍Allegro差分线匹配工具与开发往事

  [复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2015-6-30 10:20 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
本帖最后由 amao 于 2015-6-30 11:52 编辑
$ J3 J4 l- R- i6 ~. N
& N9 m) D" a6 s, c3 h+ B- f( `
【原创】史上最强悍allegro差分线匹配工具与开发往事; `' s0 Z# V/ n5 E0 K. a- ]
毛忠宇 2015061 o4 C  M- B. k$ C

5 Z& v) t' X, q/ ^- X4 k, B
差分对提取工具开发往事

       上篇《我与pads的那点事》文章发表后,收到不少网友索取所写小工具的免费授权文件,程序能被大家接受,不免有“那么一点点”的成就感。

       在Allegro Constraint Manager菜单没有出现前,那时把网络设置成差分线需要手工逐对添加Property属性来实现。那时我还在H公司,用刚学点皮毛的PERL编程写了个差分线的自动提取工具,这个程序在部门得到推广及广泛使用(现在H公司还有不少人在使用)。

我写的程序使用了很久一段时间后,Allegro在后来的版本才出现类似的功能,它提出了Constraint Manage的概念,差分线等各种网络的规则通过类EXCEL界面管理,如下图1。这样使规则管理起来更直观及更简单,其它EDA厂商的软件后来也跟着出现了类似的管理界面。

* m6 {4 k# S* w; s
图1  A软件的Constraint Manager界面

EDA软件A*差分对自动匹配存在的问题

当年在H公司由于原理图与PCB LAYOUT软件平台的原因,所有网表都是第三方的模式调入。因此其员工是业界上对调第三网表都很熟悉的,我那时开发的程序还需要手工对网表文件手工处理一下,但他们用起来基本没遇到什么问题,就一直没有更新了。

上段有个现同事向我讲起她所用的Allegro自动生成差分对功能时,还有些不够完美的地方:一次只能生成一种类型的差分线:要生成下面网络组成的差分线,Allegro中要在匹配字符框中分别多次输入:N0,P0  N1,P1   N2,P2   N3,P3……

'B7ABC_CLK_N0'         'B7ABC_CLK_P0'

'B7ABC_CLK_N1'         'B7ABC_CLK_P1'

'B7ABC_CLK_N2'         'B7ABC_CLK_P2'

'B7ABC_CLK_N3'         'B7ABC_CLK_P3'

……

, G3 A/ e0 _; c# a) e" i6 l" Q
图2  A软件匹配输入界面

如这类网络不多手工处理起来问题不大,如下图中的从N0,P0到N43到P43只需要手工输入44次匹配方式。而程序又不能识别P* N*,万一要网络定义到N1000,P1000,哪怎么办呢?要手工输入1000次那就有点“扯蛋”了。

+ v) b: q5 Y9 H8 e8 ~5 K
图3  差分网络定义格式

*以上测试基于16.5版的平台,更高级的版本没有测试。

EDA软件M*差分对自动匹配存在的问题

业界另一个EDA巨头M公司,他的差分对匹配算法很强悍,但是强悍得过了头,识别后会多出很多不符合要求的差分对,这些需要手工再去删除,反而有点画蛇添足了。如下面它对网络的匹配效果,多出了太多不想要的差分线。下图4中所有粉红色都是被匹配出的错误差分对:如B8_TX_P22  B8_RX_P22 ,而真正的差分对是B8_TX_P22  B8_TX_N22

+ e! H' `% j8 d$ j& l
图4  M软件匹配出的多余组合

自开发差分线匹配工具的优点

基于目前两在EDA软件巨头差分对算法方面的问题,我优化算法,克服了他们现存的缺点,并实现输入窗口可以同时加入多个匹配字符,从而一次性提取出所有差分线,对抽取的结果可以在文本文件中或调入后在Constraint Manager界面上把多余的删除(删除的操作总比增加的操作用起来更令人愉快),从而一次性匹配几百乃至上千对差分线。


( w; y- \* W6 K4 i6 v图5  自开发的差分线自动匹配软件工具界面

下图6是用程序对网表处理后,不到1分钟就完成的179对差分线匹配图。

- X7 r/ x& V# R1 ?
图6  自开发软件匹配效果

特点

1) 克服两大EDA公司的差分线匹配算法问题

2)适用任何Allegro版本

3)可一次性全部匹配

. _3 k' i7 O4 [0 K8 K
*《IC封装基础与工程设计实例》书籍答疑QQ群号:433148683
* 如对相关内容感兴趣,请关注微信公共帐号:amao_eda365附
) k* K2 U: f# X
程序使用方法:
+ `& S' Q- b$ T6 K% a" M
0 U1 f; r; z$ F& m3 H- ]

该用户从未签到

来自 47#
 楼主| 发表于 2015-7-24 10:12 | 只看该作者
有同学问到下面的这类差分信号如何匹配7 l2 C8 [+ e7 _2 T* V
DP_PEXPERI_N<1>
" V+ \* K& a/ z4 I( s. C7 nDP_PEXPERI_P<1>
. E8 t( V! t0 o# NDP_PEXPERI_N<2>
8 }: t& G0 h5 A1 bDP_PEXPERI_P<2>0 f  k0 o5 J. }
DP_PEXPERI_N<3>7 s3 |3 p, |9 c9 T
DP_PEXPERI_P<3>
8 S" n+ J/ X  M* U.....
2 {" ?# ~  T6 s1 {; k" N7 B对于这类只要使用下面的匹配方式即可:
4 p! C. h" x* O, i& f1 B. H, jP<\d+>=N<\d+>  : ^: s% l1 k7 c# N2 K# r* ^
8 j/ {; L4 C+ B  E# @
1 P% b( y" G$ y
如果要匹配% `# f1 n2 r7 ?& m
DP_PEXPERI_Nabc1abc% e- R2 O! ~. m3 N2 ?6 |4 n6 I
DP_PEXPERI_Pabc1abc/ H" k/ n) h' @2 J  B9 h
DP_PEXPERI_Nabc2abc
3 `1 T) g, V  e; A( DDP_PEXPERI_Pabc2abc9 U5 _: }* f) p) |/ v
你应该会怎样输入了吧
" Q' c2 e6 P0 f/ {$ q4 X& Y5 x. @0 L
欢迎挑战其它匹配模式
/ q* ?- a$ }* p. E
# j# \' u8 h4 O" ~5 f
5 g1 X0 b0 n6 _2 L+ M2 T# s2 x+ R3 u3 F8 {2 r

* F# V: l& T% c

该用户从未签到

推荐
 楼主| 发表于 2015-6-30 10:23 | 只看该作者
软件与使用说明书

allegro_dif_net_V1.rar

4.04 MB, 下载次数: 654, 下载积分: 威望 -5

点评

感谢感谢感谢感谢感谢感谢  详情 回复 发表于 2024-12-3 10:04
如何下载  详情 回复 发表于 2020-3-24 16:19

评分

参与人数 1威望 +2 收起 理由
wanily + 2 很给力!

查看全部评分

该用户从未签到

推荐
发表于 2015-8-12 12:00 | 只看该作者
bingshuihuo 发表于 2015-8-12 10:51
/ ?' W  @7 L- J3 @0 T感谢毛老师无私奉献  
. \! n9 M  Q4 r为PCB 操作提高了效率花费的心血

  K& g3 m# @4 V& v0 y& ?昨天发了邮件  1 Z  T7 _7 m, _8 W/ y" ]
收到后 使用了一下0 p  C3 L8 G( S
真的感觉很顺 ; V" [, x% b, Z: V6 ~9 R) [
* ]5 S+ P+ ^, P* h) L
最少效率提高了很多
# r- ~; Q6 F! H/ c6 ]  g9 ^; C
6 n& w. p& T% f* ^很多做SKILL的  9 f; a+ u( ^9 k4 ~4 |
在这块没有花时间去考虑
9 @/ O. N: y# @3 A+ C- k  R
0 T. h! @! }3 `; X& {4 r& _1 p1 S思维  是排出万难的发动机
* f9 i" N) x" y) h$ o4 [能力  是脱颖而出的基石/ E- Z1 U+ x" ~; S( f& H
共享  是虚怀若谷的体现
" s8 E$ U3 |0 p贡献  是推动行业发展的情怀' j: |& U$ a- W7 T! Y
2 f5 h* `! t& @! K5 Q) `9 Q* r
四美具  人生必有腾飞 * j- n8 ^/ ~4 t, m+ d

: H' }# U% l( @% c9 u; |+ k. H. a: n5 k
5 r; F9 X7 o0 H% D$ U0 j  n

( D3 x4 U/ X$ j# Z8 L2 a
  P' @: P& S, n) ^6 E

该用户从未签到

3#
发表于 2015-6-30 10:42 | 只看该作者
谢谢分享  楼主好人 大牛
  • TA的每日心情
    开心
    2023-12-4 15:58
  • 签到天数: 1 天

    [LV.1]初来乍到

    4#
    发表于 2015-6-30 10:56 | 只看该作者
    绝对好东西,32个赞!!!

    该用户从未签到

    5#
    发表于 2015-6-30 11:10 | 只看该作者
    我来顶顶顶顶顶

    该用户从未签到

    7#
    发表于 2015-6-30 11:49 来自手机 | 只看该作者
    牛xxx啊,果断下载!

    该用户从未签到

    8#
    发表于 2015-6-30 12:51 | 只看该作者
    阿毛版主太厉害了,佩服大神开发了这些实用工具

    该用户从未签到

    9#
    发表于 2015-6-30 14:21 | 只看该作者
    前人种树,后人乘凉

    该用户从未签到

    10#
    发表于 2015-6-30 15:23 | 只看该作者
    谢谢分享  楼主好人 大牛

    该用户从未签到

    11#
    发表于 2015-6-30 15:34 | 只看该作者
    很好很强大啊!
  • TA的每日心情
    开心
    2021-8-17 15:44
  • 签到天数: 1 天

    [LV.1]初来乍到

    13#
    发表于 2015-6-30 16:57 | 只看该作者
    必须给力赞啊,楼主好强大
  • TA的每日心情

    2019-11-20 15:11
  • 签到天数: 1 天

    [LV.1]初来乍到

    14#
    发表于 2015-6-30 17:31 | 只看该作者
    毛哥的干货真多,速速收藏

    该用户从未签到

    15#
    发表于 2015-6-30 18:55 | 只看该作者
    感谢大神无私奉献。
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-11-6 10:55 , Processed in 0.218750 second(s), 34 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表