Skip to content

Latest commit

 

History

History
53 lines (36 loc) · 2.03 KB

README.md

File metadata and controls

53 lines (36 loc) · 2.03 KB

High Performance C++

License: MIT GitHub Workflow Status codecov

Slides

<iframe src="https://docs.google.com/presentation/d/e/2PACX-1vSsQgXEWShyBmv29hURbcjWcCXJmAKv-PvT-6vIaIHqgV33GyhPa8tWnzT8fM1Gl3XzEXjzpfuWieXS/embed?start=false&loop=false&delayms=3000" frameborder="0" width="960" height="569" allowfullscreen="true" mozallowfullscreen="true" webkitallowfullscreen="true"></iframe>

download slides as pdf | download course description as pdf

Getting started

To clone the repo, compile the code and run the benchmarks:

git clone --recursive https://github.com/ssciwr/high-performance-cpp.git
cd high-performance-cpp
mkdir build
cd build
cmake -DCMAKE_BUILD_TYPE=Release ..
cmake --build .
./bench/bench

Notes

  • CMake 3.16 gave a target "BLAS::BLAS" error on Ubuntu (see #13)
    • Using a more recent CMake version is one solution to this problem
  • Apple clang on M1 mac doesn't support the -march=native flag
    • Possible alternatives: -mcpu=apple-m1 or -mcpu=apple-a14
    • -march=native will be supported by on M1 by clang 15

Plots

List versus Vector inserting elements:

Matrix-vector multiplication:

Struct of Arrays versus Array of Structs: