- 13.2.2019: Please select your preferred exercise group. Based on your preferences we will publish the group assignment on 19.2.
- 19.2.2019: Group assignment is online. As the space in each room is limited, please attend your assigned exercise group. If you are not in the list please contact Pavol Bielik
- 26.2.2019: Added supplementary material with Command Line Basics
The purpose of this course is to introduce students to parallel programming. By the end of the course students will be able to design and implement working parallel programs in traditional (e.g., Java Threads) and emerging parallel programming models. Moreover, students will master fundamental concepts in parallelism and be able to reason about the correctness, performance, and the construction of parallel programs using different parallel programming paradigms (e.g., task parallelism, data parallelism) and mechanisms (e.g., threads, tasks, locks, communication channels). Finally, the course will examine how parallel programming methodologies can be applied in different algorithmic domains by investigating parallelization of algorithms.
- Basic parallel programming concepts
- Parallel programming using Java
- Synchronization techniques
- Case studies of building parallel programs starting from sequential algorithms
Main text and reference book
- Introduction to Java Programming, 2014. Daniel Liang. ISBN-13: 9780133813463
- Java Concurrency in Practice, 2006. Brian Goetz, Tim Peierls, Joshua Bloch, Joseph Bowbeer, David Holmes, Doug Lea. ISBN-13: 9780321349606
- The Art of Multiprocessor Programming, 2011. Maurice Herlihy, Nir Shavit. Morgan Kaufmann. Also available online in the ETH network.
Related resources, text and reference books
- Sophomoric Parallelism and Concurrency (from: spac)
- The Little Book of Semaphores
- Programming concurrency on the JVM, 2011. Venkat Subramaniam
- Structured Parallel Programming: Patterns for Efficient Computation, 2012. Michael McCool, Arch Robison, James Reinders.
- Patterns for Parallel Programming, 2004. Timothy G. Mattson, Beverly A. Sanders, Berna L. Massingill.
- A minicourse on multithreaded programming. Charles E. Leiserson, Harald Prokop.
- (Optional) Inside the Java Virtual Machine. 2000. Bill Venners.
Introduction to Java books (freely available)
- How to Think Like a Computer Scientist, 2012. Allen B. Downey.
- Introduction to Programming Using Java, 2011. David J. Eck.
All course materials are password protected using your ETHZ credentials.
Students should bring their laptops to the exercise sessions as most of the exercises involve programming.
|Command Line Basics|
Exams and Grading
There is a written, centralized exam after the end of the semester. Exercise sessions are not graded.
- 100% of grade determined by final Exam
2018 Summer Questions
2018 Winter Questions
2016 Summer Questions 2016 Summer Solution