Welcome to the MICS 6001V at HKUST(GZ), 2025 Spring
This course introduces the fundamentals of GPU-accelerated computing, focusing on how GPUs enable high-performance solutions for complex tasks in fields like AI, data analytics, and scientific simulations. Students will explore GPU architectures, learn parallel programming models such as CUDA and ROCM, and develop skills in memory management, performance optimization, and thread synchronization. Through hands-on projects, participants will gain practical experience in leveraging GPU parallelism to solve real-world computational challenges, preparing them to apply these techniques in industries.
Text Book: Programming Massively Parallel Processors: A Hands-on Approach (PMPP)
Online Materials:
GitHub - gpu-mode/lectures: Material for gpu-mode lectures
This class will be semi-flipped. As the leading hardware acceleration approach, GPU computing has extensive expertise and high-quality tutorials available online. For selected topics, you will first watch YouTube videos explaining core concepts independently, then deliver lectures during class time.
This is a project-based class. Students work in groups of 2-3 and choose from a set of project topics. Throughout the semester, groups give paper presentations about their chosen topic and provide regular progress updates.
|
Week |
Date |
Lecture Topics
|
Reference
(PMPP) |
Notes |
| --- | --- | --- | --- | --- |
| Week 1 | Feb 7 | 1. Introduction to the Course
2. Data Parallel Programming and CUDA C | Chapter 2, Chapter 3 | https://www.nvidia.com/en-us/on-demand/session/gtcspring21-s31151/ |
| Week 2 | Feb 14 | 1. Kernel Execution
2. Memory Model & Locality | Chapter 3, Chapter 4 | Form project group and select one topic.
Please fill the information collection form |
| Week 3 | Feb 21 | 1. Shared Memory & Bank Conflicts
2. Memory Coalescing | Chapter 5
| |
| Week 4 | Feb 28 | 1. Performance Profiling
2. Project Kickoff Presentation
(Topic; Preliminary results; Plan) |
Chapter 6
| The Lecture is given by GTA |
| Week 5 | Mar 7 | 1. Convolution & Tiled Convolution
2. Paper Presentation | Chapter 7 | The Lecture is given by Students |
| Week 6 | Mar 14 | 1. Reduction
2. Paper Presentation |
Chapter 10 | The Lecture is given by Students |
| Week 7 | Mar 21 | 1. Histograms
2. Atomics
3. Paper Presentation |
Chapter 9 | The Lecture is given by Students |
| Week 8 | Mar 28 | Project Midterm Presentation
(Progress; Findings; Problems; Plan) |
Chapter 8 | |
| Week 9 | Apr 11 | 1. SpMV
2. Paper Presentation | Chapter 14 | The Lecture is given by Students |
| Week 10 | Apr 18 | 1. Scan
2. Paper Presentation | Chapter 11 | The Lecture is given by Students |
| Week 11 | Apr 25 | 1. GPU Microarchitecture
2. Paper Presentation | Chapter 13 | |
| Week 12 | Apr 27 | 1. Dynamic Parallelism & Shuffle
2. Paper Presentation | Chapter 21,
Chapter 22 | |
| Week 13 | May 9 | Final Project Presentation
(Same as conference presentation) | Chapter 23 | Submit the report in conference paper format at the same day |