Download presentation
Presentation is loading. Please wait.
1
Routing 2 Outline –Maze Routing –Line Probe Routing –Channel Routing Goal –Understand maze routing –Understand line probe routing
2
Maze Routing Place wires and components on grid –grid size = wire width + spacing –works best if all wire widths and spacings are equal –grid squares occupied Distance metric –each square has 4 neighbors unit cost away Search graph –node for each square –unit-cost edge to 4 neighboring nodes w+s 1 11 1 11 1 1
3
Maze Routing Shortest path search (Lee-Moore) –maintain leaf nodes of expansion tree –at each step add unexplored neighbors to list »with accumulated cost –stop when target vertex reached »backtrace for route Guaranteed to find shortest path –large memory requirements - the grid –long search time - number of vertices marked –local optimization - only routing one net at a time 3212 323 3 323 3212 32101 3 23 3 3
4
Algorithm add source node S into list cost S = 0 for all nodes i on list if i == destination D pathcost = cost D break for j=N,S,E,W neighbors that are not visited and not occupied add node j to list cost j = cost i +1 mark i as visited remove node i from list while i != S do mark i as path i = min cost N,S,E,W visited neighbor
5
Maze Routing Avoiding blockage –wire at a time => can block wires Solutions –rip-up and re-route »remove wire(s) causing blockage »route blocked wire »route ripped up wires –shove-aside »add dummy grid lines »squeeze wire through A B AB A B AB A AB
6
Line Probe Routing Gridless - store list of lines and obstructions –sorted lists of vertical and horizontal lines Algorithm –from source and destination project 4 horizontal/vertical rays (probes) –if probes intersect, done - route wires from nodes to intersection –if probes blocked, choose escape point and send new probes »a point just past obstruction EE E A BE
7
Line Probe Routing Advantages –small memory requirements - no grid »store sorted lists of vertical and horizontal segments –fast »binary search of segments for blockage and escape points »# probes << # grid points –higher precision coordinates - no grid Disadvantages –serial wire at a time - blockages »similar rip-up and shove-aside approaches to cope –basic algorithm may not find route when one exists »need to try more escape points »degenerates to grid search
8
Channel Routing Channel –terminals on two sides of rectangle are fixed –horizontal wires on layer1 - trunks, which run in tracks –vertical wires on layer2 - branches, which run in columns Routing Problem –minimize number of tracks used => minimizes channel height –minimize wire lengths, vias –all wires routed at same time - better overall optimization A BA AB A track trunkbranch via dogleg
9
Channel Routing Left edge algorithm –one trunk per net –trunks on one layer, branches on other sort trunks by left edge scan trunks, put all that fit into first track allocate new tracks as necessary repeat scanning until done add vertical branches –ignores vertical constraints »can add doglegs later »may need more tracks –advantage »minimum wire length, vias –not very optimal »31 tracks on “Deutsch’s difficult example” »density is 19 tracks B A A B B A A B
10
Channel Routing Greedy algorithm –route column by column rather than track by track –scan left-right by column –at each track apply heuristics to bring new nets to an existing trunk, and move nets between tracks »greedy - at each column try to minimize tracks and minimize distance to terminals –can often use exhaustive search »number of tracks in a column is small - < 100 –good results, but lots of vias »lots of track to track movement for each net
11
Algorithm for each column for each terminal bring in branch connect to trunk if it exists create trunk at first empty track otherwise create new track move between tracks using heuristics collapse nets to fewer trunks with spare branch space reduce distance between net trunks move nets towards next terminal connect multiple trunks for a net at end of channel B BA A
12
Pattern Channel Routers Slide window along channel –recognize patterns of terminals and occupiedGet more optimal results –doglegs Challenge –developing rule set Problem: Vertical constraint between A and B. C and D occupy surrounding tracks and columns Solution: Shift contacts down and to right, doglegs on each layer to reach them A B C D
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.