A Comprehensive Study on Deep Learning Bug Characteristics

By: Md Johirul Islam, Giang Nguyen, Rangeet Pan, and Hridesh Rajan

PDF Download Download Paper
Dataset

Abstract

Deep learning has gained substantial popularity in recent years. Developers mainly rely on libraries and tools to add deep learning capabilities to their software. What kinds of bugs are frequently found in such software? What are the root causes of such bugs? What impacts do such bugs have? Which stages of deep learning pipeline are more bug prone? Are there any antipatterns? Understanding such characteristics of bugs in deep learning software has the potential to foster the development of better deep learning platforms, debugging mechanisms, development practices, and encourage the development of analysis and verification frameworks. Therefore, we study 2716 high-quality posts from Stack Overflow and 500 bug fix commits from Github about five popular deep learning libraries Caffe, Keras, Tensorflow, Theano, and Torch to understand the types of bugs, root causes of bugs, impacts of bugs, bug-prone stage of deep learning pipeline as well as whether there are some common antipatterns found in this buggy software. The key findings of our study include: data bug and logic bug are the most severe bug types in deep learning software appearing more than 48% of the times, major root causes of these bugs are Incorrect Model Parameter (IPS) and Structural Inefficiency (SI) showing up more than 43% of the times. We have also found that the bugs in the usage of deep learning libraries have some common antipatterns that lead to a strong correlation of bug types among the libraries.

ACM Reference

Islam, M.J. et al. 2019. A Comprehensive Study on Deep Learning Bug Characteristics. ESEC/FSE’19: The ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE) (Aug. 2019).

BibTeX Reference

@inproceedings{islam19,
  author = {Md Johirul Islam and Giang Nguyen and Rangeet Pan and Hridesh Rajan},
  title = {A Comprehensive Study on Deep Learning Bug Characteristics},
  booktitle = {ESEC/FSE'19: The ACM Joint European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE)},
  series = {ESEC/FSE 2019},
  month = {August},
  year = {2019},
  entrysubtype = {conference},
  abstract = {
    Deep learning has gained substantial popularity in recent years.
    Developers mainly rely on libraries and tools to add deep learning
    capabilities to their software. What kinds of bugs are frequently
    found in such software? What are the root causes of such bugs?
    What impacts do such bugs have? Which stages of deep learning
    pipeline are more bug prone? Are there any antipatterns?
    Understanding such characteristics of bugs in deep learning
    software has the potential to foster the development of better
    deep learning platforms, debugging mechanisms, development practices,
    and encourage the development of analysis and verification frameworks.
    Therefore, we study 2716 high-quality posts from Stack Overflow
    and 500 bug fix commits from Github about five popular deep learning
    libraries Caffe, Keras, Tensorflow, Theano, and Torch to understand
    the types of bugs, root causes of bugs, impacts of bugs, bug-prone
    stage of deep learning pipeline as well as whether there are some
    common antipatterns found in this buggy software.
    The key findings of our study include: data bug and logic bug are
    the most severe bug types in deep learning software appearing more
    than 48% of the times, major root causes of these bugs are Incorrect
    Model Parameter (IPS) and Structural Inefficiency (SI) showing up
    more than 43% of the times.
    We have also found that the bugs in the usage of deep learning
    libraries have some common antipatterns that lead to a strong
    correlation of bug types among the libraries.
  }
}