• DocumentCode
    2293394
  • Title

    OOPar: An Object Oriented Environment for Implementing Parallel Algorithms

  • Author

    Devloo, Philippe

  • Author_Institution
    Fac. de Eng. Civil, Arquitetura e Urbanismo, UNICAMP, Campinas
  • fYear
    2008
  • fDate
    16-18 July 2008
  • Firstpage
    5
  • Lastpage
    5
  • Abstract
    OOPar is a C++ library which implements an interface to MPI (or other communication library) to offer the user a high level interface for implementing parallel algorithms. Large scale software projects have been parallelized using OOPar and their results will be presented during this presentation. OOPar introduces two concepts to help the programmer in defining a parallel algorithm: Distributed data and tasks which act on the distributed data. Distributed data are objects of classes which can be transmitted between processors. The user of the OOPar library can define his own types by deriving class from the TPZSaveable class and implementing the virtual Read/Write methods. Distributed data objects are managed by an object of type OOPDataManager. Each processor has its OOPDataManager object which administers TPZSaveable objects and the access requests issued by the OOPTask objects. Task objects implement part of a parallel algorithm acting upon and transforming distributed data objects. Task objects are submitted to a TaskManager object. Each processor has a unique TaskManager object. In order to sequence tasks in the proper order, a version is associated with distributed data objects and tasks depend on a distributed data object with a certain version. After transforming a distributed data object, the task object increments the version of the data object.
  • Keywords
    distributed processing; object-oriented methods; parallel algorithms; C++ library; OOPar; TaskManager object; distributed data object; object oriented environment; parallel algorithm; Computational fluid dynamics; Computer interfaces; Concurrent computing; Finite element methods; Large-scale systems; Parallel algorithms; Programming profession; Software algorithms; Software libraries; Web server;
  • fLanguage
    English
  • Publisher
    ieee
  • Conference_Titel
    Computational Science and Engineering, 2008. CSE '08. 11th IEEE International Conference on
  • Conference_Location
    Sao Paulo
  • Print_ISBN
    978-0-7695-3193-9
  • Type

    conf

  • DOI
    10.1109/CSE.2008.68
  • Filename
    4578209