Performance Analysis of the OP2 Framework on Many-core Architectures
Oxford e-Research Centre, University of Oxford
ACM SIGMETRICS Performance Evaluation Review, March 2011
@article{giles2011performance,
title={Performance analysis of the OP2 framework on many-core architectures},
author={Giles, MB and Mudalige, GR and Sharif, Z. and Markall, G. and Kelly, PHJ},
journal={ACM SIGMETRICS Performance Evaluation Review},
volume={38},
number={4},
pages={9–15},
year={2011},
publisher={ACM}
}
We present a performance analysis and benchmarking study of the OP2 "active" library, which provides an abstraction framework for the solution of parallel unstructured mesh applications. OP2 aims to decouple the scientific specification of the application from its parallel implementation, achieving code longevity and near-optimal performance through re-targeting the back-end to different hardware. Runtime performance results are presented for a representative unstructured mesh application written using OP2 on a variety of many-core processor systems, including the traditional X86 architectures from Intel (Xeon based on the older Penryn and current Nehalem micro-architectures) and GPU offerings from NVIDIA (GTX260, Tesla C2050). Our analysis demonstrates the contrasting performance between the use of CPU (OpenMP) and GPU (CUDA) parallel implementations for the solution on an industrial sized unstructured mesh consisting of about 1.5 million edges. Results show the significance of choosing the correct partition and thread-block configuration, the factors limiting the GPU performance and insights into optimizations for improved performance.
June 5, 2011 by hgpu