7633

Tuning a Finite Difference Computation for Parallel Vector Processors

Gerhard Zumbusch
Institut fur Angewandte Mathematik, Friedrich-Schiller-Universitat Jena, Jena, Germany
International Symposium on Parallel and Distributed Computing (ISPDC), 2012

@inproceedings{Zumbusch:2012*2,

   author={G. Zumbusch},

   title={Tuning a Finite Difference Computation for Parallel Vector Processors},

   booktitle={accepted for Proc. International Symposium on Parallel and Distributed Computing (ISPDC) 2012},

   year={2012},

   publisher={IEEE Press},

   pdf={http://cse.mathe.uni-jena.de/pub/zumbusch/ispdc12.pdf},

   annote={refereed}

}

Download Download (PDF)   View View   Source Source   

1843

views

Current CPU and GPU architectures heavily use data and instruction parallelism at different levels. Floating point operations are organised in vector instructions of increasing vector length. For reasons of performance it is mandatory to use the vector instructions efficiently. Several ways of tuning a model problem finite difference stencil computation are discussed. The combination of vectorisation and an interleaved data layout, cache aware algorithms, loop unrolling, parallelisation and parameter tuning lead to optimised implementations at a level of 90% peak performance of the floating point pipelines on recent Intel Sandy Bridge and AMD Bulldozer CPU cores, both with AVX vector instructions as well as on Nvidia Fermi/ Kepler GPU architectures. Furthermore, we present numbers for parallel multi-core/ multi-processor and multi-GPU configurations. They represent regularly more than an order of speed up compared to a standard implementation. The analysis may also explain deciencies of automatic vectorisation for linear data layout and serve as a foundation of efficient implementations of more complex expressions.
No votes yet.
Please wait...

* * *

* * *

HGPU group © 2010-2024 hgpu.org

All rights belong to the respective authors

Contact us: