Course Syllabus
Course Overview
In this course, we will study topics in computer systems architecture. We will first discuss the contents in Appendix A through C of the text (pipelining, instruction set principles, and memory hierarchy). Then, we will switch to other topics such as superscalar execution, branch prediction, dynamic scheduling, multithreading support, shared memory architecture, and storage systems. See here to check the prerequisites and restrictions for this course.The course Piazza page is your best source for the course information. TA office hours, additional resources and essential course information will appear on Piazza, and all course-related questions will also be answered on Piazza to ensure all students have equal access to the information.
Course Topics
Following topics will be covered in this course (subject to change).- Introduction to computer architecture
- Instruction set architecture
- Pipelining
- Memory hierarchy
- Instruction-level parallelism (Loop unrolling, Branch prediction, Tomasulo)
- Thread-level parallelism
- Data-level parallelism
- Shared-memory architecture
Administrative Information
- Instructor: Dr. Ilchul Yoon (Office: IRB 1248)
- Lecture hours: TuTh 11:00am - 12:15pm
- Classroom: CSI 1121
- TA: Goonwanth Reddy, Rohan Dixit, Yunhan Bai (Office: AVW 4101 or 4103)
Textbook
Computer
Architecture: A Quantitative Approach, Hennessy and Patterson,
5th Edition (CAQA, H+P)
Publisher: Morgan Kaufmann
ISBN-13:
978-0123838728
ISBN-10: 012383872X
Grading
|
Online-Posting of Your Project Implementations is Not Allowed
- Do not post your assignments' implementation online (e.g., GitHub) where they can be seen by others.
- Making your code accessible to others can lead to academic integrity violations. Even if the course is over, do not make your code available to others.
Academic Integrity
Note that academic dishonesty includes not only cheating, fabrication, and plagiarism, but also includes helping other students commit acts of academic dishonesty by allowing them to obtain copies of your work. In short, all submitted work must be your own.
Cases of academic dishonesty will be pursued to the fullest extent
possible as stipulated by the Office
of Student Conduct.
It is very important for you to be aware of the consequences of cheating, fabrication, facilitation, and plagiarism. If the student is found to be responsible of academic dishonesty, the typical sanction results in a special grade "XF", indicating that the course was failed due to academic dishonesty. If you have any doubt as to whether an act of yours might constitute academic dishonesty, please contact your TA or the course coordinator.
For more information on the Code of Academic Integrity or the Student Honor Council, please visit http://www.shc.umd.edu.
Examples of Academic Integrity Violations
The following are examples of academic integrity violations:
- Hardcoding of results in a project assignment. Hardcoding refers to attempting to make a program appear as if it works correctly (e.g., printing expected results for a test).
- Using any code available on the internet/web or any other source. For example, using code from Sourceforge.
- Hiring any online service to complete an assignment for you.
- You may not post the implementation of your assignments, materials related to the class (e.g., project description), or any other material associated with this course. Even if the class is over and you have graduated, you may NOT post any material. If you do, you might be violating academic integrity rules and copyrights.
- Discussing project implementations (everything beyond clarifications) with your classmates.
- Sharing your code with any student.
- Providing ideas/suggestions on how to solve/implement a programming assignment.
- Looking at another student's code.
- Using online forums to ask for help regarding our assignments.
Additional information can be found in the sections titled "Academic Integrity" and "Code of Student Conduct" available at Course Related Policies.
Disabilities Support Accommodations
In case academic accommodations are needed, you must provide a letter of accommodation from the Office of Accessibility and Disability Services (ADS) within the first TWO weeks of the semester. For details, see the section titled "Accessibility" available at Course Related Policies.
Excused Absence and Academic Accommodations
The university allows for self-documentation for some absences. If you
need to be excused for an absence from a single lecture, recitation, or
lab due to your illness (or other reasons), you shall make a reasonable
attempt to report prior to the class. (Use the absence report feature in
the grade server).
Upon returning to the class, present with
a self-signed note attesting to the date of your illness (or other
reasons). Each note must contain an acknowledgment by the student that
the information provided is true and correct. Providing false
information to University officials is prohibited under Part 9(i) of the
Code of Student Conduct (V-1.00(B) University of Maryland Code of
Student Conduct) and may result in disciplinary action.
Self-documentation may NOT be used
for the midterm exams and the final exam, and it may only
be used for only 1 class meeting (or more, if you choose) during the
semester. Any student who needs to be excused for a prolonged absence (2
or more consecutive class meetings), or for the exams, must provide
written documentation of the illness from health care provider. This
documentation must clearly recommend the student to be off from all
school work and indicate the time frame (from/to dates) that the
student is unable to meet academic responsibilities. In addition, it
must contain the name and phone number of the medical service
provider to be used if verification is needed. No diagnostic
information will ever be requested. Note that the "Medical Discharge
Summary" from the Health Center will NOT be accepted as evidence of
doctor's recommendation for your absence.
For
additional details, see the section titled "Attendance, Absences, or
Missed Assignments" available at Course
Related Policies
Course Evaluations
The department and faculty take student feedback seriously. At the end of the course visit https://www.courseevalum.umd.edu/ to complete your course evaluations.
Miscellaneous
Although every effort has been made to be complete and accurate, unforeseen circumstances arising during the semester could require the adjustment of any material given here. Consequently, given due notice to students, the instructor reserves the right to change any information on this syllabus or in other course materials.
Copyright
All course materials are copyright UMCP, Department of Computer Science © 2019. All rights reserved. Students are permitted to use course materials for their own personal use only. Course materials may not be distributed publicly or provided to others (excepting other students in the course), in any way or format. Although every effort has been made to be complete and accurate, unforeseen circumstances arising during the semester could require the adjustment of any material given here. Consequently, given due notice to students, the instructor reserves the right to change any information on this syllabus or in other course materials.