Love 103
12:20PM -- 1:10PM, MWF
This course provides an introduction to the advanced programming in the Unix environment. Topics to be covered include: concurrent programming with processes and threads, file systems, advanced (both blocking and non-blocking) I/O, signals, inter-process communications and synchronization, network programming, broadcast and multicast, client-server and peer-to-peer paradigm, among others. This course is meant for graduate students having substantial programming experience. In this course, you will acquire training in good programming techniques, while learning important programming topics in a Unix environment.
At the end of this course, you should be able to
- Use standard UNIX operating system API's
- Develop concurrent programs with processes and threads
- Develop network programs
- Write portable programs
- Proficient in C/C++ (If you are not comfortable with the pointers in C, you are NOT ready for this class. )
- COP 4610 Operating Systems or equivalent
- User-level knowledge of UNIX and comfortable working in a Unix environment
- Having completed CNT5505 (Data and Computer Communications) or CNT 4504 (Introduction to Computer Networks) is a significant advantage.
Talk to me if you are not positive.
- Required textbook
- ``Unix Network Programming, Volume 1: The Socket Networking API,'' Third Edition. By W. Rickard Stevens, Bill Fenner, and Andrew M. Rudoff. Addison-Wesley. 2004. ISBN 0-13-141155-1.
This text gives a very detailed explanation of UNIX network applications programming and along the way covers most other aspects of the UNIX applications programming, such as process creation, job control, signals, and I/O. However, the coverage of network programming is more detailed than we will need for this course, and the coverage of other aspects of the UNIX API is more diffuse than would be ideal for this course. However, there is probably no other book that would be better, and this is an excellent reference book. In class, we will only approximately follow the order or presentation of topics of the textbook, but you will be expected to read the entire book in parallel. In class we will digress from the text to fill in some background information on some aspects of the UNIX API earlier than they appear in the book.
- Recommended textbooks:
- "Advanced Programming in the Unix Environment", Second Edition. By W. Richard Stevens and Stephen A. Rago, Addison Wesley. 2008
- "The C Programming Language", by Kernighan and Ritchie.
- Two individual programming projects: 35%
- One term group project: 20%
- One mid-term exam: 20%
- One final exam: 25%
Grading of programming assignments will be based not only on functionality, portability, and correctness, but also on your understanding of your program. Individual programming assignment should be implemented using C/C++.
Each group for the term group project consists of up to 3 students. The project topic can be either selected by the group with the approval of the instructor or obtained from the instructor. Each project should have substantial software development or analysis components, where the knowledge acquired in this class can be applied. The project will be graded based on the final software developed, the presentation, and demo at the end of the semester. Group projects can be implemented using C/C++, Java, Perl, or Python.
A [91-100] A- [88-91) B+ [85-88) B [82-85) B- [79-82) C+ [76-79) C [73-76) C- [70-73) D [60-70) F <60
Attendance Policy:
The university requires attendance in all classes, and it is also important to your learning. The attendance record may be provided to deans who request it. If your grade is just a little below the cutoff for a higher grade, your attendance will be one of the factors that we consider, in deciding whether to "bump" you up to the higher grade. Missing three or fewer lectures will be considered good attendance.Excused absences include documented illness, deaths in the immediate family and other documented crises, call to active military duty or jury duty, religious holy days, and official University activities. Accommodations for these excused absences will be made and will do so in a way that does not penalize students who have a valid excuse. Consideration will also be given to students whose dependent children experience serious illness.
You should let me know in advance, when possible, and submit the documentation I seek if you miss a class. You should make up for any materials missed due to absences.
Missed exam Policy:
A missed exam will be recorded as a grade of zero. We will follow the university rules regarding missed final exams (see http://registrar.fsu.edu/dir_class/fall/exam_schedule.htm), for all the exams, including the final exam.
Late Assignment Policy:
In order to enable us to provide timely solutions to assignments, we have the following policy regarding submission of late assignments.
- An assignment that is turned in no more than 24 hours late will be scored with a 10% penalty.
- An assignment that is turned in more than 24 and no less than 48 hours late will be scored with a 20% penalty.
- An assignment that is turned in more than 48 hours late will receive the score of zero, though we will review it and comment on it.
Incomplete Grade (Grade of 'I') Policy:
The grade of 'I' will be assigned only under the following exceptional circumstances:
- The final exam is missed with an accepted excuse for the absence. In this case, the final exam must be made up during the first two weeks of the following semester.
ACADEMIC HONOR POLICY:
The Florida State University Academic Honor Policy outlines the University's expectations for the integrity of students' academic work, the procedures for resolving alleged violations of those expectations, and the rights and responsibilities of students and faculty members throughout the process. Students are responsible for reading the Academic Honor Policy and for living up to their pledge to . . . be honest and truthful and . . . [to] strive for personal and institutional integrity at Florida State University. (Florida State University Academic Honor Policy, found at http://dof.fsu.edu/honorpolicy.htm.)AMERICANS WITH DISABILITIES ACT (ADA):
Students with disabilities needing academic accommodation should:
(1) register with and provide documentation to the Student Disability Resource Center; and
(2) bring a letter to the instructor indicating the need for accommodation and what type. This should be done during the first week of class.This syllabus and other class materials are available in alternative format upon request.
For more information about services available to FSU students with disabilities, contact the:
Student Disability Resource Center
874 Traditions Way
108 Student Services Building
Florida State University
Tallahassee, FL 32306-4167
(850) 644-9566 (voice)
(850) 644-8504 (TDD)
(850) 644-7164
sdrc@admin.fsu.edu
http://www.disabilitycenter.fsu.edu/
Academic Integrity:
Remember that the goal of programming assignments and homeworks is to enhance your analysis, reasoning, and programming skills. Indulging in academic dishonesty defeats this purpose apart from being unfair to other students. In case you have any questions about whether an act of collaboration may be construed as academic dishonesty, please clarify the issue with the instructor before you collaborate.
All students should follow FSU Academic Honor Code. You might be assigned a grade of 'F', if you are found to have indulged in academic dishonesty.
It is understandable that discussing a problem with other people may lead to more insight into the issues involved. Thus discussing a problem in assignments/homeworks with other people is fine. However, discussing the solutions to the problem is NOT acceptable.
Every student must write his/her own code and homework. Showing your code or homework to members of other teams, giving it to them, or making it accessible to them (e.g., by making the files world-readable) is academic dishonesty.
You are responsible for ensuring that your code/documentation/results are adequately protected and not accessible to other teams. Change permissions of your working directory to 0700 ('chmod 0700 <directory>).
Consulting code/material from a textbook, or from the Internet, in order to understand specific aspects of your assignment is fine. However, copying such code/material will be considered academic dishonesty. If you borrow small parts of code/material from these sources, you must acknowledge this in your submission and additionally you must clearly understand and be able to explain the borrowed code/material.
Plagiarism detection tools, such as Moss (A system for detecting software plagiarism), will be used in this course.
Syllabus Changes:
This syllabus is a guide for the course and is subject to change with advance notice.