Course Outline
Official outline
The official COMP1521 course outline can be found on the UNSW course outline finder. Below is an alternate version of the course outline, which contains the same information with some additional details.
Contents
- Course Details
- Course Summary
- Teaching Strategies and Rationale
- Student Conduct and Academic Integrity
- Assessment
- Course Schedule
- Resources for Students
- Course Evaluation and Development
Course Details
Course Code | COMP1521 |
---|---|
Course Title | Computer Systems Fundamentals |
Units of Credit | 6 |
Course Contact | <cs1521@cse.unsw.edu.au> This is the primary contact point for all course-related enquiries. Please not not email individual course staff members directly. |
Course Staff |
Lecturer: Hammond Pearce
<hammond.pearce@unsw.edu.au>
Administrator: Xavier Cooney <x.cooney@unsw.edu.au>
Administrator: Abiram Nadarajah <a.nadarajah@unsw.edu.au>
|
Classes | Lectures: A: Mon 14:00—16:00; WEB1: Mon 14:00—16:00; B: Wed 11:00—13:00; WEB2: Wed 11:00—13:00; Tutorials and Labs: ... timetable for all classes |
Course Website | https://cgi.cse.unsw.edu.au/~cs1521/24T2/ |
Course Forum | https://edstem.org/au/courses/16587/discussion/ |
Handbook Entry | https://www.handbook.unsw.edu.au/undergraduate/courses/current/COMP1521/ |
Course Summary
This course introduces students to how computer systems are structured in terms of basic electronic components, how they are used to implement procedural programs, and how they are structured as a collection of software layers. It introduces students to low-level software layers such as operating systems, and introduces concurrency concepts. The goal is to give students a solid understanding of what happens when high-level programs are executed, as a basis for further study in important areas of computing such as computer architecture, operating systems.
Assumed Knowledge
Before commencing this course, students should be able to ...
- write simple programs in the C programming language
- define and invoke functions and return results in C
- define and manipulate structured data in C
- use pointers to access data objects
These are assumed to have been acquired in COMP1511 or COMP1911.
Learning Outcomes
After completing this course, students will be able to ...
- Describe the architectural layers (fundamental parts) of a modern computer systems from hardware device (chip) levels upwards
- Describe the principles of memory management and explain the workings of a system with virtual memory management
- Explain how the major components of a CPU work together, including how data and instructions are represented in a computer
- Design, implement, and analyse small programs at the assembly/machine level
- Describe the relationship between a high-level procedural language (C) and assembly (machine language) which implements it, including how a compiled program is executed in a classical von Neumann machine
- Explain how input/output operations are implemented, and describe some basic I/O devices
- Describe the components comprising, and the services offered by, an operating system
- Implement simple programs involving communication and concurrency
This course contributes to the development of the following graduate capabilities:
Graduate Capability | Acquired in |
---|---|
scholarship: understanding of their discipline in its interdisciplinary context | lectures, assignments |
scholarship: capable of independent and collaborative enquiry | lab work, assignments |
scholarship: rigorous in their analysis, critique, and reflection | tutorials |
scholarship: able to apply their knowledge and skills to solving problems | tutorials, lab work, assignments |
scholarship: ethical practitioners | all course-work, by doing it yourself |
scholarship: capable of effective communication | tutorials |
scholarship: digitally literate | everywhere in CSE |
leadership: enterprising, innovative and creative | assignments |
leadership: collaborative team workers | lab work, assignments |
professionalism: capable of operating within an agreed Code of Practice | all prac work |
Teaching Strategies and Rationale
This course uses the standard set of practice-focussed teaching strategies employed by most CSE foundational courses:
- Lectures … introduce concepts, show examples
- Tutorials … reinforce concepts and provide additional examples
- Lab Work … provide examples of using various technologies
- Assignments … allow you to solve larger problems
Having said that, the second half of the course is more discursive than other CSE foundational courses.
This course is taught the way it is because it aims to give a broad view of many topics in computer systems, to provide a foundation for further study in later systems-related courses. At the same time, it provides further practice in developing software, but at a level closer to the machine than other foundational courses.
Lectures
Lectures will be used to present the theory and practice of the techniques and tools in this course. The lectures will include practical demonstrations of various technologies. Lecture notes will be available on the course web pages before each lecture.
All lectures will be in-person, but with no live-streaming. During lectures, discussion and questions are welcome from people attending the lectures via the lecture chat system.
Recording of all lectures will be made available via YouTube. Lectures may be pre-recorded on some topics.
Tutorials
From week 1, you will also be expected to participate a one-hour tutorial session to clarify ideas from lectures and work through exercises based on the lecture material. You should make sure that you use tutorials effectively by examining in advance the material to be covered in each week's tutorial, by asking questions, by offering suggestions, and by generally participating. The tutorial questions will be posted on the Web in the week before each tutorial. There are no marks for tutorial participation.
Most tutorial and laboratory classes are running face-to-face. Please ensure you follow UNSW's Safe Return to Campus guidance.
Some tutorial classes (and laboratories) will run online via Blackboard Collaborate. A link on Moodle will take you to Blackboard Collaborate, where you will find a list of tutorial classes.
Laboratory Classes
Following the tutorial class each week, there will be a two-hour laboratory class, during which you will work on a variety of small practical problems involving the tools introduced in lectures. Because this course has a significant practical component, laboratory classes are important. If you do not put a good amount of effort into the lab classes, you risk failing the final exam.
Each week, there will be one or more exercises to work on. These exercises will be released in the week preceding the lab class.
During the lab, your tutor will provide feedback on your approach to the problem and on the style of your solution. Some labs may contain exercises which will be assessed during the lab.
Completed exercises need to be submitted. You must submit exercises before the deadline using give to obtain a mark for a lab exercise, The usual lab exercise submission deadline will be 12:00 (midday) Monday some lab exercises may have an extended deadline
The lab exercises for each week are worth in total 2 marks. All of your lab marks will be summed to give you a mark out of 18; if their sum exceeds 15, your total mark will be capped at 15.
Most labs include one or more challenge exercises. Challenge exercises may involve concepts not covered in lectures and they range in difficulty from not-very-hard to almost-impossible.
The contribution of challenge exercises to lab marks will be limited to 20%; hence you can obtain nearly all (over 95%) marks available for the lab component without completing challenge exercises.
If you wish to obtained a high mark for COMP1521, attempting some challenge exercises is highly recommended.
If your goal is just to master the core material and pass COMP1521, you can ignore challenge exercises.
Assignments
There are two assessable programming assignments. Assignments give you the chance to practice what you have learnt on relatively large problems (compared to the small exercises in the labs). Assignments are a very important part of this course, therefore it is essential that you attempt them yourself.
- Assignment 1, on Assembly programming (MIPS); due Friday Week 5; worth 15%
- Assignment 2, on System programming; due Monday Week 10; worth 15%
Late assignments submissions will be penalised. The exact penalty will be the standard UNSW late penalty of a mark reduction equal to 5% of the achieved (raw) assessment mark per day late, or a zero mark after 5 days (i.e. 120 hours).
Weekly Tests
There will be weekly tests from weeks 3–10 designed to give you timely and realistic feedback of your understanding of the course material. Tests may be programming exercises, multiple choice questions, or both.
These will be conducted in your own time under self-enforced exam-like conditions. Each test will specify the conditions, but typically these will include:
- no assistance permitted from any person;
- a time limit;
- no access to materials (written or online) except specified language documentation or man pages.
Each test is worth 1.7 marks, and will be automarked. Your total mark for the tests component is computed as a sum of your best 6 of 8 test marks.
Final Exam
There will be a three-hour final exam, held in the CSE labs during the exam period. This will be centrally timetabled, and appear in your UNSW exam timetable.During this exam you will need to execute, debug and test your answers to implementation tasks which will be similar to those encountered in lab exercises and weekly tests.
There is a hurdle requirement on the final exam. If you do not score at least 40% (18.0/45) on the exam (after scaling), you cannot pass this course. If your overall course score exceeds 50%, despite scoring very poorly (<40%) on the exam, the hurdle will be enforced via a grade of UF.
Student Conduct and Academic Integrity
Student Conduct
The Student Code of Conduct (Information, Policy) sets out what the University expects from students as members of the UNSW community. As well as the learning, teaching and research environment, the University aims to provide an environment that enables students to achieve their full potential and to provide an experience consistent with the University's values and guiding principles. A condition of enrolment is that students inform themselves of the University's rules and policies affecting them, and conduct themselves accordingly.
Students have the responsibility to observe standards of equity and respect in dealing with every member of the University community. This applies to all activities on UNSW premises and all external activities related to study and research. This includes behaviour in person as well as behaviour on social media: for example, in Facebook groups set up for the purpose of discussing UNSW courses or course work. Behaviour that is considered in breach of the Student Code Policy as discriminatory, sexually inappropriate, bullying, harassing, invading another's privacy, or causing any person to fear for their personal safety is serious misconduct, and can lead to severe penalties, including suspension or exclusion.
If you have any concerns, you may raise them with your lecturer, or approach the School Ethics Officer, Grievance Officer, or one of the student representatives.
Academic Integrity
UNSW has an ongoing commitment to fostering a culture of learning informed by academic integrity. All UNSW staff and students have a responsibility to adhere to this principle of academic integrity.
Use of Generative Tools in COMP1521
Systems such as Github Copilot and ChatGPT based on large language models or other generative artificial intelligence techniques, look likely to become heavily used by programmers.However, you need a good understanding of the language you are coding in and the systems involved before you can effectively use these tools.
Using these tools will hinder your learning in COMP1521 so we are prohibiting their use in COMP1521.
You are not permitted to use generative tools such as Github Copilot, ChatGPT, Google Bard in COMP1521, including when working on lab exercises, assignments and weekly tests. These tools will not be available in the exam environment.
Use of Github Copilot, ChatGPT, Google Bard and similar tools will be treated as academic misconduct and subject to the standard penalties, which may include 00FL, suspension and exclusion.
Assessment
Plagiarism is defined as using the words or ideas of others and presenting them as your own. Plagiarism undermines academic integrity, and is not tolerated at UNSW. Instances of plagiarism are treated by UNSW and CSE as acts of academic misconduct, which carry penalties as severe as being excluded from further study at UNSW. There are several on-line resources to help you understand what plagiarism is and how it is dealt with at UNSW.Make sure that you read and understand these. Ignorance is not accepted as an excuse for plagiarism. In particular, at CSE you are responsible for ensuring that your assignment files are not accessible by anyone but you by setting correct permissions in your CSE home directory and for any code repositories you may use. Note also that plagiarism includes paying or asking another person to do a piece of work for you, and then submitting it as your own work.
The pages below describe the policies and procedures in more detail:
Assessment
Item | Topics | Due | Marks | LOs |
---|---|---|---|---|
Tests | all topics | Weeks 3-10 | 10 | 1-9 |
Assignment 1 | Assembly programming (MIPS) | Friday Week 5 | 15 | 4 |
Assignment 2 | System programming | Monday Week 10 | 15 | 2,5 |
Labs | all topics | Week 1-10 | 15 | 1-5,9 |
Final Exam | all topics | exam period | 45 | 1-9 |
Your final mark for this course will be computed using the above assessments as follows:
CourseWorkMark | = | TestMark + LabMark + Ass1Mark + Ass2Mark | out of 55 |
ExamMark | out of 45 | ||
ExamOK | = | ExamMark ≥ 18.0/45 | true/false |
FinalMark | = | CourseWorkMark + ExamMark | out of 100 |
FinalGrade | = | UF, if ! ExamOK && FinalMark ≥ 50
FL, if FinalMark < 50/100 PS, if 50/100 ≤ FinalMark < 65/100 CR, if 65/100 ≤ FinalMark < 75/100 DN, if 75/100 ≤ FinalMark < 85/100 HD, if FinalMark ≥ 85/100 |
Course Schedule
The following is a rough schedule of when topics will be covered. This will most likely change over the session as topics take more or less time to cover.
Week | Lectures | Tut/Lab | Assigns | Tests |
---|---|---|---|---|
1 | course intro; MIPS assembly programming | C revision | - | - |
2 | MIPS assembly programming | MIPS assembly programming | - | - |
3 | MIPS assembly programming | MIPS assembly programming | assignment 1 released | test 1 released (due week 4) |
4 | MIPS assembly programming | MIPS assembly programming | - | test 2 released (due week 5) |
5 | Bit manipulations; Integer representations | MIPS assembly programming | assign 1 due Friday | test 3 released (due week 7) |
6 | flexibility week | - | - | test 4 released (due week 7) |
7 | IEEE-754; UTF-8 | Bit manipulations; Integer representations | assignment 2 released | test 5 released (due week 8) |
8 | file metadata; file systems | IEEE-754; UTF-8 | - | test 6 released (due week 9) |
9 | concurrency, parallelism, threads | manipulating files, metadata, and directories | - | test 7 released (due week 10) |
10 | hardware caching, final exam | using threads in C | assignment 2 due Monday | test 8 released (due week 11) |
Resources for Students
There is no single book that covers all of the material in this course at the right level of detail and using the same technology base as we are. The lecture notes should provide sufficient detail to introduce topics, and you will then study them in further depth in the tutes, labs and assignments.
There are also many online resources available, and we will provide links to the most useful ones. Some are listed below. If you find others, please post links in the Comments section on the Course Outline page.
The following is a Recommended Reading for this course:
- Computer Systems: A Programmer's Perspective, by Randal E. Bryant and David R. O'Hallaron; Prentice-Hall (web site)
There are copies in the UNSW Bookstore and in the library. It covers many of the topics in the course, but uses a different machine architecture (i.e., not MIPS).
Some suggestions for other books that cover at least some of the topics in this course:
- Introduction to Computer Systems: From Bits and Gates to C and Beyond, by Yale N. Patt and Sanjay J. Patel; McGraw Hill
- The Elements of Computing Systems: Building a Modern Computer from First Principles, by Noam Nisan and Shimon Schocken; MIT Press (web site, including lecture slides)
Documentation for the various systems used in the course is linked from the course website.
Course Evaluation and Development
Every term, student feedback is requested in a survey using UNSW's myExperience online survey system where the feedback will be used to make improvements to the course.
Students are also encouraged to provide informal feedback during the session, and to let course staff know of any problems as soon as they arise. Suggestions will be listened to openly, positively, constructively, and thankfully, and every reasonable effort will be made to address them.
This course has previously run in 17s2, 18s1, 18s2, 19T2, 19T3, 20T2, 20T3, 21T2, 21T3, 22T1, 22T2, 22T3, 23T1, 23T2, and 23T3.
We have read carefully the myExperience feedback from 23T3 and in response have made changes to the delivery:
- coming soon!