/xsdk-community-policies

Contains the xSDK community policies. The master branch is the latest accepted version of the policies and will be applied to future xSDK releases. See the releases page for tags corresponding to the current and past xSDK releases.

We are actively soliciting suggestions from the community at https://xsdk.info/policies.

xSDK Community Package Policies

The IDEAS Project xSDK Team

Version 1.0.0, February 17, 2023

https://xsdk.info/policies

Background

A key aspect of work started in the IDEAS Scientific Software Productivity Project and continued in the xSDK4ECP Project is developing an Extreme-scale Scientific Software Development Kit (xSDK) — a collection of related and complementary software elements that provide the building blocks, tools, models, processes, and related artifacts for rapid and efficient development of high-quality applications. As an initial step in creating xSDK, we have written the following draft xSDK package community policies to help address challenges in interoperability and sustainability of software developed by diverse groups at different institutions.

Goal

Develop a set of xSDK community policies that a software library/framework (henceforth referred to as package)1 must satisfy in order to to be xSDK compatible . The designation of a package being xSDK compatible informs potential users that the package can be easily used with other xSDK libraries and components and thus helps to address issues in long-term sustainability2 and interoperability among packages.

We consider two categories of xSDK packages: xSDK compatible packages and xSDK member packages. We also consider two levels of xSDK compatibility: mandatory policies and recommended policies.

  • A package will be declared xSDK compatible once the xSDK team has determined that the package satisfies the mandatory xSDK policies listed below. In addition to the required policies, we specify recommended xSDK policies that further help to address issues in software interoperability.

  • Similarly, a package can become an xSDK member package if (1) it is an xSDK-compatible package, and (2) it uses or can be used by another package in xSDK, and the connecting interface is regularly tested for regressions.

Initially the requirements and process are informally presented; over time, if needed, we can begin to formalize them. Currently, xSDK includes twenty-six popular numerical libraries:

  1. AMReX
  2. ArborX
  3. ButterflyPACK
  4. DTK
  5. deal.II
  6. ExaGO
  7. Ginkgo
  8. heFFTe
  9. HiOp
  10. hypre
  11. libEnsemble
  12. MAGMA
  13. MFEM
  14. Omega_h
  15. PETSc/TAO
  16. PHIST
  17. preCICE
  18. PLASMA
  19. PUMI
  20. SLATE
  21. SLEPc
  22. STRUMPACK
  23. SUNDIALS
  24. SuperLU
  25. Tasmanian
  26. Trilinos

and two applications packages:

  1. Alquimia
  2. PFLOTRAN,

which satisfy the required policies. Over the longer term, xSDK may expand to incorporate additional packages, depending on community needs and contributions.

xSDK Mandatory Policies

M1. Support portable installation through Spack.

M2. Provide a comprehensive test suite for correctness of installation verification.

M3. Employ user-provided MPI communicator (no MPI_COMM_WORLD). Don't assume a full MPI 3 implementation without checking. Provide an option to prevent any changes to MPI error-handling if it is changed by default.

M4. Give best effort at portability to key architectures (standard Linux distributions, GNU, Clang, vendor compilers, and target machines at ALCF, NERSC, OLCF).

M5. Provide a documented, reliable way to contact the development team.

M6. Respect system resources and settings made by other previously called packages (e.g. signal handling).

M7. Come with an open source (BSD style) license.

M8. Provide a runtime API to return the current version number of the software.

M9. Use a limited and well-defined symbol, macro, library, and include file name space.

M10. Provide a publicly available repository.

M11. Have no hardwired print or IO statements that cannot be turned off.

M12. For external dependencies, allow installing, building, and linking with an outside copy of external software.

M13. Install headers and libraries under <prefix>/include and <prefix>/lib.

M14. Be buildable using 64 bit pointers. 32 bit is optional.

M15. All xSDK compatibility changes should be sustainable.

M16. Have a debug build option.

M17. Provide sufficient documentation to support use and further development.

xSDK Recommended Policies

In addition to the required xSDK policies listed above, the following capabilities are also recommended.

R1. At least one validation (smoke) test that can be invoked through the Spack package.

R2. Possible to run test suite under Valgrind in order to test for memory corruption issues.

R3. Adopt and document consistent system for error conditions/exceptions.

R4. Free all system resources acquired as soon as they are no longer needed.

R5. Provide a mechanism to export ordered list of library dependencies.

R6. Document versions of packages that it works with or depends upon, preferably in machine-readable form.

R7. Have README, SUPPORT, LICENSE, and CHANGELOG files in top directory.

R8. Provide version comparision preprocessor macros.

History of the xSDK Community Policies

The original version of this document was prepared in 2015 by Barry Smith with key input from Roscoe Bartlett and feedback from members of the IDEAS project. Over time, revisions have been introduced based on discussions with the broader computational science community and developers of an expanding collection of xSDK member packages. We thank all xSDK package developers, the IDEAS team, and the scientific computing community for insightful discussion about issues and approaches.

  • Changes in version 1.0.0, February 17, 2023:

    • Made R1 (must have a public repository) mandatory, merging it into M10
    • Converted R8 (documentation) to a new mandatory policy (M17)
    • Added new recommended policy requiring a validation test, replacing R1
    • Added new recommended policy (provide version comparison preprocessor macros), replacing R8
    • Added wording to M13, clarifying the requirement and providing motivation for the policy
    • Added clarification to R5, giving rationale for the policy and an example of how to meet the requirement
    • Minor wording/grammar changes were made to M7 and R2, without changing meaning
  • Changes in version 0.6.0, October 12, 2020:

    • Added new policy R8 on documentation quality
    • Merged policies M1 and M16 with emphasis on use of Spack as xSDK installer
    • Eliminated installation policies which were included in previous M1
    • Provided a document with xSDK Spack variant guidelines
    • Added new policy M16, which requires an xSDK package to have a configuration option that allows building in debug mode, a requirement previously included in the eliminated installation policies
  • Changes in version 0.5.0, June 27, 2019:

    • Added new policy R7, which recommends the inclusion of various information files in the top directory
    • Dropped the requirement to detect MPI 2 features in M3
    • Made various editorial changes in M5, M13, M15, and R2 for clarification or to fix typos.
  • Changes in version 0.4.0, July 27, 2018:

    • Split policy M4 into 2 parts: M4 (portability to common platforms) and new policy R6 (package should document the versions of packages with which it can work on on which it depends). See xsdk-project/xsdk-issues#55
    • Revision to M7: language about open source licensing requirements. See xsdk-project/xsdk-issues#56
    • New section on history of policies and summary of changes, misc minor edits
  • Changes in version 0.3.0, November 6, 2017: added 2 new policies (M15 and M16), changed naming convention to follow xSDK release number, minor typo edits

  • Changes in version 0.3, December 2, 2016: clear definition of xSDK member packages, misc minor edits

  • Changes in version 0.2, January 28, 2016: minor edit

  • Version 0.1, November 10, 2015: original version

Frequently Asked Questions about xSDK

See the xSDK FAQ list.

Acknowledgment

This material is based upon work supported by the U.S. Department of Energy, Office of Science, Advanced Scientific Computing Research and Biological and Environmental Research programs.


1 For the purpose of this document, the term package refers to a collection of source code (possibly containing C, Fortran, or C++) that can generate zero or more shared or static libraries, zero or more include files, zero or more Fortran modules, and possibly other auxiliary artifacts, including executables, and whose functionality can be used by other packages and by application codes. A software artifact that generates only an executable is, by this definition, not an xSDK package; that is, xSDK packages are libraries, frameworks, and domain components.

2 See, for example, "Self-Sustaining Software" as outlined in http://trac.trilinos.org/wiki/TribitsLifecycleModelOverview#self_sustaining_software.