Skip to content

Latest commit

 

History

History
110 lines (83 loc) · 6.23 KB

File metadata and controls

110 lines (83 loc) · 6.23 KB

Software Development Best Practices of the AI-READI Project

View the latest version of the best practices:

🌐 On our development website »
📁 In this repository »
☁️ On Zenodo »

⚠️ Report Issue or make suggestions


stars open issues license doi

Table of Contents

About

This repository is meant to share and maintain the software development best practices of the AI-READI project. The rationales for establishing these best practices are to:

  • Help the standardization of the AI-READI software to facilitate future reuse, i.e. make the AI-READI software Findable, Accessible, Interoperable, and Reusable (FAIR)
  • Ensure the efficient and effective development of software across the project, especially when contributions from several teams are required
  • Facilitate on-boarding of new developers to the project

Our focus here is on establishing actionable best practices that can be directly implemented by the project's developers. These best practices are intended to remain general enough that they can apply to any software development project within AI-READI.

This repository is also meant to collect feedback/suggestions (through the GitHub issues) such that we can improve our guidelines and/or align them with external teams (e.g., other teams from the Bridge2AI consortium).

Repository structure

Each version of the best practices is stored in a dedicated folder under the versions folder. Each version includes:

  1. The best practices, are provided in markdown format (one file per section of the best practices).
  2. The rationale behind the different elements of the best practices, is provided in markdown format.
  3. The approach for monitoring the implementation of the best practices in the project, provided in markdown format.
  4. A pdf file combining all of the above.

Changes between the different versions are tracked in the CHANGELOG file. A main folder contains the latest version of the best practices. Pull requests with suggestions should be made from that folder.

Feedback and suggestions

Use the GitHub issues for submitting feedback or making suggestions. You can also fork the repository and submit a pull request with suggestions by making changes to the files in the main folder. Only edit the markdown files (the pdf files will be created by the approvers of the suggested changes). Suggestions will be reviewed and, if deemed adequate, approved by the AI-READI Tools module PIs (with the inclusion of other team members as necessary).

New version release process

When changes are approved to the main folder, a copy with a new version number will be added to the versions folder.

A GitHub release is created for each new version of the best practices. The pdf version of the best practice document is archived on Zenodo with each release such that each version of the best practices can be referenced with a unique digital object identifier (DOI). Additionally, the latest version of best practices will be visible on dev.aireadi.org, the developer documentation website for the AI-READI project. This documentation will display the best practices in a user-friendly manner and will contain additional elements (e.g., code snippets) such that the best practices can be easily implemented by developers.

License

This work is licensed under a Creative Commons Attribution 4.0 International License. See LICENSE for more information.

CC BY 4.0

How to cite

If you are following these best practices or reusing them for any purpose, please cite:

Patel, Bhavesh, Soundarajan, Sanjay, McWeeney, Shannon, Cordier, Benjamin A., & Benton, Erik S. (2022). 
Software Development Best Practices of the AI-READI Project (v1.0.0). Zenodo. https://doi.org/10.5281/zenodo.7363102

Acknowledgement

This project is funded by the NIH under award number 1OT2OD032644. The content is solely the responsibility of the authors and does not necessarily represent the official views of the NIH.