#### VLSI Digital Signal Processing

#### EEC 281 Lecture 1

Bevan M. Baas Tuesday, January 9, 2024

## Today

- Administrative items
- Syllabus and course overview
- My background
- Digital signal processing overview
- Read *Programmable DSP Architectures, Part I* by E. A. Lee

#### **Course Communication**

- Email
  - Urgent announcements
- Web page
  - http://www.ece.ucdavis.edu/~bbaas/281/
- Office hours
  - After lecture Tuesday
  - After lecture Thursday

## Course Workload

- 4 unit graduate course
- This course requires significant effort and time
  - Multi-disciplinary field coverage
    - DSP algorithms
    - Digital processor architectures
    - Arithmetic
  - Utilizes robust industry-standard CAD tools (but we will make use of only the core essential features)
    - Verilog
    - Synthesis tool
    - Matlab

## **Course Readings**

- No required textbook
- Over 800 slides posted as handouts on the course web page
  - You should fully understand all material in these handouts
- A few required papers
- Several posted tutorials with example code
  - You should fully understand these
- Several optional references

## Main Course Material

- The main body of material is presented in the lectures, readings, and handouts
- Generally speaking, the hwk/projets *complement* the main material
  - They go into a much greater depth on specific topics
  - They give design experience
  - They give significant practical application of theory
- The Quizzes generally focus on the main body of material

#### Breadth and Depth

• Breadth and Depth



### **Course Overview**

- EEC 281 web page contents
  - Reading materials and references
  - Hwk/Project descriptions
  - Handouts

#### **Course Overview**

- Canvas
  - Grades posted here
    - Let me know if you ever see a score different than you expect
  - Upload electronic portions of hwk/projects here
- Syllabus
  - Posted on course web page

#### Lectures

- Ask questions at any time
- Please hold conversations outside of class
- Please silence phones
- Integrated Solid-State Circuits Conference (ISSCC) February 18–21
  - Quiz 2 on Tue, Feb 20

#### Letter Grade Assignments

- I assign a letter grade only for the final course grade
- I look at the final exams and course record of the class and assign two key dividing points: the A/A+ and (probably B/B+) boundaries, and assign course grades from there using equally-sized intervals
  - No required numbers of any particular letter grades
  - Absolute scores are not important; the boundaries shift according to the difficulty of the exams in any quarter
  - Ignore any letter grades you might see on canvas



## Working With Others

- Collaboration
  - Asking questions and explaining principles produces better work and dramatically increases learning
  - Working with others
    - Do homework and prelabs with classmates nearby
    - Ask each other questions, help each other—regarding **principles**, and **approaches to solving** only
  - See Course Collaboration Policy on web page
- Dishonesty
  - Copying produces similar work, stunts learning, is not fair to honest students, and is not allowed in this course
    - Students engaged in dishonest work will be referred to Student Judicial Affairs
    - I will try to keep in-class exams honest
    - Steps will be taken to keep out of class work honest

#### Penalties for Violating the Policy on Student Conduct and Discipline

- Penalties
  - Minimum penalty: meetings with SJA officer, zero grade on work, record with SJA
  - Permanent F grade on your transcript, no credit for the class
  - One to three quarter suspension from the university
  - Permanent dismissal from all ten campuses of the University of California. Permanent notation on your transcript.

#### Penalties for Violating the Policy on Student Conduct and Discipline

- Several perspectives
  - Personal obvious reasons
  - ECE and UCD (especially for those inclined to share work with someone doing poorly in class)
     Cheating harms our major and university's reputation among employers who interview our graduates.
- In summary: The purpose of the penalties and me mentioning them is so that no one will get one!!! Don't do anything that violates the Policy on Student Conduct!

#### Penalties for Violating the Policy on Student Conduct and Discipline

- Typical scenario:
  - Someone shares code/design with another
  - They get caught
  - The "Copier" feels terrible guilt for causing a friend to get a zero
  - The "Sharer" deeply regrets sharing resulting in a zero when he/she should have had a full score

#### Exam and Quiz Regrades

- Some number of exams and quizzes will be scanned before being returned
- Key take-away messages:
  - Do not change anything on your work if you request a regrade
  - One student did last year and got in big BIG trouble!!!

# Cheating Websites chegg, coursehero, etc.

- The university has recently taken a very strong stand against paying for work (2-quarter suspension for first offense last year)
- Key take-away messages:
  - Do not post assignments
  - Of course do not use any unpermitted outside material in work you submit
  - Of course do not post solutions
  - Two students did last year and got caught!!!

#### MOSS

- "Measure Of Software Similarity" tool
- Utilizes very sophisticated and fast algorithms
- Processes all  $Order(N^2/2) = N(N-1)/2$  pairings
  - Ex: examination of 300 submissions includes 44,850 pairwise comparisons
- If needed, MOSS runs will be made with this year's work combined with work from past years

## **MOSS** Demonstration Case

submission1.v (91%) submission3.v (91%) Added, deleted, 78-214 144-168 220-245 185-192 5-12 changed all comments 195-210 <u>14-33</u> 212-224 35-47 Changed all variable submission1.v submission3. >>>> file: paint.v >>>> file: update.v module paint ( module update ( input [9:0] x , input [9:0] test1 , input [8:0] y ,
input [9:0] box\_x , input [8:0] test2 , **Reordered modules** input [9:0] test2\_vx , input [8:0] box\_y , input [8:0] test2\_vy , other input halt, input [2:0] color\_select, output reg [9:0] next\_test1, input [1:0] shape\_select, output reg [8:0] next\_test2, output reg [9:0] next\_test2\_vtest11, output [11:0] rgb reg valid ;
reg draw ; // variable declaration wire [3:0] red ; wire [3:0] green ;
wire [3:0] blue ; reg [4:0] x\_address; reg [4:0] y\_address; next\_test2\_vtest11 = 10'b000000001; wire [31:0] rom\_data;

com rom1 ( .addr(y\_address) , .data(rom\_data) ) ;

- submission 1
- 91% similarity for submission 2

#### Original version

#### Modified version

#### names

- Reordered lines of code within modules
- Changed equivalent logic
- 91% similarity for

#### MOSS

- Key take-away messages:
  - 1) MOSS is amazingly good at spotting pairs of submissions that share a common design
    - This meshes very well with the course collaboration policy
  - 2) Follow the course collaboration policy and you have nothing to worry about
  - 3) Violate the course collaboration policy and you *will* have something to worry about

## Advancing CMOS Technologies

- Moore's "Law" (Observation) was made in 1965 and notes that transistor density ~doubles every year (every 1.5 years now)
- "Cramming more components onto integrated circuits," Gordon Moore, *Electronics,* April 19, 1965.



#### Moore's Law – The number of transistors on integrated circuit chips (1971-2018)

Our World in Data

Moore's law describes the empirical regularity that the number of transistors on integrated circuits doubles approximately every two years. This advancement is important as other aspects of technological progress – such as processing speed or the price of electronic products – are linked to Moore's law.



Data source: Wikipedia (https://en.wikipedia.org/wiki/Transistor\_count)

The data visualization is available at OurWorldinData.org. There you find more visualizations and research on this topic.



Original data up to the year 2010 collected and plotted by M. Horowitz, F. Labonte, O. Shacham, K. Olukotun, L. Hammond, and C. Batten New plot and data collected for 2010-2015 by K. Rupp New data added by B. Baas

## Future Fabrication Technologies

- Basic trends
  - Number of available devices:
  - Energy dissipation per operation:

continually increasing decreasing too slowly



- There are a lot of ways to place and connect a billion transistors
- The most efficient implementations (throughput, energy, area) will have:
  - Processor sizes that capture computational kernels with few excess circuits
  - Optimized clock frequencies and supply voltages matched to dynamic workloads

## **Optimal Computational Tile Size**

• The most efficient implementations (energy, throughput, chip area) have: Processor sizes that capture computational kernels with few excess circuits



#### Number of Processors on a Single Die vs. Year



Note: Each processor capable of independent program execution