s'authentifier
version française rss feed
HAL : hal-00697257, version 1

Fiche détaillée  Récupérer au format
Parallel Processing Letters 22, 2 (2012) 1240007
SPOC: GPGPU PROGRAMMING THROUGH STREAM PROCESSING WITH OCAML
Mathias Bourgoin 1, Emmanuel Chailloux 1, Jean Luc Lamotte 1
(16/05/2012)

General purpose computing on graphics processing units (GPGPU) consists of using GPUs to handle computations commonly handled by CPUs. GPGPU programming implies developing specific programs to run on GPUs managed by a host program running on the CPU. To achieve high performance implies to explicitly organize memory transfers between devices. Besides, different incompatible frameworks exist making productivity and portability difficult to achieve. In this paper, we describe SPOC, an OCaml library, defining specific data sets in order to automatically manage transfers between GPU and CPU. SPOC also offers a runtime library looking for multiple frameworks and making them usable transparently. We also describe the link between SPOC and the OCaml garbage collector to optimize transfers dynamically. SPOC benchmarks show that SPOC can offer great performance while simplifying GPGPU programming.
1 :  Laboratoire d'Informatique de Paris 6 (LIP6)
CNRS : UMR7606 – Université Pierre et Marie Curie [UPMC] - Paris VI
APR
Pequan
Informatique/Langage de programmation
OCaml – Stream Processing – GPGPU – High Level Libraries – Data-Parallel
Liste des fichiers attachés à ce document : 
PDF
S0129626412400075.pdf(818.6 KB)