VLSI CAD Logic to Layout
Coursera
Course Summary
A modern VLSI chip has a zillion parts -- logic, control, memory, interconnect, etc. How do we design these complex chips? Answer: CAD software tools. Learn how to build these tools in this class.
-
+
Course Description
A modern VLSI chip is a remarkably complex beast: billions of transistors, millions of logic gates deployed for computation and control, big blocks of memory, embedded blocks of pre-designed functions designed by third parties (called “intellectual property” or IP blocks). How do people manage to design these complicated chips? Answer: a sequence of computer aided design (CAD) tools takes an abstract description of the chip, and refines it step-wise to a final design. This class focuses on the major design tools used in the creation of an Application Specific Integrated Circuit (ASIC) or System on Chip (SoC) design. Our focus is on the key representations that make it possible to synthesize, and to verify, these designs, as they move from logic to layout.
Our goal is for students to understand how the tools themselves work, at the level of their fundamental algorithms and data structures. You should be taking this course if (1) you are interested in building VLSI design tools; (2) you are interested in designing VLSI chips, and you want to know why the tools do what they do; (3) you just like cool algorithms, that work on big cool problems that involve bits, and gates, and geometry, and graphs, and matrices, and time, and...
-
+
Course Syllabus
Topics covered will include: Computational boolean algebra; logic verification; logic synthesis (2-level and multi-level); technology mapping; timing analysis; ASIC placement and routing.
-
+
Recommended Background
Programming experience (C++, Java) and basic knowledge of data structures and algorithms. An understanding of basic digital design: Boolean algebra, Kmaps, gates and flip flops, finite state machine design. Linear algebra and calculus at the level of a junior or senior in engineering. Exposure to basic VLSI at an undergraduate level is nice -- but it’s not necessary. We will keep the course self-contained, but students with some VLSI will be able to skip some background material.
-
+
Course Format
The class will consist of lecture videos, which are between 15 and 20 minutes in length. There will also be standalone problem sets (homeworks) that are not part of video lectures, a few programming assignments, and a (not optional) final exam.
-
+
Suggested Reading
The course is designed to be self-contained. However, we will offer pointers to original source material, i.e., papers in conferences and journals. This area lacks a single, established “front-to-back” text, that covers logic and layout, as well as representation, optimization, synthesis and verification. So, we will work to be as complete as possible in the lectures.