-
High-Order Finite-differences on multi-threaded architectures using OCCA
Abstract: High-order finite-difference methods are commonly used in wave propagators for industrial subsurface imaging algorithms. Computational aspects of the reduced linear elastic vertical transversely isotropic propagator are considered. Thread parallel algorithms suitable for implementing this propagator on multi-core and many-core processing devices are introduced. Portability is addressed through the… ▽ More
Submitted 2 October, 2014; originally announced October 2014.
Comments: ICOSAHOM 2014 conference paper, 9 pages, 2 figures, 3 tables
-
OCCA: A unified approach to multi-threading languages
Abstract: The inability to predict lasting languages and architectures led us to develop OCCA, a C++ library focused on host-device interaction. Using run-time compilation and macro expansions, the result is a novel single kernel language that expands to multiple threading languages. Currently, OCCA supports device kernel expansions for the OpenMP, OpenCL, and CUDA platforms. Computational results using fin… ▽ More
Submitted 4 March, 2014; originally announced March 2014.
Comments: 25 pages, 6 figures, 9 code listings, 8 tables, Submitted to the SIAM Journal on Scientific Computing (SISC), presented at the Oil & Gas Workshop 2014 at Rice University