This is an online course where you can learn to find and fix low-level performance issues, for example CPU cache misses and branch mispredictions. It's all about practice. So we offer you this course in a form of lab assignments and youtube videos. You will spend at least 90% of the time analyzing performance of the code and trying to improve it.
Each lab assignment focuses on a specific performance problem and can take anywhere from 30 mins up to 4 hours depending on your background and the complexity of the lab assignment itself. Once you're done improving the code, you can submit your solution to Github for automated benchmarking and verification.
Performance Ninja is supported on Linux, Windows, and Mac, and is run on all the recent HW including Intel's 12th-gen Alderlake, AMD's Zen3, and Apple's M1 CPUs. You can observe the effect of your optimizations on a variety of modern platforms.
Prerequisites: basic C++ skills are an absolute must-have for the course. Denis' book "Performance Analysis and Tuning on Modern CPUs" is recommended as an introduction to performance analysis basics. Knowledge of compilers, computer architecture, and the ability to read assembly code is a plus.
Before you start working on lab assignments, make sure you read Get Started page and watch the warmup video.
Lab assignments in this project are implemented in C++. If you're more comfortable with Rust, perf-ninja was also ported to Rust here, thanks to @grahamking.
- Core Bound:
- Memory Bound:
- Bad Speculation:
- CPU Frontend Bound:
- Data-Driven optimizations:
- Misc:
Performance Ninja is in a very much work-in-progress state. We will be adding new lab assignments and videos! The course is free by default, but we ask you to support us on Github Sponsors, Patreon or PayPal. Your sponsorship will speed up adding new lab assignments.
Current sponsors:
- Pavel Davydov
- Maya Lekova (@MayaLekova)
- Aaron St. George (@AaronStGeorge)
Thanks to Mansur Mavliutov (@Mansur) for providing an AMD-based machine for running CI jobs.
Lab authors:
- Andrew Evstyukhin (@andrewevstyukhin)
- Ivica Bogosavljevic (@ibogosavljevic)
- René Rahn (@rrahn)
- Adam Folwarczny (@adamf88)
- Jakub Beránek (@Kobzol)
- Jakub Gałecki (@kubagalecki)
- Denis Bakhvalov (@dendibakh)
We warmly welcome contributions! See Contributing.md for the details.
Please write to [email protected] with suggestions.
Copyright © 2022 by Denis Bakhvalov under Creative Commons license (CC BY 4.0).