Babel Middleware

Babel
Developer(s) LLNL
Stable release 2.0.0 / January 2012 (2012-01)
Operating system cross-platform
Type middleware
License LGPL
Website computation.llnl.gov/casc/components/

Babel is an open source middleware system serving the scientific computing community. As a language interoperability tool, Babel enables the arbitrary mixing of software libraries written in C/C++, Fortran, Python, and Java.[1][2] As a distributed computing platform, Babel provides a language-neutral Remote Method Invocation (RMI) scheme similar to Java's RMI which allows third-party plug-ins to specify custom data encodings and network protocols.[3]

How it works

Babel requires developers to use an interface description language to specify the platform and language neutral interface to code. Babel uses a custom dialect called SIDL (Scientific Interface Definition Language), which has adaptations specific to computational science and engineering applications. The Babel tool parses the SIDL specification to generate source code which provides the glue between programming languages.

Babel works on all known POSIX and Unix variants, including Linux, Mac OS X, AIX, IRIX, Solaris, Tru64, Cray's XT4, IBM's Blue Gene, and many commodity clusters. Babel does not require special compiler or linker technology and works with GNU, Intel, IBM, PathScale, PGI, and many other compilers. Babel is distributed under an LGPL license.

Impact

Babel won an R&D 100 Award in 2006.[4] [5] It has been used in diverse computational applications such as accelerator beam dynamics, cell biology, chemistry, climate, electron effects, fusion, geomagnetics, materials, nuclear power plants, radio astronomy, and subsurface transport as well as infrastructure such as frameworks, meshing, solvers, sparse linear algebra, and sourcecode refactoring.[6] Babel is also redistributed with some customer applications, the CCA framework, and Debian Linux.

History

Babel was started as an internal research project on software components at Lawrence Livermore National Laboratory in 1999. The first public (alpha) release of Babel was in 2001. Also in 2001 it secured funding from SciDAC (Scientific Discovery Through Advanced Computing) along with its collaborators in the CCA Forum (Common Component Architecture Forum).

Community

Babel development and maintenance is currently funded by United States Department of Energy, but relies heavily on an open source community. Contributors hail from Sandia National Laboratories, Argonne National Laboratory, Oak Ridge National Laboratory, Tech-X Corp, MIT, University of Utah, and more. The Babel development team maintain open software repositories, mailing lists, and issue trackers.

See also

References

  1. Babel Users' Guide
  2. High-performance language interoperability for scientific computing through Babel
  3. Babel RMI paper at IPDPS '07
  4. R&D 100 Award Archive
  5. LLNL Public Affairs Archive
  6. CCA Impact paper at SciDAC 06

External links

This article is issued from Wikipedia - version of the Tuesday, February 24, 2015. The text is available under the Creative Commons Attribution/Share Alike but additional terms may apply for the media files.