8 research outputs found
Incremental Calibration of Architectural Performance Models with Parametric Dependencies
Architecture-based Performance Prediction (AbPP) allows evaluation of the
performance of systems and to answer what-if questions without measurements for
all alternatives. A difficulty when creating models is that Performance Model
Parameters (PMPs, such as resource demands, loop iteration numbers and branch
probabilities) depend on various influencing factors like input data, used
hardware and the applied workload. To enable a broad range of what-if
questions, Performance Models (PMs) need to have predictive power beyond what
has been measured to calibrate the models. Thus, PMPs need to be parametrized
over the influencing factors that may vary.
Existing approaches allow for the estimation of parametrized PMPs by
measuring the complete system. Thus, they are too costly to be applied
frequently, up to after each code change. They do not keep also manual changes
to the model when recalibrating.
In this work, we present the Continuous Integration of Performance Models
(CIPM), which incrementally extracts and calibrates the performance model,
including parametric dependencies. CIPM responds to source code changes by
updating the PM and adaptively instrumenting the changed parts. To allow AbPP,
CIPM estimates the parametrized PMPs using the measurements (generated by
performance tests or executing the system in production) and statistical
analysis, e.g., regression analysis and decision trees.
Additionally, our approach responds to production changes (e.g., load or
deployment changes) and calibrates the usage and deployment parts of PMs
accordingly.
For the evaluation, we used two case studies. Evaluation results show that we
were able to calibrate the PM incrementally and accurately.Comment: Manar Mazkatli is supported by the German Academic Exchange Service
(DAAD
Reconstruction of Software Component Architectures and Behaviour Models using Static and Dynamic Analysis
Model-based performance prediction systematically deals with the evaluation of software performance to avoid for example bottlenecks, estimate execution environment sizing, or identify scalability limitations for new usage scenarios. Such performance predictions require up-to-date software performance models. This book describes a new integrated reverse engineering approach for the reconstruction of parameterised software performance models (software component architecture and behaviour)
Explicitly Integrated Architecture - An Approach for Integrating Software Architecture Model Information with Program Code
Software-Architekturspezifikationen und -Implementierungen sind zwei Sichtweisen auf Softwarearchitektur. Sie beschreiben gemeinsame Aspekte, wie z.B. die Existenz und Verbindung von Komponenten. Die Spezifikation fügt Informationen zum Design, zur Kommunikation und zur Analyse hinzu. Die Implementierung beschreibt stattdessen zusätzlich Details für ein ausführbares System. Die Konsistenz zwischen diesen Darstellungen manuell zu verwalten, ist schwierig und fehleranfällig. Diese Arbeit stellt einen Ansatz vor, der Informationen der Architekturspezifikation vollständig in die Implementierung integriert, sodass die Spezifikation als eigenständiges Artefakt nicht mehr notwendig ist. Das Tool Codeling extrahiert die integrierte Architekturspezifikation in unterschiedlichen Sprachen aus dem Code und propagiert Änderungen in dieser Spezifikation automatisch an den Code zurück.Specifications and implementations are both viewpoints upon software architecture. Besides common aspects, the specification adds information for design, communication, or analysis, while the implementation adds details for an executable system instead. Managing the consistency between these representations manually is difficult and error-prone. This thesis presents an approach, that completely integrates architecture specifications with the implementation, so that separate specification artifacts are not necessary anymore. The tool Codeling extracts integrated architecture specifications in multiple languages from code, and automatically propagates changes in these specifications back to the code
An Approach for Guiding Developers to Performance and Scalability Solutions
The quality of enterprise software applications plays a crucial role for the satisfaction of the users and the economic success of the enterprises. Software applications with unsatisfying performance and scalability are perceived by its users as low in quality, as less interesting and less attractive, and cause frustration when preventing the users from attaining their goals. This book proposes an approach for a recommendation system that enables developers who are novices in software perfor