Unit convenor and teaching staff |
Unit convenor and teaching staff
Richard Han
Lachlan Patrick
|
---|---|
Credit points |
Credit points
10
|
Prerequisites |
Prerequisites
COMP1010
|
Corequisites |
Corequisites
|
Co-badged status |
Co-badged status
COMP6100
|
Unit description |
Unit description
This unit studies the boundary between software and the systems on which software executes. It considers the impact of constraints imposed by operating systems and hardware systems on the design and performance of computer software. Students will learn how to operate within these constraints to build effective systems software. The unit studies these issues by looking below the abstractions provided by high-level programming languages. The unit is an introduction to systems programming and related issues. It provides an entry point into more advanced study of computer systems in the following areas: hardware implementation, operating systems, network design and programming, and programming language design and implementation. Learning in this unit enhances student understanding of global challenges identified by the United Nations Sustainable Development Goals (UNSDGs) Industry, Innovation and Infrastructure |
Information about important academic dates including deadlines for withdrawing from units are available at https://www.mq.edu.au/study/calendar-of-dates
On successful completion of this unit, you will be able to:
Grading Requirements
The assessment has three components: the two programming tasks, and the final exam. The final mark for the unit will be calculated by combining the marks for all assessment tasks according to the percentage weightings shown in the assessment summary.
Requirements to Pass this Unit
To pass this unit you must:
Throughout the semester you will engage in two programming tasks that are assessed individual work. These tasks develop your skills and assess your progress. These programming tasks are to be done in your own time, but you may also use workshop time to work on them and to seek assistance from the teaching staff. They are due as specified on iLearn for each task.
The programming tasks are designed to be completed over several weeks. Do not leave them until the last week.
Release Dates
Programming Task 1 will be released no later than 1 August (Friday of Week 1).
Programming Task 2 will be released no later than 12 September (Friday of Week 7).
The programming tasks are set as individual work and each one is personalised for a particular student.
The University's academic honesty policy will be enforced. You may assist your fellow students with general concepts, pointers to resources and useful tools or commands that are publicly available. You may not become involved in any way in helping a fellow student to find the solution to their particular task, nor may you share with them any aspect of the solution of your particular task. If you decide to develop or modify a tool (including software tools, procedures or methods) to assist you in solving your programming task, you may not provide that tool to your fellow students, nor may you publish it. Each practical task will include additional specific instructions to help you understand what is acceptable and what is not.
Each programming task must be the sole work of the student turning it in. Any cheating will be handled under the University's Academic Honesty Policy.
The following are guidelines on what collaboration is allowed for programming tasks and what is not [adapted from CS:APP website]
Be sure to store your work in protected directories, and log off when you leave any lab computer, to prevent others from copying your work without your explicit assistance.
Submission instructions for programming tasks will be provided on iLearn. The two tasks contain differing forms of automatic assessment and feedback tools that will assist you during the task. The automated feedback will help you identify your mistakes, but does not replace your own analysis of the problem, debugging and testing. The automated assessment contributes strongly to our understanding of your performance in the task.
Each programming task will specify a particular due date. The due time will be 11:55pm on the due date unless otherwise specified.
Submissions in Data File Lab are made through the lab command; submissions in Binary Bomb Lab are made automatically as you progress through the task of analysing and executing the "binary bomb" program.
If you experience serious and unavoidable difficulties that affect your ability to meet the due dates for progress or the closing date of a programming task, you may apply for special consideration as explained at https://students.mq.edu.au/study/my-study-program/special-consideration. If the request is accepted, the action may be to grant an extension of the relevant due date(s), or it may be to require you to submit an alternative assessment item. Extensions, if granted, are managed through the automated assessment system that you access via the lab command.
If you apply for special consideration, please note:
For any late submission of time-sensitive tasks, such as scheduled tests/exams, performance assessments/presentations, and/or scheduled practical assessments/labs, students need to submit an application for Special Consideration.
Our Late policy is summarized below.
Assessments where Late Submissions will be accepted
In this unit, late submissions will be accepted as follows:
Assessment Tasks
Name | Weighting | Due | |
---|---|---|---|
Final Examination | 40% | In exam period | |
Data File Lab | 30% | Sun 7 September 23:55 | |
Binary Bomb Lab | 30% | Sun 2 November 23:55 |
Assessment Type 1: Examination Indicative Time on Task 2: 26 hours. Due: In exam period. Weighting: 40%
Online examination
On successful completion you will be able to:
Assessment Type 1: Programming Task. Indicative Time on Task 2: 30 hours. Due date: see table. Weighting: 30%.
Develop C programs to manipulate data files.
On successful completion you will be able to:
Assessment Type 1: Programming Task. Indicative Time on Task 2: 30 hours. Due date: see table. Weighting: 30%.
Use debugging tools to understand the behaviour of a precompiled program. Find input strings that will be acceptable to the program (i.e. defuse the binary bomb).
On successful completion you will be able to:
1 If you need help with your assignment, please contact:
2 Indicative time-on-task is an estimate of the time required for completion of the assessment task and is subject to individual variation
Name | Weighting | Hurdle | Due |
---|---|---|---|
Final Examination | 40% | No | Exam Period |
Binary Bomb Lab | 30% | No | November 2, 23:55 pm |
Data File Lab | 30% | No | September 7, 23:55 pm |
Assessment Type 1: Examination
Indicative Time on Task 2: 26 hours
Due: Exam Period
Weighting: 40%
Written examination
Assessment Type 1: Programming Task
Indicative Time on Task 2: 30 hours
Due: November 2, 23:55 pm
Weighting: 30%
Use debugging tools to understand the behaviour of a precompiled program. Find input strings that will be acceptable to the program (i.e. defuse the binary bomb).
Assessment Type 1: Programming Task
Indicative Time on Task 2: 30 hours
Due: September 7, 23:55 pm
Weighting: 30%
Develop C programs to manipulate data files.
1 If you need help with your assignment, please contact:
2 Indicative time-on-task is an estimate of the time required for completion of the assessment task and is subject to individual variation
We introduce the class, go over the unit guide, and begin delivering technical content in the lecture and workshops. Workshops start in Week 1.
"Computer Systems: A Programmer's Perspective" 3rd edition, R.E. Bryant and D.R. O'Hallaron, Pearson 2015.
You are required to read set sections of the text book each week. The text book is available in electronic form in the library, or you can purchase a printed copy from a book seller of your choice.
"The C Programming Language" 2nd edition, Brian W Kernighan and Dennis M Ritchie, Prentice-Hall 1988.
This small book is the classic reference on C programming.
All learning materials will be published on iLearn including lecture slides, programming tasks and other explanatory documentation. We will also be making key announcements via iLearn as well as answer questions in the unit's Forum.
Lectures are a core learning experience where we will discuss the theoretical underpinnings and concepts that are essential to this unit. Key ideas for the programming tasks will be discussed from time to time in lectures.
Lectures will be provided in person. Participation in lectures is not required but is highly recommended. Lecture recordings will be provided on echo360.
Each week it is important to attend your workshop. We will be using the workshop to cover important concepts that may be useful to solving weekly questions, programming/lab issues, and/or exam questions. Workshops also provide an opportunity to discuss specific questions related to any aspect of the unit: the lecture content, the programming tasks and the set practical questions.
Workshops provide an opportunity for you to develop your skills in systems programming and your understanding of the key concepts of the unit. Workshops combine discussion with practical programming experience. Your workshop teaching staff will provide you with individual assistance and may also from time to time address the entire class to provide useful information to assist with programming tasks.
A forum for unit discussions is provided on iLearn. Students are free to post questions, comments or hints in relation to any aspect of the unit, except that you should avoid posting any questions, hints, comments or solutions that could be interpreted as cheating (see above). Civility is essential in all such postings and interactions.
Don't post your code, or anyone else's code, on the forums!
If you see a post from another student that appears to be cheating, please email the senior TA (to be specified on iLearn), and we will remove the offending post.
Apart from contacting teaching staff in-person before/after the lecture and/or workshops, and at a pre-arranged time, the main way of communication is via the iLearn forums. For general administrative questions relating to the unit, personal queries, etc. please email the lecturers and the Senior TA for the unit. Clearly identify in the title of your email "COMP 2100: ".
For specific technical questions, first contact your TA, use the Unit Forum and/or use either the announced weekly consultations time for the Senior TA in COMP2100, or the School of Computing's Drop-In Centre. If your technical question still cannot be resolved, email the convenor.
The detailed unit schedule will be available on iLearn. The unit is roughly organised as follows:
Week 1-6: C programming, Command line interface, Data representations (integer and float), some system API.
Weeks 7-12: Assembly code and how C programs appear in the machine, Operating System features and implementation.
Macquarie University policies and procedures are accessible from Policy Central (https://policies.mq.edu.au). Students should be aware of the following policies in particular with regard to Learning and Teaching:
Students seeking more policy resources can visit Student Policies (https://students.mq.edu.au/support/study/policies). It is your one-stop-shop for the key policies you need to know about throughout your undergraduate student journey.
To find other policies relating to Teaching and Learning, visit Policy Central (https://policies.mq.edu.au) and use the search tool.
Macquarie University students have a responsibility to be familiar with the Student Code of Conduct: https://students.mq.edu.au/admin/other-resources/student-conduct
Results published on platform other than eStudent, (eg. iLearn, Coursera etc.) or released directly by your Unit Convenor, are not confirmed as they are subject to final approval by the University. Once approved, final results will be sent to your student email address and will be made available in eStudent. For more information visit connect.mq.edu.au or if you are a Global MBA student contact globalmba.support@mq.edu.au
At Macquarie, we believe academic integrity – honesty, respect, trust, responsibility, fairness and courage – is at the core of learning, teaching and research. We recognise that meeting the expectations required to complete your assessments can be challenging. So, we offer you a range of resources and services to help you reach your potential, including free online writing and maths support, academic skills development and wellbeing consultations.
Macquarie University provides a range of support services for students. For details, visit http://students.mq.edu.au/support/
Academic Success provides resources to develop your English language proficiency, academic writing, and communication skills.
The Library provides online and face to face support to help you find and use relevant information resources.
Macquarie University offers a range of Student Support Services including:
Got a question? Ask us via the Service Connect Portal, or contact Service Connect.
For help with University computer systems and technology, visit http://www.mq.edu.au/about_us/offices_and_units/information_technology/help/.
When using the University's IT, you must adhere to the Acceptable Use of IT Resources Policy. The policy applies to all who connect to the MQ network including students.
Changes from the prior offering include the following:
Remove mid-semester exam
Remove Lab assignment 2's assembly language Mastery Quiz
Create cumulative Final exam
Remove progress marks from lab assignments 1 and 2
Add Lab 2 viva
Remove weekly quizzes
Reduce the number of free extensions for labs
Remove hurdle requirement based on two labs
Unit information based on version 2025.06 of the Handbook