找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

巢课
电巢直播8月计划
查看: 7795|回复: 77
打印 上一主题 下一主题

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

  [复制链接]

139

主题

460

帖子

4605

积分

EDA365特邀版主

Rank: 6Rank: 6

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

EDA365欢迎您!

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

x
本帖最后由 amao 于 2015-6-30 11:52 编辑
# V" ?' c9 o  _$ k
" a/ u7 C. p6 L+ X
【原创】史上最强悍Allegro差分线匹配工具与开发往事
: ~& J( f7 o' z% s毛忠宇 201506  }+ `# ?6 R9 D

) w- ^& x1 R3 |6 P2 E
差分对提取工具开发往事

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

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

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

: T1 Q: Z9 P3 v# Y7 `( m
图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'

……


; F  a. ^: j* R! L$ b- y图2  A软件匹配输入界面

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

5 j4 w5 _) L* n
图3  差分网络定义格式

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

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

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


# B( c' L' ^/ ^, T1 u+ m" u图4  M软件匹配出的多余组合

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

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


! A5 `7 H7 b1 U* j; r图5  自开发的差分线自动匹配软件工具界面

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


1 l+ S& ?; Q1 I) K7 l+ B0 L图6  自开发软件匹配效果

特点

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

2)适用任何Allegro版本

3)可一次性全部匹配

& C9 R1 v8 D0 y2 a  s
*《IC封装基础与工程设计实例》书籍答疑QQ群号:433148683
* 如对相关内容感兴趣,请关注微信公共帐号:amao_eda365附

0 r. t9 p0 M! ~# r% [程序使用方法:" F0 s* r; q# n2 }2 Z

& I: d. \% l+ r
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏8 支持!支持!1 反对!反对!

139

主题

460

帖子

4605

积分

EDA365特邀版主

Rank: 6Rank: 6

积分
4605
来自 47#
 楼主| 发表于 2015-7-24 10:12 | 只看该作者
有同学问到下面的这类差分信号如何匹配2 O: n5 @- @1 S' [- B4 w  q6 k' Y5 `
DP_PEXPERI_N<1>
3 O, c4 O( N* n! a0 ]DP_PEXPERI_P<1>
! i$ |- [5 @9 O7 ]* i6 uDP_PEXPERI_N<2>
$ G8 j) v' z. k" l; L4 y' t, VDP_PEXPERI_P<2>5 K/ J2 B2 T$ _! c
DP_PEXPERI_N<3># |& H4 q+ `) |. c8 n2 A
DP_PEXPERI_P<3>
/ H  x" s# w, f, j3 I5 j$ c.....3 F, Y- b0 ~4 X
对于这类只要使用下面的匹配方式即可:
4 B" Q. U9 `, A# Q2 v6 h. cP<\d+>=N<\d+>  
/ f; r7 r4 ^$ p8 V ' j, K, g# _5 u9 }1 p5 B$ m
% ^: d# d0 K) E+ S' J" g/ j5 s
如果要匹配7 \" S* \0 w9 S% l9 X% i
DP_PEXPERI_Nabc1abc
( y* I% H/ A' u  }5 L# aDP_PEXPERI_Pabc1abc- i( J2 Q- W( r3 g5 G! I
DP_PEXPERI_Nabc2abc
3 ]" d, |' Y1 t1 V; Z  W1 ODP_PEXPERI_Pabc2abc( i0 ?' y1 J7 a5 _" A7 m& b
你应该会怎样输入了吧- l; ]: l; G3 Z5 u. L7 C; @
0 P* c$ G$ h1 Y- [( ]: h
欢迎挑战其它匹配模式
% J( h1 H3 c) M& k5 c* a+ ~& `% l/ ^0 i1 c/ D5 Y

" }1 N: ^7 L/ d: Y$ u( D/ V* o! l0 n7 n7 N

7 ^& {, A1 B3 m0 w) w" L

139

主题

460

帖子

4605

积分

EDA365特邀版主

Rank: 6Rank: 6

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

allegro_dif_net_V1.rar

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

评分

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

查看全部评分

29

主题

2646

帖子

2805

积分

四级会员(40)

Rank: 4Rank: 4Rank: 4Rank: 4

积分
2805
推荐
发表于 2015-8-12 12:00 | 只看该作者
bingshuihuo 发表于 2015-8-12 10:516 w5 {/ J0 Q: ?% U' ^
感谢毛老师无私奉献    O% C5 ]8 y) ^& u3 Z
为PCB 操作提高了效率花费的心血
; }! {, V0 {! B4 G5 V  L
昨天发了邮件  
% Z6 A. b% z0 I- b收到后 使用了一下. Y4 `" g/ _3 }' @! t4 ^# N! N& q/ L
真的感觉很顺 - _3 T& \) y' i6 r

* v" W, q8 Y( i# [- J最少效率提高了很多
4 ~, `, }1 O% ~6 a" o. R/ e  _  U8 F! a& t
很多做SKILL的  
' p8 u1 V1 ^9 A) G在这块没有花时间去考虑 " B( T2 i' E, r% L4 x
4 D+ _0 m3 S2 _: ]! [+ k
思维  是排出万难的发动机
2 J$ b  c5 j. }% J3 h能力  是脱颖而出的基石3 j/ a, U0 |7 Z3 L2 F! h& D
共享  是虚怀若谷的体现
1 N6 D  D% [) d贡献  是推动行业发展的情怀6 T0 W! G) U7 C  K: P, H! N0 l

. b) u- h3 V+ S5 ^4 l四美具  人生必有腾飞 ' B( m% j, i' K+ x; y7 F' M! Y, e
8 H$ }1 ]: n2 l2 R
: Q) }: S, g6 J

, v' ~# G4 x3 l) o. G4 ~5 w- y, z# _9 j4 [# y8 T/ v9 t  i

  l0 p0 _" V8 O$ R8 ^

15

主题

301

帖子

1673

积分

四级会员(40)

Rank: 4Rank: 4Rank: 4Rank: 4

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

68

主题

613

帖子

4089

积分

五级会员(50)

Rank: 5

积分
4089
4#
发表于 2015-6-30 10:56 | 只看该作者
绝对好东西,32个赞!!!
無極生太極 太極生兩儀 兩儀生四象 四象生八卦 八卦生六十四卦 六十四卦生宇宙萬物

11

主题

189

帖子

2375

积分

四级会员(40)

Rank: 4Rank: 4Rank: 4Rank: 4

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

5

主题

63

帖子

517

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
517
6#
发表于 2015-6-30 11:40 | 只看该作者
好强大

116

主题

563

帖子

7196

积分

EDA365版主(50)

Rank: 5

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

14

主题

290

帖子

1622

积分

四级会员(40)

Rank: 4Rank: 4Rank: 4Rank: 4

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

1

主题

149

帖子

952

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

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

29

主题

2646

帖子

2805

积分

四级会员(40)

Rank: 4Rank: 4Rank: 4Rank: 4

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

5

主题

32

帖子

779

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
779
11#
发表于 2015-6-30 15:34 | 只看该作者
很好很强大啊!

14

主题

219

帖子

533

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
533
12#
发表于 2015-6-30 16:00 | 只看该作者
顶起来

1

主题

62

帖子

195

积分

二级会员(20)

Rank: 2Rank: 2

积分
195
13#
发表于 2015-6-30 16:57 | 只看该作者
必须给力赞啊,楼主好强大

10

主题

543

帖子

6373

积分

五级会员(50)

Rank: 5

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

7

主题

69

帖子

350

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

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

本版积分规则

关闭

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

巢课

技术风云榜

关于我们|手机版|EDA365 ( 粤ICP备18020198号 )

GMT+8, 2025-4-19 22:28 , Processed in 0.070897 second(s), 39 queries , Gzip On.

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

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

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