This course covers the the methods available to write high performance parallel codes in Julia, including threading, GPU acceleration, and distributed programming with MPI and Dagger.jl.
By the end of the course students will be able to use Julia to write write portable and performant code that scales from their laptop CPUs to GPU-enabled supercomputer clusters like NERSC Perlmutter. These skills will be illustrated with a set of applications including scientific codes like Gray-Scott, and training large scale AI applications like LLMs.
Lectures: Mondays, Wednesdays, and Fridays 11 AM - 12 AM in room 36-144.
Prerequisites: 18.03, 18.06, or equivalents, and some programming experience. You should have taken the first half-semester numerical "hub" 18.S190/16.S090. Familiarity with Julia is assumed.
Instructors: A. Edelman
Teaching Assistants: Raye Kimmerer, Eveylne Ringoot, Rabab Alomairy
Office Hours:
- Raye on Tuesdays and Thursdays 12:45PM - 1:45PM on Zoom room
rayegun
.
Lecture Recordings: Unfortunately we are not teaching in a recorded classroom this semester.
Links: Worth bookmarking:
-
6 Homeworks: 90%
-
Class Participation: 10%
Homework | Assigned | Due | Topic | Solution |
---|---|---|---|---|
HW0 | April 2 | April 7 @ 11:59PM | Logistics |