@inproceedings{90398427752a4c67a313f03f4c883c6b,
title = "Subsuming methods: Finding new optimisation opportunities in object-oriented software",
abstract = "The majority of existing application profiling techniques ag- gregate and report performance costs by method or call- ing context. Modern large-scale object-oriented applications consist of thousands of methods with complex calling pat- terns. Consequently, when profiled, their performance costs tend to be thinly distributed across many thousands of loca- tions with few easily identifiable optimisation opportunities. However experienced performance engineers know that there are repeated patterns of method calls in the execution of an application that are induced by the libraries, design patterns and coding idioms used in the software. Automati- cally identifying and aggregating costs over these patterns of method calls allows us to identify opportunities to improve performance based on optimising these patterns. We have developed an analysis technique that is able to identify the entry point methods, which we call subsuming methods, of such patterns. Our ofiine analysis runs over previously collected runtime performance data structured in a calling context tree, such as produced by a large number of existing commercial and open source profilers. We have evaluated our approach on the DaCapo bench- mark suite, showing that our analysis significantly reduces the size and complexity of the runtime performance data set, facilitating its comprehension and interpretation. We also demonstrate, with a collection of case studies, that our analysis identifies new optimisation opportunities that can lead to significant performance improvements (from 20% to over 50% improvement in our case studies).",
keywords = "Dynamic performance analysis, Profiling, Runtime bloat, Subsuming methods",
author = "David Maplesden and Ewan Tempero and John Hosking and Grundy, {John C.}",
note = "Publisher Copyright: Copyright {\textcopyright} 2015 ACM.; 6th ACM/SPEC International Conference on Performance Engineering, ICPE 2015 ; Conference date: 31-01-2015 Through 04-02-2015",
year = "2015",
month = jan,
day = "28",
doi = "10.1145/2668930.2688040",
language = "English",
series = "ICPE 2015 - Proceedings of the 6th ACM/SPEC International Conference on Performance Engineering",
publisher = "Association for Computing Machinery (ACM)",
pages = "175--186",
booktitle = "ICPE 2015 - Proceedings of the 6th ACM/SPEC International Conference on Performance Engineering",
address = "United States",
}