posted on 2023-11-29, 18:13authored byAlexander Kampmann, Nikolas Havrikov, Ezekiel Soremekun, Andreas ZellerAndreas Zeller
We introduce Alhazen—an approach that automatically determines the circumstances under which a particular program behavior, such as a failure, takes place. Alhazen starts with a run that exhibits this behavior and automatically determines _input features_ associated with the behavior in question:
(1) We use a _grammar_ to parse the input into individual elements.
(2) We determine _features_ from the elements such as existence, length, or numerical values.
(3) We use a decision tree learner to _observe_ and _learn_ which input features are associated with the behavior in question.
(4) We use the grammar to _generate additional inputs_ to further strengthen or refute hypotheses as learned associations.
(5) By repeating steps 2 to 4, we obtain a _theory_ that explains and predicts the given behavior.
In our evaluation using inputs for find, grep, NetHack, and a JavaScript transpiler, the theories produced by Alhazen predict and produce failures with high accuracy and allow developers to focus on a small set of input features: “grep fails whenever the --fixed-strings option is used in conjunction with an empty search string.”
History
Preferred Citation
Alexander Kampmann, Nikolas Havrikov, Ezekiel Soremekun and Andreas Zeller. When does my Program do this? Learning Circumstances of Software Behavior. In: European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE). 2020.
Primary Research Area
Secure Connected and Mobile Systems
Secondary Research Area
Empirical and Behavioral Security
Name of Conference
European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE)
Legacy Posted Date
2020-06-12
Open Access Type
Unknown
BibTeX
@inproceedings{cispa_all_3107,
title = "When does my Program do this? Learning Circumstances of Software Behavior",
author = "Kampmann, Alexander and Havrikov, Nikolas and Soremekun, Ezekiel and Zeller, Andreas",
booktitle="{European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE)}",
year="2020",
}