A Formal Algorithm for Routing Traces on a Printed Circuit Board by Hedgley, David R., Jr.
NASA
Technical
Paper
3639
September 1996
A Formal Algorithm for
Routing Traces on a
Printed Circuit Board
David R. Hedgley, Jr.
J
https://ntrs.nasa.gov/search.jsp?R=19970001350 2020-06-16T03:49:04+00:00Z

NASA
Technical
Paper
3639
1996
National Aeronautics and
Space Administration
Office of Management
Scientific and Technical
Information Program
A Formal Algorithm for
Routing Traces on a
Printed Circuit Board
David R. Hedgley, Jr.
Dryden Flight Research Center
Edwards, California

ABSTRACT
This paper addresses the classical problem of printed circuit board routing: that is, the problem of automatic
routing by a computer other than by brute force that causes the execution time to grow exponentially as a function
of the complexity. Most of the present solutions are either inexpensive but not efficient and fast, or efficient and fast
but very costly. Many solutions are proprietary, so not much is written or known about the actual algorithms upon
which these solutions are based. This paper presents a formal algorithm for routing traces on a printed circuit board.
The solution presented is very fast and efficient and for the first time speaks to the question eloquently by way of
symbolic statements.
NOMENCLATURE
The following nomenclature do not appear in alphabetical order as each definition is predicated upon
previous definitions.
_t
RM
RM h
RM
V
the major axis (horizontal or vertical direction) where the sequence {Ji } is associated with It.
the minor axis (horizontal or vertical direction) where the sequence { Mki } is associated with 13.
a rectangular matrix of evenly spaced grid points where a node is defined to be an arbitrary grid point
belonging to RM.
RM represented as a sequence of horizontal lines composed of grid points.
RM represented as a sequence of vertical lines composed of grid points (fig. 1).
r
.... e-_-e---e_--4_, _- e'_ -e-,-.e---_$_ --,0- _.e,---o- -4, ....
r
. H7,2= 5 : "
.--.--.--.--.--.--.--'.--.--.--.--,,or--
L'_'H
V 6,1=1
6,2 = 0 RM
I1
I T I [ [ [ I ! I t 1 ! [
! ! i ! I 1 I I t 1 ! 1
I I ! I • _ • I t II 1 I
• • • _ v4,4.3 • • • • •I ! 1 I i I I I I
1 I I I I 1 I I I ! 1 I
l ! I I l + I ! I I I II I
I I I i I I 1 I I I I i
• • • • • • • • • • • •
I I i ! I I ! I I l i I
I i t I " l I I' I ! l ! I
l t l i 1 i I I I, 1 _ I
RM
nol _ctu_ trace_
Figure 1. A representation of an internal matrix.
Hp,l
Vp,l
Ji
Mki
Ni_> 1
S(J i, Mki)
the number of available nodes from left to right at the node, (p, l), that belongs to RM h (fig. 1).
the number of available nodes from bottom to top at the node, (p, 1), that belongs to RM v.
the i th designated node on the major axis where sequence { Ji } is monotonic and bounded. That is,
if (IB, MB) and (IE, ME) are the initial and terminal nodes respectively, then IB = J i > J2 > J3 >
J4 ..... Jn = IE, or IB = Jl < J2 < J3 <J4 ..... Jn = IE. (These inequalities are consistent with the
horizontal axis as the major axis. Otherwise, the sequence { Ji } is bounded by MB and ME, and the
inequalities will be consistent with the vertical axis as the major axis. Moreover, [Ji - Ji - 1[ repre-
sents the number of available nodes between Ji and Ji- l' That is, the sequence { Ji } is determined
by availability (fig. 2). If IB = IE or MB = ME, then only one major axis (direction) exists.)
the k th designated node on the minor axis that intersects the major axis at Ji, where Mki may not be
monotonic or bounded for any i. The sequence { Mk, } is designated by the assignment of nodes in
a cluster, if possible (fig. 2).
the number of nodes (1 < k i _<Ni) on the minor axis associated with Ji' The M li denotes the inter-
section node of the minor axis with the major axis at Ji •
the discrete function that first interrogates the availability of a path belonging to either RM h or RM v,
which is initiated at the node (Ji, Mki), in the major direction. If applicable, the function then st, b-
sequently interrogates the availability of a path in the minor direction if, and only if, Ji + I = IE or
ME. The values of S(Ji, Mki ) are defined as follows:
• NA = No availability (not any space on the major axis is free).
• PA = Partial availability on the major axis.
° TA = Total availability (both axes are free to complete the trace).
" :- ". - "- " _ " Targel
i • " ,,--_=---o' ..... • • .-•
• IP' ...... q ...... ,o- ..... • • •/ /"
'b,, "I _ / _'J"_'"l _ --
!
I
I
IM
| 21
I
!
I
!
b
MS
1
• • ...... • ...... l •
M22
I
I
I
I
• • ..... _ _ • •
M
12
Red i_gir.atoe ocqmpaa,,W
Bluo indlcalloe emlreat Ilac_
Pins
• Nod,.* (r_ v_,it_)
m m m Actual tl-ace$ or; horizontal oKle
i Act_I tr_es _ ve_al s_
Figure 2. A representation of a typical trace.
NI no further interrogation, implying total success or total failure.
Definitions of Operations:
C _ D the exchange of definitions of C and D.
C _ D the exchange of definitions of C and D cannot take place.
E[S(b, c)] evaluate S(b, c).
INTRODUCTION
An automated solution to the printed circuit board problem that is both efficient and cost effective continues to
be in great demand. Most of the present solutions !-4 are either inexpensive but not efficient and fast, or efficient
and fast but very costly. In either case, no solution exists that describes its algorithm symbolically with any degree
of eloquence, nor are any algorithms sufficiently fast enough to facilitate parts placement for optimization. Many
solutions are proprietary, so not much is written or known about the actual algorithms upon which these solutions
are based.
The purpose of this paper is to accomplish three objectives:
• To facilitate optimization of arrangement of parts (for example, resistors and capacitors) on printed circuit
boards for more sophisticated and expensive systems.
• To make a very fast and efficient algorithm accessible at no cost for individual users or small companies.
• To serve as a pedagogical tool that has heuristic value by presenting a formal symbolic structure that
describes the entire algorithm.
FORMAL SYMBOLIC STATEMENTS
The purpose of the following algorithm, presented as a list of symbolic statements, is to construct a path from
the source node, (IB, MB), to the target node, (IE, ME). A typical path (fig. 2) is described by the sequence of nodes
(J 1, M 1t), (J2, M 12), (J2' M52), and (J3, M13)" In this case, M ll = M I2 and M52 = M13. In general, if (Ji' Mki)
is an arbitrary element in a sequence leading to a solution, then the next element in the sequence will be either
(Ji + 1, Ml(i + 1)) or (Ji, M(k + u)i)' where u > 0. Thus, the algorithm is as follows:
(a) Ni > 1, k i < Ni, and S(Ji, Mki ) = NA _ E[S(Ji, M(k + 1)i) ]
(b) i> l,Ni>l,k i = N i, and S(Ji, Mk) = NA_E[S(Ji_I,M(k+I)__I)]
(c) i = 1,Ni>-l,k i = Ni, andS(Ji, Mk) = NA_I.t_ I]or(IB, MB)_ (IE, ME) andE[S(JI,MI)]
(d) i = 1, N i->l,k i = N i,S(J i,Mk, ) = NA, la:_ _and(IB, MB)"_ (IE, ME)_NI
(e) S(J i, Mki ) = PA _ E[S(J i + 1, Ml(i + i))]
(f) S(Ji, Mki ) = TA _ NI
Theefficiencyof the algorithm is also predicated upon the process that determines the availability of rows and
columns and determines the maintenance of the two respective directories. That is, a directory of rows, RMh, and
a directory of columns, RM v, are maintained where each directory theoretically addresses different sides of the
routing board. If required, any subsequent layers or surface mounts are handled similarly.
In general, the determination of the availability at an arbitrary node, (p, 1), with respect to either RM h or RM v
may be addressed accurately, keeping in mind that Hp, l and Vp, l are interchangeable as they relate to the following
explanation (fig. 1). For the sake of specificity, Hp, I will be employed here. Thus, let (u o, lo) be a target with re-
spect to (Po, lo) and where u o > Po" Then the availability at (Po, lo) = min[Hpo, lo, Uo - Po]" However, if u o < Po,
then construct the equation T O = Huo ' lo - (Po - Uo)' Consider the two cases T o _>0 and T O< 0. If T o > 0, then the
availability at (Po, lo) with respect to (u o, lo) is Po - Uo" If T O< 0, let T -- Hu, lo - (Po - u), where u o < u < Po'
Then the availability at the node (Po, lo) that belongs to RM h is calculated using the bisection method whose di-
rection of seek is governed by the sign of T. Moreover, because the maximum availability is sought, the number of
iterations will be n = [LOGE(Po- Uo) ] + 1.
The integrity of the algorithm, which is implemented by recursive descent, is not disturbed by either the defini-
tion of the major and minor axes or the specificity of the terminal and initial nodes. Therefore, all four combinations
of axes and nodes are transparent to the algorithm itself. Furthermore, an additional criterion to interchange axes or
nodes could be predicated on the value of i or the magnitude of k i for some i.
The number of vias can be minimized from the contents of the directories (RM v and RMh) after the solution
is complete. This reduction results in a lower cost for the actual physical implementation of the solution. Finally, the
updating of the directories dynamically is trivial, as the RM v and RM h contents are corrected based on the values
of Ji and the corresponding Mki resulting from the monotonic sequence {Ji }'
The application of the theory presented confirms the objectives sought. Appendix A presents examples of typical
solutions found. Moreover, a comparison study of the state-of-the-art algorithms is made. Appendix B addresses the
efficiency, the cost, the ratio of solution to the Manhattan distance, and the central processing unit time.
CONCLUSION
An automated solution to the printed circuit board problem that circumvents the devastation of exponential growth
as a function of complexity has been presented. Moreover, application of the theory displayed in Appendix A
demonstrates its versatility and range. The statistics presented in Appendix B confirm the objectives sought. The com-
puter program based upon the ideas presented here will be offered by COSMIC, located in Athens, Georgia.
The author wishes to acknowledge Glenn Bever, Rodney Bogue, and Harry. Chiles fbr their many helpful
suggestions.
APPENDIX A
EXAMPLES OF TYPICAL SOLUTIONS*
;'/ ,---, ,
o _ _ 9\ ` ,, ; / t
_o _.o o o:_--'/o o o _,_ o o ,o,_-o.o o".e o
.... / ! I I I I _1\ \ ,
_-_rO _ 6_0L0'G 'D 0)O'O {)'0 ,_l 0_Ot0 0 "9 ,C' 0/
," _ \ , ". , -/ I / ,L I _ I _/
,._ r r n I ' "-
_ k I I i r"t . o i i e . n , j _.I_-.L.4 I _ "1
'[c,-' o'e,_&,e o 'o o,o,o_o,o o I ¢,:olele_o,o,o I
ori! 'oi i : :' : <A
; _ _0 _i_ 0 -¢,10 "0 ¢" 0 0,,,_ 0,0-, 0 _0 0 00@'0',0v0 I
..,--,.--._[o,o o o'o o, ,o e,o) e..o o,o' ,¢ o,o,o o',o,o',
I ' _ K I "r _ -- I , _ I I 1
i F \ ! I I t _ I -- I
". I I I } I II:J; i'<,/. ,-. ,,o .
I' "-.,.e',o'_ 6!o:_ o' e,o,o",_ e,o',o '.o]_,;o.o o,_,o,;
I'. ,o,o. o,_o o .e 'e,o'o".e[o o .e ¢,,o,o,o;o,o o,,
7,_ e,o e,o'.o,o '..e .e o\o,o,o o; o e,_ o.o o,e._
o,o'o,o o,o o o'.o _ o-o:o _.. _ _,o_I_1o',o,
'.0_0_0 O'@iO" ¢' "0 0 0 O" 0 0'_0 OlO/O" 0/0 0 I
I I I ._ I d ' I r _ I I L / I
_"-T'-'--_I , I I l I _ I I ] I
I s I . 1 "_-,, I / t t
"0 0 0j0 010_0,0 0, -,b.. 0_'-
o t,_-o o:o,_--_, o,o,o o, o_,_',o o,,_ o, ,---_
I I I A I __h I i I I'_ _ I I 1"
' _ 0 ,0_@-'0 _ 0" 0 0 0 ,0 0 ¢.4,. 0 010 '._t©'0'l_
O O "_ 10 I 0 '_ 0 I i O "_ 0 0J0 0 "_ I1_0 0 t 0 9 010 I 0
I I i I I _t / I _ I "[ i - IX
..-O zO 0_0_0_9" 0' _0 _ 0_0 Cb 0_0_ 0 0,0 _ _,_"0
"_ Ii/ o 0,o,9 o,0]0_'0,_ 0,_-0 0,0, 0 0,0 9 0,o 0
IX x I I , I _ ', i I _ I I • \_ L I _ _ I
--_ I I ' I _ I ya .,f, I I
\ 5 , 0
x ........................
o
II
N
u-'
O
e-,
i:m
*Dash lines and solid lines are on different sides of the layer.
5
ill
I I
t
I I
11 I
I
ill
ill
II I
III
IIiiiii
lllilll
II I
I I II
f
o
0
II I It I
It
I IIt I
"Oi 0 {it+OI
_0 liO I l I/()l
I I rio t I
ii li l I
I
I[ I 1
",1
II
II
III Iii
I
i ii I III I
II Iii I Itl I
II Iii I Ill I
I . Ol liOi
11
I/ i _ I It111_ I
IO IO!_ JO
iO.sr_-__, i0
I_ I I I
I t11,1 II
I t
I I
I I
,oi(_4_I01 I0 iO _ 0
i ill _i i i i_, I
I Itl t
I_ t ill
I I t ti
II 0 li_ C)Ii_ OJ 0 lli_
1 I i1 I
I I i1'_ t
SOil I
I
iO C_
,0 0 g
I1
I I
I I
I II I
0
! I
i I
I I
I I
Oil
_11
II I
t !0 i
I I I
I I
II I I
il I I
I I I tll
I I I I I !1
{_ I0 i 0 II0,-4..!._
II
II
I I
I I I I
6, o
O_ 0
i I I I
I I
I i
I
I I! I
I i I I
I i I
'010 frO i
'0,0
I I II I I I
I I
I
;io 'o ioi0 0 IO
t I I I I t I
I I I
I I I
01 IO iO" _) tO l IC) OlO
I 'iOi'0 iO
i I I
I I i I
i I i I
I
Ol 0 _0 0
C"xI
c5
If
m
"1=
b/}
©
©
¢,)
0
N
"i::
0
{-.i
II
II Iii i
II I_I
II
L\
Iii
I
III
i I
0
o
II
N
'T.
o
©
o
o
o
o
U.
APPENDIX B
TABLE OF COMPARISONS*
Ratio,
actual distance/ Completion Cost,
Algorithm Manhattan distance rate, percent dollars
CPU time,
minutes
Shape tech 1.05 98-100 12,000 10
Pcad 1.10 92 4,000 30
Hedgley 0.97 93 0 0.25
IIc . .
Chart statistics are reflective of a one-layer board that is two-sided with equivalent grid sizes.
8
REFERENCES
Kinnucan, Paul, "Printed-Circuit Board Design: Low-Cost Systems are Winning Respect," The S. Klein Computer
Graphics Review, Summer 1987, pp. 79-105.
2 Wittenberg, Roland C., "Algorithms Do What Designer Does Naturally," Electronic Engineering Times, September
14, 1987, pp. 137-138.
3 Jackoway, Gary, "Automating the Printed Circuit Board Design Process," Hewlen-Packard Journal, February 1988,
pp. 68-71.
4 "Speedy Gridless Software Designs Denser PC Boards," Electronics, v. 60, no. 14, July 9, 1987, pp. 102-103.
REPORT DOCUMENTATION PAGE Form Approved
OMB No. 0704-0188
Pul_icreportingburdenfor thiscollectionof informationis estimatedto average1hourperresponse,includingthe time for rewewinginstructions,searching existingdatasources,gatheringend
maintainingthe data needed, and completingend reviewingthe collection Ofinformation.Sendcommentsregardingthisburdenestimateor any other aspectof thiscollectionOfinformation,
includingsuggestions for reducingthisburden, to WashingtonHeadquartersSennces,Directoratefor InformationOperationsand Reaorts, 1215JeffersonDavisHighway,Suite1204, Arlington,
VA2220_-4302, and tothe Office of Managementand Budget,PaperworkReductionProject{0704-0188),Washington,DC 20503.
1. AGENCY USE ONLY (Leave blank) 2. REPORT DATE S. REPORTTYPE AND DATES COVERED
September 1996 Technical Paper
4.TITLE AND SUBTITLE
A Formal Algorithm for Routing Traces on a Printed Circuit Board
6. AUTHOR(S)
David R. Hedgley, Jr.
7. PERFORMINGORGANIZATIONAME(S)ANDADORESS(ES)
NASA Dryden Flight Research Center
P.O. Box 273
Edwards, California 93523-0273
9. SPONSORING/MONOTORINGA ENCYNAME(S)ANDADDRESS(ES)
National Aeronautics and Space Administration
Washington, DC 20546-0001
11. SUPPLEMENTARY NOTES
S. FUNDING NUMBERS
WU 505-68-84
8. PERFORMING ORGANIZATION
REPORT NUMBER
H-2104
10. SPONSORING/MONITORING
AGENCY REPORT NUMBER
NASA TP-3639
12a. Di3/_IBUTION/AVAILABILITY STATEMENT
Unclassified--Unlimited
Subject Category 61
13. AB_i _CT (Maximum 200 words)
12b. DISTRIBUTION CODE
This paper addresses the classical problem of printed circuit board routing: that is, the problem of automatic
routing by a computer other than by brute force that causes the execution time to grow exponentially as a func-
tion of the complexity. Most of the present solutions are either inexpensive but not efficient and fast, or efficient
and fast but very costly. Many solutions are proprietary, so not much is written or known about the actual algo-
rithms upon which these solutions are based. This paper presents a formal algorithm for routing traces on a print-
ed circuit board. The solution presented is very fast and efficient and for the first time speaks to the question
eloquently by way of symbolic statements.
14. SUBJECTTERMS
Artificial intelligence, Printed circuit board, Routing
17. SECURITY CLASSIFICATION le. SECURITY CLASSIFICATION
OF REPORT OFTHIS PAGE
Unclassified Unclassified
NSN 7540-01-2S0-5S00
19. SECURITY CLASSIFICATION
OF ABSTRACT
Unclassified
Available from the NASA Center for AeroSpace Information, 800 Elkddge Landing Road,
Linthicum Heights, MD 21090; (30 I)621-0390
15. NUMBER OF PAGES
13
16. PRICE CODE
A03
20. LIMITATION OF ABSTRACT
Unlimited
Standard Form 298 (Rev. 2-89)
PrescribedbyANSIStdZ39-18
298"102
