ARMI: An adaptive, platform independent communication library

Steven Saunders, Lawrence Rauchwerger

Research output: Contribution to conferencePaperpeer-review


ARMI is a communication library that provides a framework for expressing fine-grain parallelism and mapping it to a particular machine using shared-memory and message passing library calls. The library is an advanced implementation of the RMI protocol and handles low-level details such as scheduling incoming communication and aggregating outgoing communication to coarsen parallelism when necessary. These details can be tuned for different platforms to allow user codes to achieve the highest performance possible without manual modification. ARMI is used by STAPL, our generic parallel library, to provide a portable, user transparent communication layer. We present the basic design as well as the mechanisms used in the current Pthreads/OpenMP, MPI implementations and/or a combination thereof. Performance comparisons between ARMI and explicit use of Pthreads or MPI are given on a variety of machines, including an HP V2200, SGI Origin 3800, IBM Regatta-HPC and IBM RS6000 SP cluster.

Original languageEnglish (US)
Number of pages12
StatePublished - 2003
Externally publishedYes
Event2003 ACM SIGPLAN Symposium on Principles and Practice of Parallel Programming - San Diego, CA, United States
Duration: Jun 11 2003Jun 13 2003


Conference2003 ACM SIGPLAN Symposium on Principles and Practice of Parallel Programming
Country/TerritoryUnited States
CitySan Diego, CA


  • Communication library
  • MPI
  • OpenMP
  • Parallel programming
  • Pthreads
  • RMI
  • RPC
  • Run-time system

ASJC Scopus subject areas

  • Software


Dive into the research topics of 'ARMI: An adaptive, platform independent communication library'. Together they form a unique fingerprint.

Cite this