Scout: A Source-to-Source Transformator for SIMD Optimizations

Publikation: Beitrag in Buch/Konferenzbericht/Sammelband/GutachtenBeitrag in Buch/Sammelband/GutachtenBeigetragenBegutachtung

Abstract

We present Scout, a configurable source-to-source transformation tool designed to automatically vectorize C source code. Scout provides the means to vectorize loops using SIMD instructions at source level. Our main focus during the development of Scout is a maximum flexibility of the tool in two ways: being capable of vectorizing a wide range of loop constructs and being capable of targeting various modern SIMD architectures. Scout supports several SIMD instructions sets like SSE or AVX and is easily extensible to upcoming ones. In the second part of the paper we present results of applying Scout’s vectorizing capabilities to CFD production codes of the German Aerospace Center. The complex loops used in these codes often inhibit the automatic vectorization of usual C compilers. In contrast, Scout is able to vectorize most of these loops. We measured the resulting speedup for SSE and AVX platforms.

Details

OriginalspracheUndefiniert
TitelEuro-Par 2011: Parallel Processing Workshops
Seiten137-145
Seitenumfang9
PublikationsstatusVeröffentlicht - 2012
Peer-Review-StatusJa

Publikationsreihe

ReiheLecture Notes in Computer Science, Volume 7156
ISSN0302-9743

Externe IDs

Scopus 84882623205
ORCID /0000-0001-8719-5741/work/173053665

Schlagworte

Bibliotheksschlagworte