IDEAS home Printed from https://ideas.repec.org/a/ntu/ntcmss/vol1-iss2-13-05.html
   My bibliography  Save this article

Developing a High Performance Software Library with MPI and CUDA for Matrix Computations

Author

Listed:
  • Bogdan Oancea

    () ("Nicolae Titulescu" University of Bucharest, Romania)

  • Tudorel Andrei

    () (The Bucharest Academy of Economic Studies, Romania)

Abstract

Nowadays, the paradigm of parallel computing is changing. CUDA is now a popular programming model for general purpose computations on GPUs and a great number of applications were ported to CUDA obtaining speedups of orders of magnitude comparing to optimized CPU implementations. Hybrid approaches that combine the message passing model with the shared memory model for parallel computing are a solution for very large applications. We considered a heterogeneous cluster that combines the CPU and GPU computations using MPI and CUDA for developing a high performance linear algebra library. Our library deals with large linear systems solvers because they are a common problem in the fields of science and engineering. Direct methods for computing the solution of such systems can be very expensive due to high memory requirements and computational cost. An efficient alternative are iterative methods which computes only an approximation of the solution. In this paper we present an implementation of a library that uses a hybrid model of computation using MPI and CUDA implementing both direct and iterative linear systems solvers. Our library implements LU and Cholesky factorization based solvers and some of the non-stationary iterative methods using the MPI/CUDA combination. We compared the performance of our MPI/CUDA implementation with classic programs written to be run on a single CPU.

Suggested Citation

  • Bogdan Oancea & Tudorel Andrei, 2013. "Developing a High Performance Software Library with MPI and CUDA for Matrix Computations," Computational Methods in Social Sciences (CMSS), "Nicolae Titulescu" University of Bucharest, Faculty of Economic Sciences, vol. 1(2), pages 5-10, December.
  • Handle: RePEc:ntu:ntcmss:vol1-iss2-13-05
    as

    Download full text from publisher

    File URL: http://cmss.univnt.ro/wp-content/uploads/vol/split/vol_I_issue_2/CMSS_vol_I_issue_2_art_001.pdf
    File Function: First version, 2013
    Download Restriction: no

    References listed on IDEAS

    as
    1. repec:dau:papers:123456789/7463 is not listed on IDEAS
    Full references (including those not matched with items on IDEAS)

    Corrections

    All material on this site has been provided by the respective publishers and authors. You can help correct errors and omissions. When requesting a correction, please mention this item's handle: RePEc:ntu:ntcmss:vol1-iss2-13-05. See general information about how to correct material in RePEc.

    For technical questions regarding this item, or to correct its authors, title, abstract, bibliographic or download information, contact: (Stefan Ciucu). General contact details of provider: http://edirc.repec.org/data/feuntro.html .

    If you have authored this item and are not yet registered with RePEc, we encourage you to do it here. This allows to link your profile to this item. It also allows you to accept potential citations to this item that we are uncertain about.

    If CitEc recognized a reference but did not link an item in RePEc to it, you can help with this form .

    If you know of missing items citing this one, you can help us creating those links by adding the relevant references in the same way as above, for each refering item. If you are a registered author of this item, you may also want to check the "citations" tab in your RePEc Author Service profile, as there may be some citations waiting for confirmation.

    Please note that corrections may take a couple of weeks to filter through the various RePEc services.

    IDEAS is a RePEc service hosted by the Research Division of the Federal Reserve Bank of St. Louis . RePEc uses bibliographic data supplied by the respective publishers.