Visual Computing Group
Singapore University of Technology and Design
[The following materials are compiled from various sources such as textbooks, lecture materials, conference talks, web resources and are shared for research purposes only. In the interest of brevity, every source is not cited. The compiler of these materials gratefully acknowledges all such sources. Please contact [email protected] for any queries.]
Predominant portion of contemporary machine learning research faces reproducibility and replication crisis. Though both terms are used interchangeably in the literature, we understand reproducibility as the gateway for replication.
Reproducibility is the ability to obtain closeness of the agreement between the results of measurements of the same measurand, carried out by using identical methodology and identical artifacts described in a scientific work.
Replication is the ability to obtain consistent closeness of the agreement between the results of measurements of the same measurand, carried out by using identical methodology described in a scientific work across multiple relevant artifacts.
This Guide book is written with the intention of helping researchers and engineers working in machine learning domains to publish reproducible research. We break research components into two for reproducibility purposes. 1) Compulsory/ required components and 2) Optional components. They are clearly explained in the upcoming sections.
Note: Please feel free to contribute/ correct any mistakes. If you are interested in understanding more, please refer to this talk on Machine Learning Reproducibility, NeurIPS 2019.
- Required Components
- Optional Components
A large portion of machine learning code repositories do not include concrete information on data. We identify a list of key elements where authors should clearly address with respect to data to allow reproducibility.
- Authors should publish or include links for the original data used for their research. Even if benchmark datasets are used (i.e.: ImageNet), including links to these data repositories to avoid any confusions.
- In instances where the authors cannot publish the data used for their research due to data confidentiality or other factors (i.e.: Medical data), this should clearly be mentioned in the code repository.
- In order to alleviate data confidentiality issues, some authors publish synthetic data to evaluate their research methods. In these instances, authors should clearly describe the process and methods used to generate these data.
- Licensing information for datasets should be strictly included (Even if benchmark datasets are used).
- Most algorithms may require pre-processing techniques. So authors need to clearly describe all relevant information with respect to data preprocessing. Wherever possible, the authors should publish preprocessed data allowing to reproduce research results more easily.
- Clear splits of data used for training, validation and test should be published. Many code repositories do this by including a txt/ csv file describing the splits.
This section is generally deterministic.
-
The code should include clear implementation of proposed method (i.e.: architecture, loss functions, evaluation metrics).
-
Complexity details (space, time and sample size) should be included.
-
Any diagrams associated with proposed method can be included here.
With increasing data volumes and distributed training strategies, it is vital to include clear details on the hardware setup used to run the experiments.
-
Authors should indicate as to whether they used in-house machines, super-computing facilities or cloud computing instances to run their experiments.
-
They can provide additional information on specific cloud computing vendor (AWS/ GCP) to help other researchers working on similar problems.
- Authors should include clear details on the CPU configuration used for running the experiments.
- Authors should include clear details on GPU/ TPU configuration used for running the experiments.
- Authors should include information on the list of operating systems (with version details) in which the code was tested.
- Authors should include information on the list of programming language versions in which the code was tested.
- For most machine learning applications, we use existing frameworks (Tensorflow, Pytorch, Caffe etc). Authors should include information on the list of frameworks/ framework versions in which the code was tested.
- If authors used any additional software (i.e.: Unity game engine for generating synthetic data), they should be clearly mentioned. If any proprietary software was used, include references to that as well.
- Licensing information for any other additional software used should be mentioned.
- Most software libraries do not function standalone. Hence the list of dependencies need to be explicitly mentioned. i.e.: For python based projects, many repositories include dependencies as a text file. (requirements.txt)
- Containers are a way to package software in a format that can run isolated on a shared operating system. Authors can alternatively publish/ distribute docker images with source code, so that users do not need to worry about setting up dependencies.
For your repository to truly be open source, you'll need to license it so that others are free to use, change, and distribute the software. So please add the corresponding license file to your code repository. This tool can help you understand how to license your code.
- All quantitative results with relevant diagrams should be included. In many instances, including graphics from the corresponding scientific work can help here.
- Results that could not be included in the original publication (i.e.: due to page limit etc), can be included here.
- In many instances, final results are obtained by averaging over a number pf independent executions of the algorithm. Authors should include these information as well.
-
Any quantitative results with relevant diagrams should be included.
-
Results that could not be included in the original publication (i.e.: due to page limit etc), can be included here.
Generally there are multiple stochastic elements associated with machine learning research. Hence precise information on final values of all hyper-parameters, methods used to obtain them and randomization control settings need to be included.
- Clear details on seed values to reproduce the results should be included.
Many research code repositories forget to address this factor. As we know, many machine learning algorithms are computationally very intensive and time-consuming. So clear details on the following should be included:
Information on how long it takes to train a single model should be included. This should correspond to the hardware and software settings mentioned above.
Information on how long it takes to run inference need to be included (i.e.: Object detection inference time per image). This should correspond to the hardware and software settings mentioned above.
Most code repositories do not have a standard structure. Hence, we propose to follow a standard code directory structure to make reproducibility easier. (We also do understand that it may not be possible to follow this structure for all projects)
-
/assets: contains GitHub readme resources (i.e. : images used in readme.md)
-
/src : contains all source code files
-
/data: contains required data
-
/config: contains configuration files (if any)
-
/output: contains any results or outputs
-
requirements.txt: contains all software dependencies to run the code.
-
LICENSE: License file
This is the most important section. Authors should clearly describe the steps on how to run the code and reproduce the results.
Authors should mention whether pretrained weights are made available and describe the means of obtaining them. Having a single centralized cloud location to publish all the models belonging to the organization is often useful.
Any references to code/ data obtained from from sources need to be citied here. (Not publication references).
Citation information should be included here
Acknowledgements enable you to thank all those who have helped in carrying out the research. Please keep it concise.
If the work was part of a conference, links to materials such as video presentations, poster and blogs can be included.
Authors can optionally include any contact information for feedback or discussion.
Authors can also add a FAQ section to answer commonly asked queries.