Assessing and restoring reproducibility of Jupyter notebooks
Proceedings of the 35th IEEE/ACM International Conference on Automated …, 2020•dl.acm.org
Jupyter notebooks---documents that contain live code, equations, visualizations, and
narrative text---now are among the most popular means to compute, present, discuss and
disseminate scientific findings. In principle, Jupyter notebooks should easily allow to
reproduce and extend scientific computations and their findings; but in practice, this is not
the case. The individual code cells in Jupyter notebooks can be executed in any order, with
identifier usages preceding their definitions and results preceding their computations. In a …
narrative text---now are among the most popular means to compute, present, discuss and
disseminate scientific findings. In principle, Jupyter notebooks should easily allow to
reproduce and extend scientific computations and their findings; but in practice, this is not
the case. The individual code cells in Jupyter notebooks can be executed in any order, with
identifier usages preceding their definitions and results preceding their computations. In a …
Jupyter notebooks---documents that contain live code, equations, visualizations, and narrative text---now are among the most popular means to compute, present, discuss and disseminate scientific findings. In principle, Jupyter notebooks should easily allow to reproduce and extend scientific computations and their findings; but in practice, this is not the case. The individual code cells in Jupyter notebooks can be executed in any order, with identifier usages preceding their definitions and results preceding their computations. In a sample of 936 published notebooks that would be executable in principle, we found that 73% of them would not be reproducible with straightforward approaches, requiring humans to infer (and often guess) the order in which the authors created the cells.
In this paper, we present an approach to (1) automatically satisfy dependencies between code cells to reconstruct possible execution orders of the cells; and (2) instrument code cells to mitigate the impact of non-reproducible statements (i.e., random functions) in Jupyter notebooks. Our Osiris prototype takes a notebook as input and outputs the possible execution schemes that reproduce the exact notebook results. In our sample, Osiris was able to reconstruct such schemes for 82.23% of all executable notebooks, which has more than three times better than the state-of-the-art; the resulting reordered code is valid program code and thus available for further testing and analysis.
ACM Digital Library