SELGJul 25, 2022

Differential testing for machine learning: an analysis for classification algorithms beyond deep learning

arXiv:2207.11976v16 citationsh-index: 24
Originality Synthesis-oriented
AI Analysis

This work addresses the problem of testing machine learning libraries for practitioners, but it is incremental as it extends differential testing from deep learning to other classification algorithms.

The study investigated the application of differential testing to classification algorithms beyond deep learning, finding that while there is potential for popular algorithms, feasibility is limited due to configuration mismatches, and tests revealed many deviations in scores and classes, with only a lenient statistical approach avoiding failures.

Context: Differential testing is a useful approach that uses different implementations of the same algorithms and compares the results for software testing. In recent years, this approach was successfully used for test campaigns of deep learning frameworks. Objective: There is little knowledge on the application of differential testing beyond deep learning. Within this article, we want to close this gap for classification algorithms. Method: We conduct a case study using Scikit-learn, Weka, Spark MLlib, and Caret in which we identify the potential of differential testing by considering which algorithms are available in multiple frameworks, the feasibility by identifying pairs of algorithms that should exhibit the same behavior, and the effectiveness by executing tests for the identified pairs and analyzing the deviations. Results: While we found a large potential for popular algorithms, the feasibility seems limited because often it is not possible to determine configurations that are the same in other frameworks. The execution of the feasible tests revealed that there is a large amount of deviations for the scores and classes. Only a lenient approach based on statistical significance of classes does not lead to a huge amount of test failures. Conclusions: The potential of differential testing beyond deep learning seems limited for research into the quality of machine learning libraries. Practitioners may still use the approach if they have deep knowledge about implementations, especially if a coarse oracle that only considers significant differences of classes is sufficient.

Code Implementations1 repo
Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes