Skip to content

This is an online course where you can learn and master the skill of low-level performance analysis and tuning.

Notifications You must be signed in to change notification settings

dendibakh/perf-ninja

Repository files navigation

Linux Windows Windows Linux

Performance Ninja Class

YouTube X (formerly Twitter) Follow GitHub Repo stars

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++. Also, Performance Ninja was ported to:

Lab assignments

Support the project

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)

Contributing

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).

About

This is an online course where you can learn and master the skill of low-level performance analysis and tuning.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published