# ECE102 - Digital Circuit Logic - Spring 2024

Instructor: Prof. Mahdi Nikdast (<u>http://www.engr.colostate.edu/~mnikdast/</u>) Email: <u>Mahdi.Nikdast@colostate.edu</u>

**Teaching Assistants:** Mr. Rashadul Kabir (<u>Rashadul.Kabir@colostate.edu</u>) and Mr. Asif Mirza (<u>Mirza.Baig@colostate.edu</u>).

## **Office Hours:**

| Instructor            | Time                                                                | Location                                      |
|-----------------------|---------------------------------------------------------------------|-----------------------------------------------|
| Prof. Nikdast         | Friday;                                                             | Join <b>Zoom</b> Meeting                      |
| <mark>(Online)</mark> | 11 AM – 12 PM                                                       | https://zoom.us/j/95475705867?pwd=d3ZPU1pCaEg |
|                       |                                                                     | 3cW03M2ZkVC85N1ZIUT09                         |
|                       |                                                                     | Meeting ID: 954 7570 5867                     |
|                       |                                                                     | Passcode: 462264                              |
| Mr. Kabir             | P1: Monday;<br>1:45 PM – 2:30 PM<br>P2: Thursday;<br>5:15 PM – 6 PM | <mark>In person</mark> at C207                |
| Mr. Mirza             | Wednesday;<br>3 PM – 4:30 PM                                        | <mark>In person</mark> at C207                |

Lectures: Tuesday, Thursday 8 AM – 9:15. Biology Room 136

Labs: https://www.engr.colostate.edu/ECE102/Spring24/labs.html

**Objectives:** To understand the concepts of digital logic and learn methods and tools for the design of digital circuits.

**Prerequisites:** Major in ECE or prior approval.

The official home page for ECE102 is **Canvas**. Students are expected to visit the official home page **frequently** for class handouts, assignments, and important announcements!

Grading Policy: The grade will be based on

| Homework (Every week)                                         | 25% |
|---------------------------------------------------------------|-----|
| Labs (12+1 in total)                                          | 25% |
| iClicker Quizzes                                              | 5%  |
| Midterm 1 (February 22, 2024)                                 | 15% |
| Midterm 2 (April 5, 2024)                                     | 15% |
| Final Exam (May 9, 2024; 6:20 PM – 8:20 PM; Biology Room 136) | 15% |

The +/- grading scheme will be used, with the scale

| >95% | 90- | 85- | 80- | 75- | 70- | 65- | 55- | 40- | <40% |
|------|-----|-----|-----|-----|-----|-----|-----|-----|------|
|      | 94% | 89% | 84% | 79% | 74% | 69% | 64% | 54% |      |
| A+   | А   | A-  | B+  | В   | B-  | C+  | С   | D   | F    |

iClicker Quizzes: During the lectures (and mostly at the beginning of each lecture), there will be several in-class quizzes using iClickers. iClicker quizzes cover the material taught on the same day of the lecture OR to review materials delivered in the previous lecture. <u>Therefore</u>, it is important to attend the lectures, while considering the safety of others in case of sickness, to take part in iClicker quizzes, which account for 5% of the final course grade. In case of sickness, you can contact the instructor before the lecture to be excused from the iClicker questions.

Homework Procedures: Homework assignments are due online (must be submitted on Canvas as pdf). Selected questions from each homework assignment will be graded. However, turn in ALL of the assigned problems. All assigned problems are equally important for the development of your understanding of the subjects of digital logic. To receive full credit for your homework, show ALL reasonable steps in solving the problem. Written solutions will be available online after the due date of the homework. Make sure the file you submit to Canvas is readable, otherwise the course grader will NOT grade your assignment.

Late Policy: Quizzes and Exams must be taken as scheduled in order to receive credit. Late homework will NOT be accepted unless its lateness is due to circumstances beyond your control (official proof is required). To receive full credit, lab reports must be submitted online through Canvas on/before the date due. Late lab reports will be accepted, but points will be deducted from the score (see penalties below).

Lab Assignments and Attendance: Laboratory assignments are a very important component of this course. You will learn to design and develop digital logic circuits, and by the end of the semester, will be able to design sophisticated digital circuits. We use a set of digital tools used by professional engineers, which may appear a bit intimidating at first. After the first two to three labs, you will become comfortable with the tools and will be on your way to designing some interesting circuits.

- You must pass EVERY lab assignment with score > 60% to pass the course.
- Lab board: Online students will receive the board required in the lab from CSU (please watch out for an email from Mr. Brayan Trejo (brayan.trejo@colostate.edu) for shipping information. Students in in-person lab sessions will receive the lab board (do NOT purchase online).
- Lab attendance (online and in-person): Mandatory (TAs will record participation). In rare situations when you cannot attend your scheduled lab session due to circumstances beyond your control, you **must** obtain clearance in advance from your lab instructor (TA). In such a case, you can attend another lab section during that same week **ONLY IF YOU**

**GET APPROVAL FROM YOUR TA**. Remember that all lab projects must be completed with a passing grade in order to pass the course (i.e., >60%).

- Conduct in the lab: Students are expected to maintain a professional working atmosphere in the lab (online and in person), which includes not disturbing other students or groups, not talking loudly, and following additional instructions provided by Teaching Assistants. Use of cellphones (for voice or texting) is not allowed. No food or drinks allowed in C207. TAs are responsible to report any misconduct or unprofessional behavior to the instructor for further actions.
- **Prelab:** Prelabs should be checked at **the beginning of corresponding lab sessions**. This prelab must be included in your lab reports every week.
- Demonstration of hardware circuits & Submitting Project reports: You may submit the hardware demo any time before the start date of the next project for your lab section (online students: Please see Lab Demo Instructions on Canvas). All the lab demos must be presented in person during the lab sessions (or online through YouTube for online students --- Please see the Online Demo Instructions).
- **Policy on collaboration with other students:** Design alone, build alone, write alone, and submit individually prepared reports and circuits. It is fine to talk, give advice, receive advice, but do your own work.
- **Grading policy:** The grading differs from one lab project to the other. An example would be: hardware circuit: 30%, required technical items in the report: 40%, memo text: 20%, instructor discretion: 10%. A neatness bonus of 5% may be assigned. **In addition, you must be able to answer all the questions asked by your TA.**
- **Penalties:** Penalties will be assessed for each lab report (except where specifically allowed): -15% for missing the lab session, -5% for missing prelab, -5%-per-day for late submission, and -10% for not following Banana memo format (https://www.engr.colostate.edu/ECE102/FALL17/LABS/preparingmemo.html).

**Conduct and Nature of Exams:** You will be allowed to use one double-sided page of notes, prepared by you, during the three exams. Exams will be straightforward BUT will demand the kind of preparation only possible through continual, daily study.

**Instructional Objectives:** Given during class, these are the bases of all exam questions and homework assignments. For this reason, **consistent class attendance is very important**.

Textbook: Fundamentals of Logic Design, by Charles H. Roth published by Cengage Learning. The latest is the 7th Edition. Sixth, fifth or fourth editions are acceptable. Some of these earlier editions were published by Thompson Publishing Co. Be aware that there are differences in chapter, page and problem numbers of the different editions. CSU Bookstore carries a paperback version containing the necessary chapters of the 7th edition at а lower price compared to the regular version. It is not critical to have the text during the first week.

**Tutoring:** The course's Graduate Teaching Assistants (TAs) will be available for drop-in consultation as well as help sessions at times listed on the website.

Academic Integrity: This course will adhere to the CSU Academic Integrity Policy as found in the General Catalog (<u>http://www.conflictresolution.colostate.edu/academic-integrity</u>) and the Student Conduct Code (<u>http://www.conflictresolution.colostate.edu/conduct-code</u>). At a minimum, violations will result in a grading penalty in this course and a report to the Office of Conflict Resolution and Student Conduct Services. My policy is that of zero tolerance. Minor first infraction in HWs and Lab reports will lead to a zero score (-40% for Lab assignments) as well as one letter level (e.g., A to B) reduction in the course grade. Project or Major or repeated infractions in HWs and Lab reports will result in "F" grade for the course as well as reporting to the Dean's Office. Any misconduct in an exam (e.g., cheating) will lead to a zero score for that exam, and very likely, course failure.

All submitted work should be your own. Copying of language, structure, images, ideas, or thoughts of another, and representing them as one's own without proper acknowledgement (from web sites, books, papers, other students, solutions from previous offerings of this course, etc.) and failure to cite sources properly is not acceptable. Sources must always be appropriately referenced, whether the source is printed, electronic, or spoken.

**Diversity Statement**: As the instructor in ECE102, I am deeply committed to helping build an inclusive culture in the classroom, in the Department of Electrical and Computer Engineering, in the Walter Scott, Jr. College of Engineering, and at CSU. Each individual brings diversity to our class in the identities they hold, the ways they think, their interests and skills, their background and past experiences. To me, inclusion means not only accepting these differences, but embracing them and understanding that we can leverage these differences to be better engineers.

My goal for this class is to create an environment where we do not discriminate against individuals because of their identities (e.g., race, ethnicity, sex, gender identity, sexual orientation, religion, nationality, age, levels of ability). It is also important to understand that even when we hold egalitarian beliefs, we can hold implicit or unconscious biases that can also influence the way we treat others or approach engineering design. It is my expectation that students in this class will:

- 1. Adhere to the CSU Principles of Community https://diversity.colostate.edu/principles-of-community/;
- 2. Work in teams in ways that recognize the contributions of all team members and provide all team members the opportunity to learn;
- 3. Examine their own behaviors and refrain from acting in biased ways;
- 4. Reflect on the ways bias can influence engineering work;
- 5. Speak with the professor when biased behaviors may occur from other students, their TAs, and the professor;
- 6. Be sensitive to context and acknowledge that hurtful comments can sometimes be inadvertent, but they still have an impact.

# **Important information for students (added based on CSU regulations):**

All students are expected and required to report to the COVID Reporter(https://covid.colostate.edu/reporter/) when:

- You suspect you have symptoms of COVID, regardless of whether or not you are vaccinated and even if your symptoms are mild
- You have tested positive for COVID through a non-CSU testing site, such as home test or test at a pharmacy
- You believe you may have been exposed to COVID go to the COVID Reporter and follow the guidance under "I believe I have been in close contact with someone who has COVID-19." This guidance will depend upon your individual circumstances

#### You will not be penalized in any way for reporting symptoms or concerns.

Do not ask me as your instructor to report for you. It is your responsibility to report through the COVID Reporter promptly.

As your instructor I may not ask you about vaccination status or if you have COVID but you may freely volunteer to send me information from a public health official - if you have been asked to isolate or quarantine.

When you complete the COVID Reporter, the CSU Public Health office is notified. Once notified, that office will contact you and, depending upon each situation, will conduct contact tracing, initiate any necessary public health requirements, and notify you if you need to take any steps. If you do not have internet access to fill out the online COVID-19 Reporter, please call (970) 491-4600.

For the latest information about the University's COVID resources and information, including FAQs about the spring semester, please visit the **CSU COVID-19 site** https://covid.colostate.edu/.

### **CSU Has Resources to Help**

Many of us are struggling. CSU is a community that cares. You are not alone. CSU Health Network Counseling Services has trained professionals who can help. Your student fees provide access to a wide range of support services. Call Counseling Services at (970) 491-6053, and they will work together find which services right with you to out are for you. Visit https://health.colostate.edu/about-counseling-services (Links to an external site.) to learn more and https://health.colostate.edu/mental-health-resources/ (Links to an external site.) for additional student mental health and well-being resources. If you are concerned about a friend or peer, use Tell Someone by calling (970) 491-1350 or visiting https://supportandsafety.colostate.edu/tell-someone/ (Links to an external site.) to share your concerns with a professional who can discreetly connect the distressed individual with the proper resources. Rams Take Care of Rams. Reach out and ask for help if you or someone you know if having a difficult time.

| Week                        | Course Objectives                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Readings       |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| W1 (Jan. 15)                | Introduction to ECE102 and digital systems<br>- State the differences between analog and digital<br>systems                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | N/A            |
| W2 (Jan. 22)                | <ul> <li>Binary representation of information <ul> <li>Define the term "positional number system"</li> <li>Represent numbers in decimal, binary, octal and hexadecimal notations and convert from one notation to the other</li> <li>Add, subtract, multiply and divide binary numbers</li> <li>Represent numbers in sign-magnitude, one's complement and two's complement forms</li> <li>Carry out addition and subtraction, and identify overflow conditions</li> <li>Represent numbers in binary coded decimal format (BCD)</li> <li>Represent characters using ASCII format</li> </ul> </li> </ul>                                       | Ch. 1          |
| W3 (Jan. 29)<br>W4 (Feb. 5) | <ul> <li>Boolean Algebra and Combinational Logic</li> <li>Define the basic logic operations (AND, OR, NOT)</li> <li>Evaluate Boolean expressions</li> <li>Derive the logic function implemented by a combinational logic circuit</li> <li>Use Laws and Theorems of Boolean Algebra to simplify logic expressions</li> <li>Find the complement of a Boolean expression using DeMorgan's Law</li> <li>Find the dual of a Boolean expression</li> <li>State and use the Negative Logic Theorem</li> <li>Use Consensus theorem to simplify logic expressions</li> <li>Implement Boolean expressions using 2-level networks (SOP, POS)</li> </ul> | Ch. 2<br>Ch. 3 |
| W5 (Feb. 12)                | <ul> <li>Convert functional specifications (written in<br/>English) to logic expressions</li> <li>Convert specifications written in English to a truth<br/>table</li> <li>Write a logic expression as a minimum POS,<br/>minimum SOP, canonical POS and a canonical POS</li> <li>Design logic circuits to add/subtract two's<br/>complement numbers</li> <li>Obtain minterm and maxterm expansions (using<br/>m/M notations or in algebraic form) from a truth table</li> </ul>                                                                                                                                                              | Ch. 4          |

**Topics** (Dates/Topics may change with reasonable notice):

|                                | <ul> <li>Convert a minterm expansion it a maxterm<br/>expansion and vice versa</li> <li>Use m/M notation to obtain product/sum of logic<br/>expressions</li> <li>Find the minterm and maxterm expansions of F'.</li> </ul>                                                                                                                                                                                                                                      |        |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
|                                | <ul> <li>F.G, F+G where F, G are Boolean functions Hardware for Arithmetic</li> <li>Design logic circuits to add/subtract two's complement numbers</li> </ul>                                                                                                                                                                                                                                                                                                   |        |
|                                | - Design an array multiplier for binary integers                                                                                                                                                                                                                                                                                                                                                                                                                |        |
| W6 (Feb. 19)                   | <ul> <li>Use don't care terms to simplify logic expressions</li> <li>Represent 3,4,5 and 6 variable functions using K-maps</li> <li>Represent expressions given in SOP, POS, maxterm or minterm form on K-maps</li> <li>Obtain minimum POS and SOP expansions using K-map</li> <li>Design multiple output circuits using K-maps</li> <li>Represent 5 and 6 variable functions using K-maps</li> </ul>                                                           | Ch. 5  |
|                                | and obtain minimum SOP, POS                                                                                                                                                                                                                                                                                                                                                                                                                                     |        |
|                                | Midterm 1 (February 22, 2024)                                                                                                                                                                                                                                                                                                                                                                                                                                   |        |
| W7 (Feb. 26)<br>W8 (Mar. 4)    | - Implement logic functions using multilevel networks<br>- Derive alternative gate symbols for basic logic gates                                                                                                                                                                                                                                                                                                                                                | Ch. 7  |
|                                | - Implement logic functions using basic 2-level<br>forms (NAND-NAND_AND-OR_etc.)                                                                                                                                                                                                                                                                                                                                                                                | Ch. 8  |
|                                | <ul> <li>Convert networks from one form to another</li> <li>Implement logic functions using only NOR gates or<br/>only NAND gates</li> <li>Describe the operation of tri-state logic gates,<br/>multiplexers and decoders</li> <li>Implement logic functions using multilevel networks</li> <li>Design multiple-output circuits</li> <li>Implement combinational logic expressions using<br/>multiplexers, decoders, ROMS and programmable<br/>logic</li> </ul> | Ch. 9  |
| W9 (Mar. 11)                   | Enjoy your spring break! 😂                                                                                                                                                                                                                                                                                                                                                                                                                                      |        |
| W10 (Mar. 18)<br>W11 (Mar. 25) | Sequential Circuits<br>- Describe the operation of S-R, T, D, and J-K latches<br>and flip flops                                                                                                                                                                                                                                                                                                                                                                 | Ch. 11 |
|                                | <ul> <li>- Draw timing diagrams of circuits containing latches<br/>and flip-flops</li> <li>- Draw the circuit diagram, and describe the operation<br/>of registers, shift registers, cyclic shift registers, etc.</li> </ul>                                                                                                                                                                                                                                    | Cn. 12 |

| W12 (Apr. 1)                   | - Analyze Moore and Mealy type sequential networks,                                                                                                                                                                                                                                | Ch. 13 |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| W13 (Apr. 8)                   | <ul> <li>1.e., given a sequential circuit,</li> <li>Derive the state graphs/ state tables of a given sequential circuit</li> </ul>                                                                                                                                                 | Ch. 14 |
|                                | <ul> <li>Draw timing diagrams corresponding to given input waveforms</li> <li>Derive Moore and Mealy type state diagrams to meet given specifications</li> <li>Synthesize Moore &amp; Mealy circuits to meet given specifications using D, T, J-K and/or S-R flip-flops</li> </ul> | Ch. 15 |
| W14 (Apr. 15)<br>W15 (Apr. 22) | <ul> <li>Identify equivalent states and reduce state diagrams<br/>to minimum number of states</li> <li>Determine whether two state diagrams are equivalent</li> <li>Use Alphanumeric Notation in state graphs</li> <li>Verilog</li> </ul>                                          |        |
| W16 (April 29)                 | Review                                                                                                                                                                                                                                                                             |        |
| Thursday –<br>May 9, 2024      | Final Exam<br>6:20 PM to 8:20 PM<br>Biology Room 136                                                                                                                                                                                                                               |        |

# Lab Assignments and Instructions:

- It is essential to read the assignment before the lab and be ready to begin when you come to the lab.
- Report is due in a week.
- Official lab webpage: <u>https://www.engr.colostate.edu/ECE102/Spring24/labs.html</u>.

#### Lab Schedule:

L03: Tuesday, 5:00 PM – 6:40 PM (TA: Asif Mirza) L04: Wednesday 12:00 PM – 01:40 PM (TA: Rashadul Kabir) L05: Thursday 10:00 AM – 11:40 AM (TA: Asif Mirza) L06: Wednesday 08:00 AM – 09:40 AM (TA: Asif Mirza)

| Week                  | Project Description                                                  |  |  |
|-----------------------|----------------------------------------------------------------------|--|--|
| Jan 16 - Jan 22       | Lab 0: Introduction                                                  |  |  |
|                       | Creating an Engineering Network Account                              |  |  |
| Jan 23 - Jan 29       | Lab 1: Introduction to Altera DE board and Quartus II Design         |  |  |
|                       | Software <u>Lab 1 Circuit</u> <u>Lab steps</u> <u>DE0 manual</u>     |  |  |
|                       | The only difference between DE0, DE1 and DE2 implementation is the   |  |  |
|                       | FPGA number and PIN assignments. (Quartus II) software instructions  |  |  |
|                       | remain the same.                                                     |  |  |
| Ion 20 Eab 5          | Lab 2: Schematic Entry, Timing Diagrams and Functional Simulation    |  |  |
| Jan 30 - Feb 3        | using Quartus II                                                     |  |  |
| Feb 6 - Feb 12        | Lab 3: Design, Simulation and Verification of Combinational Circuits |  |  |
| Feb 13 - Feb 19       | Lab 4: Two's Complement Adder Subtractor Design                      |  |  |
| Feb 20 - Feb 26       | Lab 5: The Arithmatic Logic Unit                                     |  |  |
| Feb 27 - Mar 8        | Lab 6: The Seven Segment Display                                     |  |  |
| <b>Mar 9 - Mar 17</b> | Spring Break                                                         |  |  |
| Mar 19 - Mar 25       | Lab 7: BCD to Seven Segment Display                                  |  |  |
| Mar 26 - Apr 1        | Lab 8: Accumulator Based Tally Unit                                  |  |  |
| Apr 2 - Apr 8         | Lab 9: Register Bank and Shift Registers                             |  |  |
| Apr 9 - Apr 15        | Lab 10: Design of Counters                                           |  |  |
| Apr 16 - Apr 22       | Lab 11: Encryption Unit                                              |  |  |
| Apr 23 - Apr 29       | Lab 12: Nanoprocessor                                                |  |  |