MiniKokkos: A Calculus of Portable Parallelism
DescriptionKokkos is a C++ library and ecosystem for writing parallel programs on heterogeneous systems. One of the primary goals of Kokkos is portability: programs in Kokkos are expressed through general parallel constructs which can enable the same code to compile and execute on different parallel architectures. However, there is no known formal model of Kokkos's semantics, which must be generic enough to support current and future CPU and accelerator architectures. As a first step of formalizing Kokkos, We introduce MiniKokkos: a small language capturing the main features of Kokkos, and then prove that MiniKokkos ensures portability across all possible parallel executions. We also provide a case study of how MiniKokkos can help reason about Kokkos programs and help find a bug in the Kokkos implementation.
Event Type
Workshop
TimeFriday, 18 November 202211am - 11:20am CST
LocationD167
Registration Categories
W
Tags
Correctness
Software Engineering
Session Formats
Recorded
Back To Top Button