## University of Toronto, Department of Electrical and Computer Engineering ## ECE 1387 - CAD for Digital Circuit Synthesis and Layout ## September 2016 **Instructor:** Jason Anderson **Phone:** 416-946-7285 Office: EA 314 (Engineering Annex) E-Mail: janders@ece.toronto.edu Instructor's Web: http://janders.eecg.toronto.edu Office Hours: After class or by appointment or swing by my office Course Web: https://piazza.com/utoronto.ca/fall2016/ece1387/home **Pre-requisites:** ECE 1388 (VLSI Design Methodology), or ECE 451 (VLSI Systems), or CSC 2410 (Algorithms in Graph Theory), or Permission of instructor. **Programming skills in C/C++**, including data structures. **Lecture:** Fridays 5:00-7:00 PM in room GB 221 (Galbraith Building) **Papers/Readings:** Available in PDF on course website. **Evaluation:** Assignments 50% (3 or 4) Paper 25% Exercises 15% (3) Quizzes 10% (2) **Assignments:** Programming implementations of CAD problems such as placement, routing, and technology mapping using optimization strategies such as simulated annealing, dynamic programming, integer linear programming (ILP), and branch and bound, and illustrated using computer graphics. **Exercises:** Hands-on experience with CAD tools such as ABC (UC Berkeley), VPR (Auto Place & Route), and hMetis (Partitioning). **The Paper:** A critical assessment of work in a subset of the field (chosen in consultation with the instructor) based on 3 to 4 papers. Quizzes: Short 15 minute quizzes, at the end of selected lectures (to be announced in advance), on topics presented in preceeding lectures. ## **TENTATIVE Lecture and Assignment Schedule – Fall 2016** | # | Date of<br>Friday<br>Lecture | Lecture Topic | Assignment/<br>Exercise<br>Handed Out | Assignment/<br>Exercise<br>Due | |----|------------------------------|------------------------------------------------------------|----------------------------------------------------------------------------------|--------------------------------| | 1 | Sept 16 | Introduction, Overview | Paper | | | 2 | Sept 23 | Routing | Assignment 1 – Routing | | | 3 | Sept 30 | Timing-Driven Routing | | | | 4 | Oct 7 | Placement | | | | 5 | Oct 14 | Placement (Analytical Techniques) | Assignment 2 – Analytical Placement | Assignment 1 | | 6 | Oct 21 | Placement (Simulated Annealing) | Exercise 1 – VPR placement and routing | | | 7 | Oct 28 | Partitioning or SAT Solvers<br>(Branch and Bound) | Assignment 3 – B&B as applied to partitioning or Boolean SAT | Assignment 2 | | 8 | Nov 4 | Timing Analysis and Slack Allocation | | Exercise 1 | | | Nov 11 | NO CLASS | | | | 9 | Nov 18 | Partitioning (FM/Multi-Level: hMetis) | Exercise 2 – Partitioning Using hMetis or FM | Assignment 3 | | 10 | Nov 25 | Technology Mapping / Logic Synthesis (Dynamic Programming) | Exercise 3 – Technology<br>Mapping Using Dynamic<br>Prog in ABC<br>(UC Berkeley) | Exercise 2 | | 11 | Dec 2 | High-Level Synthesis 1<br>(Intro + Scheduling) | Assignment 4 –<br>LegUp High-Level<br>Synthesis | Exercise 3 | | | Dec 9 | NO CLASS | | | | 12 | Dec 12 or 16<br>(TBD) | High-Level Synthesis 2 | | | | | Dec 31 | | | Assignment #4<br>+ Paper | | | | | | | **NOTE**: You must consult with the instructor on your paper topic by mid-November.