| TIME | MONDAY | TUESDAY | WEDNESDAY | THURSDAY | FRIDAY | Contents | |
|---|---|---|---|---|---|---|---|
| 8:40 10:30 | 
 | Ceng 471 (T) A319 | 
 | 
 | 
 | ||
| 10:40 12:30 | 
 | 
 | 
 | 
 | 
 | ||
| 12:40 14:30 | 
 | 
 | 
 | 
 | |||
| 14:40 16:30 | 
 | 
 | 
 | OFFICE HOURS | Ceng 471 (L)PCLab | ||
| Instructoroffice: Computer
			Engineering Department, 329-L | TA
 
 | 
Watch
this space for the latest updates. Last updated: 
Sorting Algorithms: Şenay Büyükarslan, Yaren Ilgaz, Ayşe Meydan
Numerical Algorithms: Nevrez İmamoğlu, Alp Eren Özkul, Çağatay Bal
Image Processing: Ufuk Gün, Ömer Sezgin Uğurlu
Searching and Optimization: Neslihan Nailli, Gülistan Özdemir, Salih Körpeoğlu
The others should talk to me. The presentations will be at the last week of the semester.
This course provides an introduction to parallel and distributed computing and practical experiences in writing parallel programs on a cluster of computers. You will learn about the following topics:
Parallel Computers
Message Passing Computing
Embarrassingly Parallel Computations
Partitioning and Divide-and-Conquer Strategies
Pipelined Computations
Synchronous Computations
Load Balancing
Programming with Shared Memory
Topics might be classifed into two main parts as;
Parallel computers: architectural types, shared memory, message passing, interconnection networks, potential for increased speed.
Basic techniques: embarrassingly parallel computations, partitioning and divide and conquer, pipelined computations, synchronous computations, load balancing, shared memory programming.
There is one group for lecturing. You will be expected to do significant programming assignments, as well as run programs we supply and analyze the output. Since we will program in C on a UNIX environment, some experience using C on UNIX will be important. We will provide tutorials for basic C on UNIX during the first few class periods.
In lab sessions, we will concentrate upon the message-passing method of parallel computing and use the standard parallel computing environment called MPI (Message Passing Interface). Thread-based programming will also be outlined, and the distributed shared memory (DSM) approach (If we have enough time). Each student will complete a project based on parallel computing for the laboratory study.
Also, each student will complete a project based on parallel computing, (distributed computing, cluster computing) for the midterm exam.
Important announcements will be posted to the Announcements section of this web page above, so please check this page frequently. You are responsible for all such announcements, as well as announcements made in lecture.
Readings will be assigned in Parallel Programming: Techniques and Application Using Networked Workstations and Parallel Computers, 2nd edition, by B. Wilkinson and M. Allen, Prentice Hall Inc., 2005, ISBN 0-13-140563-2.

Beowulf Cluster Computing with Linux, 2nd edition, edited by William Gropp, Ewing Lusk, Thomas Sterling, MIT Press, 2003, ISBN 0-262-69292-9.
Beowulf Cluster Computing with Windows, Thomas Sterling , MIT Press, 2001, ISBN 0-262-69275-9.
Using MPI , Portable Parallel Programming with the Message Passing Interface, William Gropp, Ewing Lusk and Anthony Skjellum, The MIT Press, 1999, ISBN 0-262-57132-3.
Using MPI-2, Advanced Features of the Message Passing Interface, William Gropp, Ewing Lusk, Rajeev Thakur, The MIT Press, 1999, ISBN 0-262-57133-1.
MPI: The Complete Reference (Vol. 1) - The MPI Core, Marc Snir, Steve Otto, Steven Huss-Lederman, David Walker and Jack Dongarra, The MIT Press, 1998, ISBN 0-262-69215-5.
MPI: The Complete Reference (Vol. 2) - The MPI-2 Extensions, William Gropp, Steven Huss-Lederman, Andrew Lumsdaine, Ewing Lusk, Bill Nitzberg, William Saphir and Marc Snir, The MIT Press, 1998, ISBN 0-262-57123-4.
In Search of Clusters: The ongoing battle in lowly parallel computing, Second Edition, by Gregory F. Pfister, Prentice Hall Publishing Company, 1998, ISBN: 0-13-899709-8.
How to Build a Beowulf – A Guide to the Implementation and Application of PC Clusters, by Thomas Sterling, John Salmon, Donald J. Becker and Daniel F. Savarese, MIT Press, 1999, ISBN 0-262-69218-X.
PVM: Parallel Virtual Machine, A Users' Guide and Tutorial for Network Parallel Computing, Al Geist, Adam Beguelin, Jack Dongarra, Weicheng Jiang, Robert Manchek and Vaidyalingam S. Sunderam, MIT Press, 1994, ISBN 0-262-57108-0.
This texts are only recommended rather than required. This books are useful for reference, for an alternative point of view.
Some materials are given. Please inform me about the usefullness of the materials. Check this place for updates.
The following references are available online
There will be a final exam: 40%
Term Project as Midterm exam: 25%
Term Project as Lab. exam: 25%
Attendance is required and constitutes part of your course grade; 10%
Attendance is not compulsory, but you are responsible for everything said in class.
I encourage you to ask questions in class. You are supposed to ask questions. Don't guess, ask a question!
You may discuss homework problems with classmates (although it is not to your advantage to do so).
You can use ideas from the literature (with proper citation).
You can use anything from the textbook/notes.
The code you submit must be written completely by you.
The following schedule is tentative; it may be updated later in the semester, so check back here frequently.
| Week | Dates | Topic | Lecture Notes | |
|---|---|---|---|---|
| Lectures | ||||
| 1 | Sep 27, 2005 | First Meeting | ||
| Sep 30, 2005 | ||||
| 2 | Oct 4, 2005 | Parallel Computers | Wilkinson | |
| Oct 7, 2005 | ||||
| 3 | Oct 11, 2005 | Message-Passing Computing | Wilkinson | |
| Oct 14, 2005 | ||||
| 4 | Oct 18, 2005 | Message-Passing Computing | Wilkinson | |
| Oct 21, 2005 | ||||
| 5 | Oct 25 2005 | Embarrassingly Parallel Computations | Wilkinson | |
| Oct 28, 2005 | Tatil | |||
| Tatil | ||||
| 6 | Nov 1, 2005 | Partitioning and Divide-and-Conquer Strategies | Wilkinson | |
| Nov 4, 2005 | Tatil | |||
| Tatil | ||||
| 7 | Nov 8, 2005 | |||
| Nov 11, 2005 | ||||
| 8 | Nov 14-18, 2005 | Midterm Week | ||
| 9 | Nov 22, 2005 | Pipelined Computations | Wilkinson | |
| Nov 25, 2005 | ||||
| 10 | Nov 29, 2005 | Synchronous Computations | Wilkinson | |
| Dec 2, 2005 | 
 | |||
| 
 | ||||
| 11 | Dec 6, 2005 
 | Load Balancing and Termination Detection | 
 | |
| Dec 9, 2005 | ||||
| 12 | Dec 13, 2005 | Programming with Shared Memory | ||
| Examples; Buffer Limit, Barrier, Collective Communications and Parallel Matrix Multiplication | ||||
| Dec 16, 2005 | ||||
| 13 | Dec 20, 2005 | Programming with Shared Memory | ||
| Dec 23, 2005 | ||||
| 14 | Dec 27, 2005 | 
 | 
 | |
| Dec 30, 2005 | ||||
| Exams | ||||
| 18 January 2006 15:00-17:00 A319 | 
 | |||