Behavioral Resource-Aware Model Inference
by Tony Ohmann, Michael Herzberg, Sebastian Fiss, Armand Halbert, Marc Palyart, Ivan Beschastnikh, Yuriy Brun
Abstract:

Software bugs often arise because of differences between what developers think their system does and what the system actually does. These differences frustrate debugging and comprehension efforts. We describe Perfume, an automated approach for inferring behavioral, resource-aware models of software systems from logs of their executions. These finite state machine models ease understanding of system behavior and resource use.

Perfume improves on the state of the art in model inference by differentiating behaviorally similar executions that differ in resource consumption. For example, Perfume separates otherwise identical requests that hit a cache from those that miss it, which can aid understanding how the cache affects system behavior and removing cache-related bugs. A small user study demonstrates that using Perfume is more effective than using logs and another model inference tool for system comprehension. A case study on the TCP protocol demonstrates that Perfume models can help understand non-trivial protocol behavior. Perfume models capture key system properties and improve system comprehension, while being reasonably robust to noise likely to occur in real-world executions.

Citation:
Tony Ohmann, Michael Herzberg, Sebastian Fiss, Armand Halbert, Marc Palyart, Ivan Beschastnikh, and Yuriy Brun, Behavioral Resource-Aware Model Inference, in Proceedings of the 29th IEEE/ACM International Conference on Automated Software Engineering (ASE), 2014, pp. 19–30.
Bibtex:
@inproceedings{Ohmann14ase,
  author = {Tony Ohmann and Michael Herzberg and Sebastian Fiss and
  Armand Halbert and Marc Palyart and Ivan Beschastnikh and 
  Yuriy Brun},
  title =
  {\href{http://people.cs.umass.edu/brun/pubs/pubs/Ohmann14ase.pdf}{Behavioral
  Resource-Aware Model Inference}},
  booktitle = {Proceedings of the 29th IEEE/ACM International
  Conference on Automated Software Engineering (ASE)},
  venue = {ASE},
  pages = {19--30},
  address = {V{\"{a}}ster{\aa}s, Sweden},
  month = {September},
  date = {15--19},
  year = {2014},
  accept = {$\frac{50}{258} \approx 19\%$},

  doi = {10.1145/2642937.2642988},  
  note = {\href{https://doi.org/10.1145/2642937.2642988}{DOI: 10.1145/2642937.2642988}},

  abstract = {<p>Software bugs often arise because of differences between what
  developers think their system does and what the system actually does.
  These differences frustrate debugging and comprehension efforts. We
  describe Perfume, an automated approach for inferring behavioral,
  resource-aware models of software systems from logs of their
  executions. These finite state machine models ease understanding of
  system behavior and resource use.</p>

  <p>Perfume improves on the state of the art in model inference by
  differentiating behaviorally similar executions that differ in
  resource consumption. For example, Perfume separates otherwise
  identical requests that hit a cache from those that miss it, which can
  aid understanding how the cache affects system behavior and removing
  cache-related bugs. A small user study demonstrates that using Perfume
  is more effective than using logs and another model inference tool for
  system comprehension. A case study on the TCP protocol demonstrates
  that Perfume models can help understand non-trivial protocol behavior.
  Perfume models capture key system properties and improve system
  comprehension, while being reasonably robust to noise likely to occur
  in real-world executions.</p>},

  fundedBy = {NSERC, Microsoft Research via a SEIF award},
}