ebook img

Algorithms for VLSI Physical Design Automation PDF

499 Pages·1993·14.042 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Algorithms for VLSI Physical Design Automation

ALGORITHMS FOR VLSI PHYSICAL DESIGN AUTOMATION ALGORITHMS FOR VLSI PHYSICAL DESIGN AUTOMATION by Naveed A. Sherwani Western Michigan University ~. " Springer Science+Business Media, LLC Library of Congress Cataloging-in-Publication Data Sherwani, N. A (Naveed A) Algorithms for VLSI physical design automation / Naveed A Sherwani. p. cm. Includes bibliographical references (p. ) and indexes. ISBN 978-1-4757-2221-5 ISBN 978-1-4757-2219-2 (eBook) DOI 10.1007/978-1-4757-2219-2 1. Integrated circuits-oVery large scale integration--Design and construction--Data processing. 2. Computer-aided design. 3. Algorithms. I. Title. TK874.S455 1993 621.39'5--dc20 92-38496 CIP Copyright © 1993 by Springer Science+Business Media New York Originally published by Kluwer Academic Publishers in 1993 Softcover reprint of the hardcover 1st edition 1993 All rights reserved. No part of this publication may be reproduced, stored in a retrieval system or transmitted in any form or by any means, mechanical, photo-copying, recording, or otherwise, without the prior written permission of the publisher, Springer Science+Business Media, LLC. Printed on acid-free paper. To my parents Akther and Akram Sherwani Contents Foreword xv Preface xvii Acknowledgments xxiii 1 VLSI Physical Design Automation 1 1.1 VLSI Design Cycle . . 2 1.2 Physical Design Cycle 5 1.3 Design Styles ..... 9 1.3.1 Full-Custom .. 9 1.3.2 Standard Cell . 10 1.3.3 Gate Arrays. . 13 1.3.4 Field Programmable Gate Arrays . 13 1.3.5 Sea of Gates ........... . 17 1.3.6 Comparison of Different Design Styles 17 1.4 System Packaging Styles . . . . 18 1.4.1 Printed Circuit Boards. 19 1.4.2 MuItichip Modules ... 20 1.4.3 Wafer Scale Integration 22 1.4.4 Comparison of Different Packaging Styles 22 1.5 Historical Perspectives 23 1.6 Summary . . . . . . . . . . . . . . . . . . 26 2 Design and Fabrication of VLSI Devices 29 2.1 Fabrication Materials ......... . 30 2.2 Transistor Fundamentals. . . . . . . . 33 2.2.1 Basic Semiconductor Junction 33 2.2.2 TTL Transistors ... 34 2.2.3 MOS Transistors. . . . . . 35 2.3 Fabrication of VLSI Circuits. . . . 39 2.3.1 nMOS Fabrication Process 41 2.3.2 CMOS Fabrication Process 42 2.3.3 Details of Fabrication Processes. 43 2.4 Design Rules . . . . . . . . . . . . 47 vii 2.5 Layout of Basic Devices . . . . 50 2.5.1 Inverters ........ . 51 2.5.2 NAND and NOR Gates 52 2.6 Additional Fabrication Factors 54 2.6.1 Scaling ........ . 55 2.6.2 Parasitic Effects ... . 56 2.6.3 Yield Statisti~s and Fabrication Costs 57 2.6.4 Delay Computation 59 2.6.5 Noise and Crosstalk 60 2.6.6 Power Dissipation 61 2.7 Summary 62 2.8 Exercises ........ . 62 3 Data Structures and Basic Algorithms 67 3.1 Basic Terminology ........... . 68 3.2 Complexity Issues and NP-hardness .. 70 3.2.1 Algorithms for NP-hard Problems 71 3.2.1.1 Exponential Algorithms. 71 3.2.1.2 Special Case Algorithms 71 3.2.1.3 Approximation Algorithms 72 3.2.1.4 Heuristic Algorithms 73 3.3 Basic Algorithms . . . . . . . . . . . . . . . 73 3.3.1 Graph Algorithms ......... . 74 3.3.1.1 Graph Search Algorithms. 74 3.3.1.2 Spanning Tree Algorithms 75 3.3.1.3 Shortest Path Algorithms. 76 3.3.1.4 Matching Algorithms ... 79 3.3.1.5 Min-Cut and Max-Cut Algorithms. 79 3.3.1.6 Steiner Tree Algorithms ... 81 3.3.2 Computational Geometry Algorithms . 83 3.3.2.1 Line Sweep Method ..... . 83 3.3.2.2 Extended Line Sweep Method 85 3.4 Basic Data Structures . . . . . . . . . . . . . 86 3.4.1 Atomic Operations for Layout Editors 87 3.4.2 Linked List of Blocks. 88 3.4.3 Bin-Based Method 90 3.4.4 Neighbor Pointers .. 91 3.4.5 Corner Stitching . . . 93 3.4.6 Multi-layer Operations. 99 3.4.7 Limitations of Existing Data Structures 100 3.4.8 Layout Specification Languages . . . . 100 3.5 Graph Algorithms for Physical design ..... 104 3.5.1 Classes of Graphs in Physical Design .. 105 3.5.1.1 Graphs Related to a Set of Lines. 105 3.5.1.2 Graphs Related to Set of Rectangles . 107 3.5.2 Relationship Between Graph Classes . . . . . . 109 viii 3.5.3 Graph Problems in Physical Design 109 3.5.4 Algorithms for Interval Graphs . . . 111 3.5.4.1 Maximum Independent Set 112 3.5.4.2 Maximum Clique and Minimum Coloring 112 3.5.5 Algorithms for Permutation Graphs 113 3.5.5.1 Maximum Independent Set 113 3.5.6 Algorithms for Circle Graphs . . . . 115 3.5.6.1 Maximum Independent Set 115 3.5.6.2 Maximum k-Independent Set . 116 3.5.6.3 Maximum Clique. 118 3.6 Summary 118 3.7 Exercises 119 4 Partitioning 125 4.1 Problem Formulation ................ . 131 4.1.1 Design Style Specific Partitioning Problems 134 4.2 Classification of Partitioning Algorithms 136 4.3 Group Migration Algorithms . . . . . . . . . . 137 4.3.1 Kernighan-Lin Algorithm ....... . 138 4.3.2 Extensions of Kernighan-Lin Algorithm 140 4.3.2.1 Fiduccia-Mattheyses Algorithm 140 4.3.2.2 Goldberg and Burstein Algorithm 142 4.3.2.3 Component Replication 142 4.3.2.4 Ratio Cut. . . . . . 144 4.4 Simulated Annealing and Evolution. 145 4.4.1 Simulated Annealing. . 145 4.4.2 Simulated Evolution . . . . 147 4.5 Other Partitioning Algorithms .. 150 4.5.1 Metric Allocation Method. 150 4.6 Performance Driven Partitioning 151 4.7 Summary 154 4.8 Exercises ............. 155 5 Placement, Floorplanning and Pin Assignment 159 5.1 Placement............................ 161 5.1.1 Problem Formulation ................. 162 5.1.1.1 Design Style Specific Placement Problems. 164 5.1.2 Classification of Placement Algorithms. . 166 5.1.3 Simulation Based Placement Algorithms. 167 5.1.3.1 Simulated Annealing. . . . 167 5.1.3.2 Simulated Evolution. . . . . . . 170 5.1.3.3 Force Directed Placement. . . . 173 5.1.3.4 Comparison of Simulation Based Algorithms 175 5.1.4 Partitioning Based Placement Algorithms . 175 5.1.4.1 Breuer's Algorithm ........ 175 5.1.4.2 Terminal Propagation Algorithm. 177 ix 5.1.5 Other Placement Algorithms . . 178 5.1.5.1 Cluster Growth .... 178 5.1.5.2 Quadratic Assignment. 179 5.1.5.3 Resistive Network Optimization 180 5.1.5.4 Branch-and-Bound Technique 180 5.1.6 Performance Driven Placement 181 5.2 Floorplanning................... 182 5.2.1 Problem Formulation .......... 182 5.2.1.1 Design Style Specific Floorplanning Problems. 183 5.2.2 Classification of Floorplanning Algorithms. 183 5.2.3 Constraint Based Floorplanning ...... 185 5.2.4 Integer Programming Based Floorplanning 187 5.2.5 Rectangular Dualization 189 5.3 Pin Assignment . . . . . . . . . . . . . . . . . . . . 190 5.3.1 Problem Formulation ............ 191 5.3.1.1 Design Style Specific Pin Assignment Problems 191 5.3.2 Classification of Pin Assignment Algorithms. 193 5.3.3 General Pin Assignment . 193 5.3.4 Channel Pin Assignment. 194 5.4 Integrated Approach 197 5.5 Summary 200 5.6 Exercises .. 200 :i Global Routing 205 6.1 Problem Formulation .................. . 207 6.1.1 Design Style Specific Global Routing Problems 212 6.2 Classification of Global Routing Algorithms .. . . . . . . 214 6.3 Maze Routing Algorithms . 215 6.3.1 Lee's Algorithm ... 216 6.3.2 Soukup's Algorithm 218 6.3.3 Hadlock's Algorithm 219 6.3.4 Comparison of Maze Routing Algorithms 221 6.4 Line-Probe Algorithms ..... . 224 6.5 Shortest Path Based Algorithms ... 227 6.6 Steiner Tree based Algorithms. . . . . 228 6.6.1 Separability Based Algorithm. 229 6.6.2 Non-Rectilinear Steiner Tree Based Algorithm 232 6.6.3 Steiner Min-Max Tree based Algorithm 233 6.6.4 Weighted Steiner Tree based Algorithm 235 6.7 Integer Programming Based Approach 236 6.7.1 Hierarchical Approach 236 6.8 Summary 241 6.9 Exercises ......... . 242 x 7 Detailed Routing 247 7.1 Problem Formulation. . . . . . 249 7.1.1 Routing Considerations 249 7.1.2 Routing Models. . . . . 250 7.1.3 Channel Routing Problems 252 7.1.4 Switchbox Routing Problems 256 7.1.5 Design Style Specific Detailed Routing Problems 258 7.2 Classification of Routing Algorithms . . 258 7.3 Single-Layer Routing Algorithms . . . . . . . . . . 259 7.3.1 General River Routing Problem. . . . . . . 261 7.3.1.1 General River Routing Algorithm 262 7.3.2 Single Row Routing Problem . . . . . . 267 7.3.2.1 Origin of Single Row Routing. . . 268 7.3.2.2 A Graph Theoretic Approach. . . 271 7.3.2.3 Algorithm for Street Congestion Minimization 272 7.3.2.4 Algorithm for Minimizing Doglegs 273 7.4 Two-Layer Channel Routing Algorithms. . . . 274 7.4.1 Classification of Two-Layer Algorithms 276 7.4.2 LEA based Algorithms. . . . . . . . 276 7.4.2.1 Basic Left-Edge Algorithm . . 276 7.4.2.2 Dogleg Router . . . . . . . . . 278 7.4.2.3 Symbolic Channel Router: YACR2. 280 7.4.3 Constraint Graph based Routing Algorithms 284 7.4.3.1 Net Merge Channel Router. . . . . 286 7.4.3.2 Glitter: A Gridless Channel Router 291 7.4.4 Greedy Channel Router .......... . 294 7.4.5 Hierarchical Channel Router ....... . 295 7.4.6 Comparison of Two-Layer Channel Routers 300 7.5 Three-Layer Channel Routing Algorithms .... 300 7.5.1 Classification of Three-Layer Algorithms. 301 7.5.2 Extended Net Merge Channel Router 301 7.5.3 HVH Routing from HV Solution 303 7.5.4 Hybrid HVH-VHV Router ..... 304 7.6 Multi-Layer Channel Routing Algorithms 307 7.7 Switchbox Routing Algorithms ..... . 308 7.7.1 Classification of switchbox routing algorithms. 309 7.7.2 Greedy Router ............. . 310 7.7.3 Rip-up and Re-route Based Router .. . 313 7.7.4 Computational Geometry Based Router 313 7.7.5 Comparison of Switchbox Routers 317 7.8 Summary 317 7.9 Exercises ......... . 318 xi

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.