Object-oriented analysis and design of the message passing interface

Academic Article


  • The major contribution of this paper is the application of modern analysis techniques to the important Message Passing Interface standard, work done in order to obtain information useful in designing both application programmer interfaces for object-oriented languages, and message passing systems. Recognition of 'Design Patterns' within MPI is an important discernment of this work. A further contribution is a comparative discussion of the design and evolution of three actual object-oriented designs for the Message Passing Interface (MPI-1) application programmer interface (API), two of which have influenced the standardization of C++ explicit parallel programming with MPI-2, and which strongly indicate the value of a priori object-oriented design and analysis of such APIs. Knowledge of design patterns is assumed herein. Discussion provided here includes systems developed at Mississippi State University (MPI++), the University of Notre Dame (OOMPI), and the merger of these systems that results in a standard binding within the MPI-2 standard. Commentary concerning additional opportunities for further object-oriented analysis and design of message passing systems and APIs, such as MPI-2 and MPI/RT, are mentioned in conclusion. Connection of modern software design and engineering principles to high performance computing programming approaches is a new and important further contribution of this work.
  • Published In

  • Concurrency  Journal
  • Digital Object Identifier (doi)

    Author List

  • Skjellum A; Wooley DG; Lu Z; Wolf M; Bangalore PV; Lumsdaine A; Squyres JM; McCandless B
  • Start Page

  • 245
  • End Page

  • 292
  • Volume

  • 13
  • Issue

  • 4