Cargando…

ATLAS Offline Software Performance Monitoring and Optimization

In a complex multi-developer, multi-package software environment, such as the ATLAS offline Athena framework, tracking the performance of the code can be a non-trivial task in itself. In this paper we describe improvements in the instrumentation of ATLAS offline software that have given considerable...

Descripción completa

Detalles Bibliográficos
Autores principales: Chauhan, N, Kabra, G, Kittelmann, T, Langenberg, R, Mandrysch , R, Salzburger, A, Seuster, R, Ritsch, E, Stewart, G, van Eldik, N, Vitillo, R
Lenguaje:eng
Publicado: 2013
Materias:
Acceso en línea:https://dx.doi.org/10.1088/1742-6596/513/5/052022
http://cds.cern.ch/record/1622268
_version_ 1780933237362655232
author Chauhan, N
Kabra, G
Kittelmann, T
Langenberg, R
Mandrysch , R
Salzburger, A
Seuster, R
Ritsch, E
Stewart, G
van Eldik, N
Vitillo, R
author_facet Chauhan, N
Kabra, G
Kittelmann, T
Langenberg, R
Mandrysch , R
Salzburger, A
Seuster, R
Ritsch, E
Stewart, G
van Eldik, N
Vitillo, R
author_sort Chauhan, N
collection CERN
description In a complex multi-developer, multi-package software environment, such as the ATLAS offline Athena framework, tracking the performance of the code can be a non-trivial task in itself. In this paper we describe improvements in the instrumentation of ATLAS offline software that have given considerable insight into the performance of the code and helped to guide optimisation. Code can be instrumented firstly using the PAPI tool, which is a programing interface for accessing hardware performance counters. PAPI events can count floating point operations, cycles and instructions and cache accesses. Triggering PAPI to start/stop counting for each algorithm and processed event gives a good understanding of the whole algorithm level performance of ATLAS code. Further data can be obtained using pin, a dynamic binary instrumentation tool. Pintools can be used to obtain similar statistics as PAPI, but advantageously without requiring recompilation of the code. Fine grained routine and instruction level instrumentation is also possible. Pintools can additionally interrogate the arguments to functions, like those in linear algebra libraries, so that a detailed usage profile can be obtained. These tools have charaterised the extensive use of vector and matrix operations in ATLAS tracking. Currently, CLHEP is used here, which is not an optimal choice. To help evaluate replacement libraries a testbed has been setup allowing comparison of the performance of different linear algebra libraries (including CLHEP, Eigen and SMatrix/SVector). Results are then presented via the ATLAS Performance Management Board framework, which runs daily with the current development branch of the code and monitors reconstruction and Monte-Carlo jobs. This framework analyses the CPU and memory performance of algorithms and an overview of results are presented on a web page. These tools have provided the insight necessary to plan and implement performance enhancements in ATLAS code by identifying the most common operations, with the call parameters well understood, and allowing improvements to be quantified in detail.
id cern-1622268
institution Organización Europea para la Investigación Nuclear
language eng
publishDate 2013
record_format invenio
spelling cern-16222682019-09-30T06:29:59Zdoi:10.1088/1742-6596/513/5/052022http://cds.cern.ch/record/1622268engChauhan, NKabra, GKittelmann, TLangenberg, RMandrysch , RSalzburger, ASeuster, RRitsch, EStewart, Gvan Eldik, NVitillo, RATLAS Offline Software Performance Monitoring and OptimizationDetectors and Experimental TechniquesIn a complex multi-developer, multi-package software environment, such as the ATLAS offline Athena framework, tracking the performance of the code can be a non-trivial task in itself. In this paper we describe improvements in the instrumentation of ATLAS offline software that have given considerable insight into the performance of the code and helped to guide optimisation. Code can be instrumented firstly using the PAPI tool, which is a programing interface for accessing hardware performance counters. PAPI events can count floating point operations, cycles and instructions and cache accesses. Triggering PAPI to start/stop counting for each algorithm and processed event gives a good understanding of the whole algorithm level performance of ATLAS code. Further data can be obtained using pin, a dynamic binary instrumentation tool. Pintools can be used to obtain similar statistics as PAPI, but advantageously without requiring recompilation of the code. Fine grained routine and instruction level instrumentation is also possible. Pintools can additionally interrogate the arguments to functions, like those in linear algebra libraries, so that a detailed usage profile can be obtained. These tools have charaterised the extensive use of vector and matrix operations in ATLAS tracking. Currently, CLHEP is used here, which is not an optimal choice. To help evaluate replacement libraries a testbed has been setup allowing comparison of the performance of different linear algebra libraries (including CLHEP, Eigen and SMatrix/SVector). Results are then presented via the ATLAS Performance Management Board framework, which runs daily with the current development branch of the code and monitors reconstruction and Monte-Carlo jobs. This framework analyses the CPU and memory performance of algorithms and an overview of results are presented on a web page. These tools have provided the insight necessary to plan and implement performance enhancements in ATLAS code by identifying the most common operations, with the call parameters well understood, and allowing improvements to be quantified in detail.ATL-SOFT-PROC-2013-040oai:cds.cern.ch:16222682013-10-30
spellingShingle Detectors and Experimental Techniques
Chauhan, N
Kabra, G
Kittelmann, T
Langenberg, R
Mandrysch , R
Salzburger, A
Seuster, R
Ritsch, E
Stewart, G
van Eldik, N
Vitillo, R
ATLAS Offline Software Performance Monitoring and Optimization
title ATLAS Offline Software Performance Monitoring and Optimization
title_full ATLAS Offline Software Performance Monitoring and Optimization
title_fullStr ATLAS Offline Software Performance Monitoring and Optimization
title_full_unstemmed ATLAS Offline Software Performance Monitoring and Optimization
title_short ATLAS Offline Software Performance Monitoring and Optimization
title_sort atlas offline software performance monitoring and optimization
topic Detectors and Experimental Techniques
url https://dx.doi.org/10.1088/1742-6596/513/5/052022
http://cds.cern.ch/record/1622268
work_keys_str_mv AT chauhann atlasofflinesoftwareperformancemonitoringandoptimization
AT kabrag atlasofflinesoftwareperformancemonitoringandoptimization
AT kittelmannt atlasofflinesoftwareperformancemonitoringandoptimization
AT langenbergr atlasofflinesoftwareperformancemonitoringandoptimization
AT mandryschr atlasofflinesoftwareperformancemonitoringandoptimization
AT salzburgera atlasofflinesoftwareperformancemonitoringandoptimization
AT seusterr atlasofflinesoftwareperformancemonitoringandoptimization
AT ritsche atlasofflinesoftwareperformancemonitoringandoptimization
AT stewartg atlasofflinesoftwareperformancemonitoringandoptimization
AT vaneldikn atlasofflinesoftwareperformancemonitoringandoptimization
AT vitillor atlasofflinesoftwareperformancemonitoringandoptimization