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).
Original language | English |
---|---|
Title of host publication | Proceedings of the 6th ACM/SPEC International Conference on Performance Engineering |
Editors | Kai Sachs, Catalina M. Lladó, Herb Schwetman |
Place of Publication | New York NY USA |
Publisher | Association for Computing Machinery (ACM) |
Pages | 175-186 |
Number of pages | 12 |
ISBN (Electronic) | 9781450332484 |
DOIs | |
Publication status | Published - 2015 |
Externally published | Yes |
Event | ACM/SPEC International Conference on Performance Engineering 2015 - Austin, United States of America Duration: 31 Jan 2015 → 4 Feb 2015 Conference number: 6th https://icpe2015.spec.org/ |
Conference
Conference | ACM/SPEC International Conference on Performance Engineering 2015 |
---|---|
Abbreviated title | ICPE 2015 |
Country | United States of America |
City | Austin |
Period | 31/01/15 → 4/02/15 |
Internet address |
Keywords
- Dynamic performance analysis
- Profiling
- Runtime bloat
- Subsuming methods