An industrial case study of classifier ensembles for locating software defects

Ayşe Tosun Misirli, Ayşe Başar Bener, Burak Turhan

Research output: Contribution to journalArticleResearchpeer-review

50 Citations (Scopus)

Abstract

As the application layer in embedded systems dominates over the hardware, ensuring software quality becomes a real challenge. Software testing is the most time-consuming and costly project phase, specifically in the embedded software domain. Misclassifying a safe code as defective increases the cost of projects, and hence leads to low margins. In this research, we present a defect prediction model based on an ensemble of classifiers. We have collaborated with an industrial partner from the embedded systems domain. We use our generic defect prediction models with data coming from embedded projects. The embedded systems domain is similar to mission critical software so that the goal is to catch as many defects as possible. Therefore, the expectation from a predictor is to get very high probability of detection (pd). On the other hand, most embedded systems in practice are commercial products, and companies would like to lower their costs to remain competitive in their market by keeping their false alarm (pf) rates as low as possible and improving their precision rates. In our experiments, we used data collected from our industry partners as well as publicly available data. Our results reveal that ensemble of classifiers significantly decreases pf down to 15% while increasing precision by 43% and hence, keeping balance rates at 74%. The cost-benefit analysis of the proposed model shows that it is enough to inspect 23% of the code on local datasets to detect around 70% of defects.

Original languageEnglish
Pages (from-to)515-536
Number of pages22
JournalSoftware Quality Journal
Volume19
Issue number3
DOIs
Publication statusPublished - 1 Jan 2011
Externally publishedYes

Keywords

  • Defect prediction
  • Embedded software
  • Ensemble of classifiers
  • Static code attributes

Cite this