SkePU swMATH ID: 14958 Software Authors: Johan Enmyren; Christoph W. Kessler Description: SkePU: a multi-backend skeleton programming library for multi-GPU systems. We present SkePU, a C++ template library which provides a simple and unified interface for specifying data-parallel computations with the help of skeletons on GPUs using CUDA and OpenCL. The interface is also general enough to support other architectures, and SkePU implements both a sequential CPU and a parallel OpenMP backend. It also supports multi-GPU systems. Copying data between the host and the GPU device memory can be a performance bottleneck. A key technique in SkePU is the implementation of lazy memory copying in the container type used to represent skeleton operands, which allows to avoid unnecessary memory transfers. We evaluate SkePU with small benchmarks and a larger application, a Runge-Kutta ODE solver. The results show that a skeleton approach to GPU programming is viable, especially when the computation burden is large compared to memory I/O (the lazy memory copying can help to achieve this). It also shows that utilizing several GPUs have a potential for performance gains. We see that SkePU offers good performance with a more complex and realistic task such as ODE solving, with up to 10 times faster run times when using SkePU with a GPU backend compared to a sequential solver running on a fast CPU. Homepage: http://dl.acm.org/citation.cfm?id=1863487 Related Software: CUDA; OpenACC; OpenCL; StarPU; PETSc; SkelCL; Thrust; HOSTA; OmpSs; GPGPU; MPI; CuPP; NAS Parallel Benchmarks; Copperhead; ViennaCL; CUBLAS; PyOP2; GitHub; SYCL; HPX Cited in: 3 Documents all top 5 Cited by 8 Authors 1 Fröhlich, Jochen 1 Henrio, Ludovic 1 Huismann, Immo 1 Keßler, Christoph W. 1 Li, Lu 1 Mudalige, Gihan R. 1 Reguly, István Z. 1 Stiller, Jörg Cited in 2 Serials 2 Computers and Fluids 1 Journal of Logical and Algebraic Methods in Programming Cited in 3 Fields 2 Numerical analysis (65-XX) 2 Fluid mechanics (76-XX) 1 Computer science (68-XX) Citations by Year