当PCB板设计完成后,无论是手工布线还是采用SPECCTRA进行自动布线,总会产生一些布线效果不好、多余过孔等问题。此时可以利用allegro提供的Gloss命令对设计进行优化和调整,这样不仅可以提高设计的美观和可生产性,并且可以降低制造成本,提高产品可靠性。 9 ]7 J8 [( [& G4 v+ I
一、 优化前的准备工作
) }" l7 j! g$ I! Y在进行优化工作之前,先检查设计以确定是整个板子都需要进行优化还是只对某个区域或者某些网络进行优化。
* C2 f8 l2 V" t如果某些网络有特殊要求,我们就应该对其进行设置以保护在优化过程中不改变这些网络的特殊性。保护网络不在优化过程中改变的俄方法就是给网络增加NO_GLOSS 或者FIXED属性。
+ K9 c# d% c4 {( l" E5 i如果要保护设计中的某个区域不被优化,则应设置一个NO_GLOSS的多边形。NO_GLOSS的多边形应该设置在MANUFACTURE层,它的子层可以是NO_GLOSS_TOP、NO_GLOSS_BOTTOM、NO_GLOSS_ALL或NO_GLOSS_INTERNAL。
5 f+ B. F+ H8 J. ^0 ~9 SAllegro还提供了几种不同的优化命令可以针对不同的优化区域进行操作,分别为优化菜单中的Design、Room、Window、Highlight和List。Design用于对整个设计进行优化,Room用于对选定的room进行优化,Window用于对选定的窗口进行优化,Hightlight用于对高亮显示的当个网络或者元件进行优化,List用于对所设定的列表项目进行优化。 . ]/ m; ^9 b, K4 H, s5 @3 R
二、 项目和参数设置
$ x. H2 [: w9 u) P0 E% N选择菜单命令Route/Gloss/Parameters,弹出如图1所示对话框。 . M" T' _: ?' b1 M, S9 A
. O! q7 ?) A; L8 k2 A' M3 V5 `# X* k j- U B8 u
图1 Route/Gloss/Parameters 0 H# x) z/ s/ |6 H1 Y* H/ ~
; o4 s4 a3 K0 n5 O8 ~对话框中的Application栏列出了可进行优化操作的所有选项,单击任一选项前面的按钮可进入到该选项的参数设置对话框,选中某项后面的Run,再单击对话框中的“Gloss”按钮即可进行相关项目的优化。如果一次选中多个选项,优化时就按照这些选项的排列顺序依次进行。 $ W' {, ^ c+ x+ J7 {* \% V; V0 C
该对话框中可进行的优化项目包括: a2 z: F% C3 L0 |, T3 s7 C
◆ Line And via cleanup:走线和过孔的清除 6 ` H( O/ C/ }- d# d
◆ Via eliminate:减少过孔
+ W' ^3 o( _3 H5 ^. P: h5 R7 t% g3 a/ i+ I◆ Line smoothing:将弯折线变平滑
1 ~8 ]9 M* i( l; @( D# }) \: \◆ Center lines between pads:将两焊盘之间的走线放置在中间 ! K2 }. X- d* g# c% n+ a
◆ Improve line entry into pads:增加连入焊盘走线的入口
Y- X" t- _, V4 A' c◆ Line fattering:增大线宽 ! o) h) v7 \; d+ k- c5 T# N
◆ Convert conner to arc:将走线方角变为圆弧
! g1 R& K& P: q% G( M- `) ]' _6 A& }3 u◆ Pad and T connection filter:焊盘和T行联接处理
6 A B5 ~0 V: b; M& h+ l1 p9 U◆ Dielectric generation:产生绝缘体 " ? x7 [- F& C! G c
下面分别对常用的几种功能进行介绍。 1 _5 q! f4 T1 D/ Y* {, B
1、Line And via cleanup:这项功能将走线和过孔清除后重新布线。单击该项前面的按钮可进入参数设置对话框,如图2所示。 7 _/ ~" Z1 T) H
* S0 `! Y' s. e- ]% E4 _, F4 E" X& n1 P9 l2 [" ?
图2 0 i M, Q% R4 w0 \
: V7 Q( ?/ u. `2 L/ U- v
对话框中的参数设置分为3部分。 : S( l# C U2 f f
第一部分是关于Line的参数设置,主要选项功能如下 9 D& s6 L& [. z7 ]5 r& g' J
◆ Jog Size Limit:用于设定在清除过程中可增加的斜线段个数,值为-1时表明该项没有限制。
, k3 {0 e! J$ [- z2 B8 f/ `* d* c◆ Etch Length/Via:用于设定为了减少过孔而增加的布线长度,值为-1时表明该项没有限制。 # s6 U' n% j/ n; A2 Y9 t% l
◆ Net Length Limit:用于设定线网的长度超过该设定值时才对其进行清除和重新布线,值为-1时表明该项没有限制。
' j2 c3 e. O( |2 H◆ Maximum 45 Length:用于设定45度角的水平边或者垂直边的长度。 9 p7 J X* C0 w% l. ?
◆ 复选框Slip Slide:用于设定在清除布线时是否可以应用推挤功能。
1 }2 J6 d. U5 p& p5 W" G$ N0 W第二部分为关于Via的参数设置,主要选项功能介绍如下。
' J0 _" R2 g6 D {8 Z; l◆ 复选框Retry:用于设定清除连线后布线器是否进行进行重新布线,一般情况下选中该复选框。
1 d% Z/ K& A, r3 u0 f+ H◆ Number of Executions:用于设定执行操作的次数,推荐选择多次运行。 & s+ y& Y$ G4 v6 w: Y+ |
◆ Cleanup All:用于设定清除的对象,选择Lines只清除连线,选择Lines and Vias则清除连线和过孔,选择Lines,Vias,and Missing Connecs则清除连线和过孔,对后对清除的连线以及设计中没有连接的线网进行连线。 6 h. q; J6 R/ \" c4 _% }2 v
2、Via eliminate:这项主要用来减少整个设计所用过孔数量。单击该选项前面的按钮,弹出如图3所示参数设置对话框。
3 S: T5 r" ^3 Y1 E/ Q2 M4 \
L2 m$ \% ]3 |8 W( Z& t: \: C* f5 w1 [% S, k1 c! w
图3
9 N" e5 X# {4 Q$ z/ U, r; u- z* j' o! z/ B3 T* H# I
◆ Eliminate Used Pin Escapes:用来设定是否减少有用的扇出过孔。选中后,当两个SMD类型焊盘各通过一个扇出孔引出后又通过其他层走线相连时,系统会尝试将这两个过孔删除,用同样线宽的表层走线来实现两个SMD焊盘的连接。
& h* I- {8 w- E3 G◆ Eliminate Unused Pin Escapes:用来设定是否减少无用的扇出过孔。选中后,当一个SMD焊盘通过一个扇出孔引出后又通过表层走线实现了和另一个SMD焊盘的连接时,系统会删除这个没有起作用的过孔。 ) Z9 F* _4 S. r
◆ Eliminate Stand Alone Vias:用来设定是否删除没有网络属性的孤立过孔。
8 t6 G4 R) Q" D. W" K& k◆ Eliminate Regular Through Vias:用来设定是否删除正规的多余通孔。 ! s t/ V# K( Y
◆ Jog Size:用来设定在执行Via Eliminate时可用的最大的拐线尺寸,缺省值为-1,表明没有拐线尺寸方面的限制。
: V! D2 n. m5 q, `0 E1 a设置完成之后单击“Ok”,在图1所示界面中选择Via eliminate选项,单击“Ok”开始进行Via eliminate的优化操作。 / r4 R, _2 l! {2 _3 P
3、Line smoothing:用来删除设计中额外的连接线段或者拐线,是连接线变得平滑,每次执行Line smoothing命令时只对设计中的每个线网检查一遍,所以最优的情况是将该命令执行多次,单击选项前面的按钮,弹出如图4所示的设置对话框。 - R8 l( b2 `5 t- F0 `& {7 `; q
2 _! _6 Q& x6 Y2 W4 }* ?) g$ \2 M F) v
7 W# M% G2 d9 G3 c0 @
图4 . A7 \5 i0 G0 k: w7 ^
; U+ N$ O% I* H' k◆ Eliminate:用于设定能被删除的对象。 9 c; c! n+ s7 C* w! \
◆ Bubbles:用来设定是否删除一个90度走线后的45度走线。
& V8 `; B, s+ q6 y◆ Jogs:用来设定是否删除多余的拐线,将两段拐线合并为一段。 . J/ y4 k3 L8 `" E [! X3 Z4 @
◆ Dangling Lines:用来设定是否删除两头没有连接的孤立线段。
: m- ~% @8 m7 c◆ Line Segments:用来设定线段的一些参数。 ) x% L% M2 {/ d5 j6 U6 b3 a
◆ Convert 90 to 45:用来设定是否将设计中的90度的拐角转换成45度的拐角
( m U" e3 d/ Z+ k◆ Extend 45:用来设定是否延长连接一个水平线段和一个垂直线段的45度连接线,这样就可以将水平线段和垂直线段删除。
$ o" u; m' f; T1 b( Y◆ Maximum 45 Length:用来设定45度连接线的最大长度,缺省值为-1,表明对该项没有限制。
; m& y+ o! j- q! v5 q0 H! H% M1 K◆ Length Limit:用来设定进行平滑处理的连接线的长度,缺省值为-1,表明没有限制,任何长度的连接线都要进行平滑处理。
4 z: Q) ]/ j! T& s) G, \7 `2 U◆ Corner Type:用来设定是45度的拐角还是90度的拐角,缺省为45。 & m( _4 g; ` G% D5 M4 |! {
◆ Number of Executions:用来设定Line smoothing命令的执行次数,推荐多次使用该命令。 ! S1 [0 Y% t) ~' w6 u/ _! U g
4、Center lines between pads:用来调整连接线使之与相邻管脚保持相同的距离。单击选项前面按钮,弹出如图5所示的设置对话框。 $ z# n3 F4 Y* r6 P3 F3 i
- H* n! p7 p1 u
& c( L' M- H* b: \/ |! L" K7 Q$ |/ p图5 3 ~4 r" x* J! ^ \4 o
$ M- U$ K) q$ a% Q
◆ Minimum move size:用来设定移动连接线的最小距离,缺省值为两个设计单位。当一组连接线中任意连接线的移动距离小于该值,这一组中所有的连接线都不进行移动。
" g9 B/ Z* ~3 m F! V9 a◆ Adjacent pad tolerance:用来设定两个相邻管脚水平方向或者垂直方向上中心到中心的最大距离。 # T6 G0 ^$ Q6 v! L
◆ Corner Type:用来设定采用的是45还是90度拐角,缺省为45。 : f3 f: \* K3 y' c& p. i/ K7 G
◆ Line spacing:用来设定划分线间距的种类。选择Minimum是说明按照线到线的最小间距分配布线空间,最外面的连接线和管脚之间的声誉间距保持平均分配,如果有DRC错误产生,就不将连线移动到中间。选择Even是保持每一条连接线和管脚之间的间距都是相等的,如果有DRC错误产生,则应用Minimum规则重新移动连接线。 2 V. U8 ?; R0 Z
单击Gloss layer按钮可进入图6所示的对话框。
7 H5 C, K" h8 q+ k- q/ C# P; J' b1 U% e$ c
0 @( D; x& q7 p% a: S
图6
- ]3 F9 s8 g8 p2 l* \' A3 ]3 |' b# U0 R/ [/ ~- {# U
在这个对话框中可从现有板层中添加或删除进行Gloss处理的叠层,单击Add按钮可以添加新层(可选的层都是已经定义的并且类型设置为Conductored的层),单击Delete可以删除后面的层,右边的文本输入框用来设定有效的aroute生成的连接线上的拐线个数,由于Allegro中aroute不能用,此处可以忽略。
& a+ z6 q9 K: R9 i; X设置完成之后单击Ok推出设置对话框,在图1所示界面中选择Center lines between pads选项,单击Gloss开始进行Center lines between pads的操作。 |