# HEP Benchmark Suite: Enhancing Efficiency and Sustainability in Worldwide LHC Computing Infrastructures

Natalia Szczepanek $^1,$  David Britton $^2,$  Alessandro Di Girolamo $^1,$  $\rm E$ woud Ketel $\rm \bar{e}^{1},$  Ivan Glushkov $^{3},$  Domenico Giordano $^{1},$  Ladislav Ondris<sup>1</sup>, Emanuele Simili<sup>2</sup>, Gonzalo Menendez Borge<sup>1</sup>

<sup>1</sup>CERN, European Laboratory for Particle Physics, Geneva, Switzerland <sup>2</sup>University of Glasgow, Glasgow, United Kingdom <sup>3</sup>University of Texas, Arlington, United States

E-mail: natalia.diana.szczepanek@cern.ch, domenico.giordano@cern.ch

Abstract. As the scientific community continues to push the boundaries of computing capabilities, there is a growing responsibility to address the associated energy consumption and carbon footprint. This responsibility extends to the Worldwide LHC Computing Grid (WLCG), encompassing over 170 sites in 40 countries, supporting vital computing, disk, tape storage and network for LHC experiments. Ensuring efficient operational practices across these diverse sites is crucial beyond mere performance metrics. This paper introduces the HEP Benchmark suite, an enhanced suite designed to measure computing resource performance uniformly across all WLCG sites, using HEPScore23 as performance unit. The suite expands beyond assessing only the execution speed via HEPScore23. In fact the suite incorporates metrics such as machine load, memory usage, memory swap, and notably, power consumption. Its adaptability and user-friendly interface enable comprehensive acquisition of system-related data alongside benchmarking. Throughout 2023, this tool underwent rigorous testing across numerous WLCG sites. The focus was on studying compute job slot performance and correlating these with fabric metrics. Initial analysis unveiled the tool's efficacy in establishing a standardized model for compute resource utilization while pinpointing anomalies, often stemming from site misconfigurations. This paper aims to elucidate the tool's functionality and present the results obtained from extensive testing. By disseminating this information, the objective is to raise awareness within the community about this probing model, fostering broader adoption and encouraging responsible computing practices that prioritize both performance and environmental impact mitigation.

## 1 Introduction

The Worldwide LHC Computing Grid (WLCG) contain more than 170 sites in over 40 countries providing computing, disk, tape storage and network to the LHC experiments. The WLCG adopted HEPScore23 (HS23) [\[1\]](#page-6-0) as a performance metric for resource capacity planning, hardware acquisition, pledging of future resources and usage accounting of the experiments. HEPScore is a tool that coordinates the consecutive execution of various containerised HEP-Workloads containers and determine the final benchmark score of a given compute resource [\[2\]](#page-6-1). HEPScore is orchestrated by the HEP Benchmark Suite, which also enables the execution for non-HEP benchmarks such as HEP-SPEC06 (HS06) [\[3\]](#page-6-2), SPEC CPU 2017 [\[4\]](#page-6-3),

and DB12 [\[5\]](#page-6-4). HS23 includes seven workloads from five experiments, each running with 3 repetitions with the latest version of the experimental software, which supports both x86 64 and aarch64 architectures. This is particularly important as several new architectures are expected to emerge in the future alongside  $x86.64$  currently used in WLCG. The reference machine for this benchmark is an Intel® Xeon® Gold 6326 CPU @ 2.90 GHz with hyperthreading (HT) enabled [\[2\]](#page-6-1). The Suite can be easily installed and used as described in [\[6\]](#page-6-5). Thanks to the design of the Suite, it is possible to publish the results to dedicated

<span id="page-1-0"></span>

Figure 1: The HEPiX Benchmarking Solution for WLCG Computing Resources provides a reusable infrastructure suitable for various workload management systems. The HEP Benchmark Suite integrates with any job submission infrastructure, allowing jobs to be submitted to selected sites. Once the job containing the benchmarking script is executed, the results are automatically sent via message broker to dedicated database. From there, site managers, researchers, and other users can retrieve and analyze the results.

database; and then to perform data analysis using visualization tools such as Grafana [\[7\]](#page-6-6). HEPScore can be adjusted to experiments needs and be used not only on bare-metal nodes [\[8\]](#page-6-7) and local machines, but also in automated or semi-automated way on WLCG batch system, by combining the Suite with the experiments job submission infrastructures, which is conceptually presented in Figure [1](#page-1-0). It was positively tested with the ATLAS [\[9\]](#page-6-8) and LHCb [\[10\]](#page-6-9) collaborations. This approach can scale up the data acquisition of benchmarking data and allow more accurate and broad analysis.

Continuous acquisition and monitoring of benchmark data offer significant benefits for experiments. This process aids in monitoring machine performance, facilitates decision-making regarding site utilization, and assists in resolving configuration issues. Site administrators can leverage this system to oversee their infrastructure, while experiments can utilize the data to optimize site usage and detect any misconfigurations. The HEPiX Benchmarking Working group extended use of the HEP Benchmark Suite beyond conventional boundaries. Despite the existing capability to capture performance and diverse system information, the group designed a highly adaptable and user-friendly methods for acquiring various system-related metrics alongside the benchmark. The Suite Plugins can be easily extended and tailored by new metrics depending on user needs, thanks to its flexible and intuitive modification. Collected metrics can be compared with the data from reference machines, enabling the detection of anomalies associated with system misconfiguration.

## 2 HEP Benchmark Suite with Plugins

The Suite Plugins were developed to introduce flexible and extensible functionality to the Suite, independent of the benchmark, and to gather additional data such as machine load, power consumption, and memory usage. The design allows for independent operation alongside the benchmark, ensuring the execution time remains unchanged, and enables data collection in three phases: before (pre), during, and after (post). The "pre" and "post" phases run only for a brief configurable moment to retrieve a single measurement, which can be modified by the user. The ease of use and extended functionality of the HEP Benchmark Suite are attributed to the Command Executor Plugin, which can be seen in Figure [2a](#page-2-0). The modification and addition of new metrics are highly flexible. Each metric has several parameters, such as command to be executed, regular expression (regex) to extract the relevant metric, unit, interval mins, and aggregation, that can be adjusted based on user needs. In Figure [2b](#page-2-0), the timeseries of the load, as one of the collected metric is visualized.

<span id="page-2-0"></span>



(a) The Command Executor Plugins facilitate metric definition by allowing users to specify the metric name, command, regex, unit, and interval (in minutes, interval\_mins).

(b) The timeseries data from the JSON file can be visualized to analyze performance. The top section shows load from a grid environment, while the bottom section illustrates data from a bare-metal node, highlighting differences between isolated test results and those observed in a production environment.

Figure 2: HEP Benchmark Suite Plugins: Configuration and timeseries data collection. (a) Configuration of the HEP Benchmark Suite Plugins is easy to modify by the user. Data collection can be performed on bare-metal nodes (lower  $(b)$ ) as well as on grid (upper  $(b)$ ). When executing on a grid, the collected data reflects the overall load on the entire machine, rather than just the individual job slot.

# 3 Data Analysis

A significant amount of data has been collected using the HEP Benchmark Suite with Plugins for different workload management systems (WMS) such as those of ATLAS and LHCb. The statistics of the collected data are presented in Table [1](#page-2-1). For LHCb, because most of its job slots are single core and cannot run the multicore WLs of HS23, a dedicated workload was submitted with three repetition on a single core job slot, manually, using DIRAC [\[11\]](#page-6-10). For ATLAS, extensive data was gathered using the automated job submission capabilities of HammerCloud [\[12\]](#page-6-11) and PanDA [\[13\]](#page-6-12). The official HS23 configuration was utilized, with each job slot running on 8 cores and a single repetition. This strategy was adopted due to its shorter execution times and automated processes, enabling the collection of a substantial volume of statistical data. This study focuses on analyzing the machine's load and its relationship to performance, highlighting the most noteworthy and significant aspects of the gathered data.

<span id="page-2-1"></span>Table 1: Data Statistics for each of the experiments. Automated submission for ATLAS allows the collection of extensive statistics data every day. The walltime shown for ATLAS is the effect of running one repetition of the full HS23 benchmark. For LHCb, just the dedicated LHCb benchmark workload was run, three times.

|              |        |     |     | Experiment No. $\#$ No. Sites No. CPU Models Walltime [min] % of total walltime |
|--------------|--------|-----|-----|---------------------------------------------------------------------------------|
| <b>ATLAS</b> | 148257 | 139 | 227 | 0.06                                                                            |
| LHCb         | 2100   | 48  | -10 | N/A                                                                             |

#### 3.1 HS23 vs Load analysis

The idea of adding load to the collected metrics originated from analyzing results from the WLCG batch systems at multiple sites. The utilization of physical cores is imperative due to the availability of outcomes for both HT ON and OFF. In the context of logical cores, results would converge at a comparable level, introducing potential misinterpretation. It has been discovered that for the same CPU model, different sites achieved varying results, as illustrated in **Figure [3a](#page-3-0)**. These results were compared with those from bare-metal nodes, with the expectation that they would fall within a similar range. However, as presented, the differences between sites ranged from a few percent to almost 33% when HT was enabled. Additionally, results within a single site, such as site 7, showed significant variability. The hypothesis was that these discrepancies were related to the load on the machines during the benchmarking script execution.

After implementing the plugins functionality, the collection of the load of the machine has been possible, adding another dimension to our data. The updated data representation is shown in Figure [3b](#page-3-0). As observed, performance variability is small for some sites, but significantly higher for others, showing correlation with the machine load. The general trend indicates that as the machine load increases, the HS23 per physical core decreases, supporting our hypothesis. Understanding the impact of machine load on performance variability is crucial for optimizing resource allocation and benchmarking accuracy in distributed computing environments. For instance, the significant variability observed at site 7 underlines the need for standardized load monitoring and management practices across sites to ensure consistent performance.

<span id="page-3-0"></span>



(a) A boxplot displays HS23 per physical core data across various (ATLAS) sites (numbered 1 to 10), distinguishing between HT ON and OFF conditions. The results range from approximately 11 to 19 for HT ON, with the lines representing data collected from bare-metal nodes during the standard benchmarking procedure.

(b) The scatter plot of HS23/Core versus Load/Physical Core illustrates how the performance of each site varies depending on the machine load at the time of benchmarking script execution.

#### Figure 3: Results collected from different WLCG sites for AMD 7452 32-Core Processor CPU.

The example of the AMD EPYC 7452 32-Core CPU is particularly intriguing when examining the overall trend, which indicates that as load increases, performance per core decreases. However, as shown in Figure [4a](#page-4-0), there is a notable anomaly represented by the orange region, which diverges from this trend. Performance at this site, in terms of score per core, is notably lower compared to other sites with double the server load. Upon contacting the site administrator, it was discovered that the servers had incorrect configuration significantly impacting performance. Fixing the issue results in a 66% improvement in performance, as depicted in Figure [4b](#page-4-0).

This outcome underscores how this analysis and corrective actions have enhanced site efficiency. Recursive studies across various CPU models identified and resolved additional configuration issues at different sites. These efforts also provided insights into the deliberate configuration choices made by site administrators, which, although initially appearing as anomalies, were intentional decisions.

#### 3.2 Data Model and governor analysis

Thread scanning refers to the process of analyzing the performance of CPU threads under varying loads to identify patterns and anomalies. Based on the results of thread scan measurements and other related studies [\[2\]](#page-6-1), a single pattern was expected in the data from the grid. However, two main patterns emerged: one where the load in the range (0,1) results in a constant performance despite increasing load (consistent with the thread scan) shown in Figure [5a](#page-4-1), and another where performance decreases in this load range, as seen in Figure [5b](#page-4-1). The presence of these two distinct patterns indicates the influence of hidden

<span id="page-4-0"></span>



(a) Before the intervention, the performance at the highlighted site, in terms of score per core, was only about half of that of other sites with the same load.

(b) After the intervention, a 66% improvement is observed at the highlighted site, demonstrating the effectiveness of the changes and the importance of proper configuration and optimization.

Intel(R) Xeon(R) CPU E5-2630 v4 @ 2.20GHz - HS23/Core VS Load/Physical Core

1.00 1.25<br>Load/Physical Core

1.50

1.75

Policy

data model

ondemand

performance

 $2.00$ 

grid

Figure 4: Anomaly detection for AMD EPYC 7452 32-Core CPU reveals that the highlighted site exhibits performance below the expected trend (a). After the intervention performance increased by  $66\%$  (b).

 $20.0$ 

 $17.5$ 

 $15.0$ 

 $\frac{0}{0}$  12.5 しょこう  $10.c$  $7.5$  $5.0$  $2.5$ 

 $0.0$ 

 $0.25$ 

 $0.50$ 

<span id="page-4-1"></span>

factors affecting performance.

7302 16-Core Processor.

(a) Pattern 1: Governor study on bare-metal node vs results from the grid vs data model for AMD EPYC (b) Pattern 2: Governor study on bare-metal node vs results from the grid vs data model for Intel $\widehat{R}$ ) Xeon $\widehat{R}$ CPU E5-2630 v4 @ 2.20GHz.

 $0.75$ 

Figure 5: Data from the grid shows two performance patterns in HS23 vs Load analysis. The first, observed in the low-load region  $(0,1)$ , aligns with expected thread-scan behavior, as seen in  $(a)$  with stable performance under low load. The second pattern deviates from expectations, showing variable performance with load changes in (b). When using the 'powersave' governor, only the first pattern appears in isolated tests (a,b). In contrast, 'performance' and 'ondemand' governors exhibit both patterns consistently in isolated on bare-metal nodes and grid tests (a,b).

The initial goal was to determine whether the observed behavior was unique to the grid or also present on bare-metal nodes. Additionally, the impact of various governors [\[14\]](#page-6-13) on system performance was investigated. Dedicated tests were conducted on bare-metal nodes using different governors, which are referred to later as isolated tests. The benchmarking was performed on AMD EPYC 7302 16-Core Processor and Intel® Xeon® CPU E5-2630 v4 @ 2.20GHz machines, employing a thread scan with a modularity of 4. The governors tested included performance, ondemand, and powersave. In Figure [5a](#page-4-1), consistent performance trends were observed across all governors on bare-metal nodes, consistent with the first pattern observed on the grid. Figure [5b](#page-4-1) similarly illustrates performance characteristics on bare-metal nodes, showing decreased performance with increasing load, which is in line with the second visible pattern for the performance and ondemand governors. On the contrary, the powersave governor exhibited results aligning with the first pattern observed on bare-metal nodes, consistent with thread

scan. Current hypothesis is that specific configuration aspects, such as turbo boost and thermal shielding effects associated with brand and CPU launch year, as illustrated in Figure [6](#page-5-0), may influence performance and contribute to the emergence of the second pattern. In this figure, coefficients are derived from the fit line in the HS23 versus Load within the low load region (0,1), where the patterns are observed. Each point represents a different (CPU Model, Site) pair, categorized by brand and launch year. The data suggest that newer architectures exhibit lower coefficients, which correlates with the appearance of the second pattern.

<span id="page-5-0"></span>

Figure 6: Coefficients derived from the fit line in the HS23 versus Load 2D plot, focusing on the low load region (0,1). Each point represents a different CPU model, categorized by brand and launch year.

#### 3.3 Power Consumption and CPU Frequency Study

Another use case of the enhanced HEP Benchmark Suite is power measurements in conjunction with frequency and HEPScore. Due to the permissions needed for ipmitools [\[15\]](#page-6-14), power measurements cannot be automatically performed on the grid. However, the enhanced suite can be used on bare-metal nodes to conduct such tests and analyses. The measurements presented in Figure [7](#page-5-1) show that nearly all different hardwares have a frequency that maximises the HS23/Watt. These findings can be applied to develop best practices for server configuration. Additionally, this study enables the assessment of machine sustainability across different architectures and hardware setups. This research is ongoing and will continue to provide valuable insights into optimizing performance and energy efficiency. For further details on power efficiency and frequency analysis, see [\[16\]](#page-6-15).

<span id="page-5-1"></span>

Figure 7: HEPScore/Power vs Frequency. Measurements on different hardwares show that almost all servers have a frequency that maximises the HEPScore/Watt.

#### 4 Conclusions

The enhanced HEP Benchmark Suite is versatile across various workload management systems, as demonstrated in ATLAS and LHCb experiments. With plugins enabling measurements of user-defined metrics such as machine load, memory usage, and power consumption, it facilitates detailed performance analysis. The Suite offers valuable insights into the configuration factors that most significantly affect system performance. This includes insights into optimizing server operation, achieving improvements of up to

66% through configuration adjustments. In addition, the expansion of newer architectures such as ARM [\[17\]](#page-7-0) has arrived, and the system is ready to collect data from it. Last but not the least, HEPScore was used to perform a CPU Consumption Study and test whether it is possible to decrease the power consumption by reducing the CPU frequency. Our measurements highlight that servers can operate at frequencies that maximise the HEPScore/Watt, suggesting better practices for server configuration and enhancing sustainability assessments across diverse hardware setups. The HEPScore with the Suite Plugins is an extremely powerful tool and it can, and should be employed to aid in monitoring experiments compute resources. Its utilisation helps provide a better understanding of the compute resources, detects and enables misconfiguration issues to be rectified, and thus enhances performance as demonstrated by the work described here. Ongoing investigations are exploring additional metrics to better understand performance dynamics, particularly related to CPU frequency and thermal effects.

#### References

- <span id="page-6-0"></span>[1] Domenico Giordano et al. Hepscore: A new cpu benchmark for the wlcg. EPJ Web of Conf., 295:07024, 2024. doi: 10.1051/epjconf/202429507024. URL [https://doi.org/10.1051/epjconf/](https://doi.org/10.1051/epjconf/202429507024) [202429507024](https://doi.org/10.1051/epjconf/202429507024).
- <span id="page-6-1"></span>[2] Domenico Giordano et al. Hepix benchmarking solution for wlcg computing resources. Computing and Software for Big Science, 5(1):28, 2021. doi: 10.1007/s41781-021-00074-y.
- <span id="page-6-2"></span>[3] Michele Michelotto et al. A comparison of hep code with spec1 benchmarks on multi-core worker nodes. Journal of Physics: Conference Series, 219(5):052009, 2010. doi: 10.1088/1742-6596/219/5/ 052009.
- <span id="page-6-3"></span>[4] SPEC. Spec cpu (2017) standard performance evaluation corporation. URL [https://www.spec.](https://www.spec.org/cpu2017/) [org/cpu2017/](https://www.spec.org/cpu2017/). Accessed 28 Nov 2023.
- <span id="page-6-4"></span>[5] P. Charpentier. Benchmarking worker nodes using lhcb productions and comparing with hepspec06. Journal of Physics: Conference Series, 898(8):082011, 2017. ISSN 1742-6596. doi: 10.1088/1742-6596/898/8/082011. Published under licence by IOP Publishing Ltd.
- <span id="page-6-5"></span>[6] HEPiX Benchmarking Working Group. How to run hepscore23 benchmark, 2023. URL [https:](https://w3.hepix.org/benchmarking/how_to_run_HS23.html) [//w3.hepix.org/benchmarking/how\\_to\\_run\\_HS23.html](https://w3.hepix.org/benchmarking/how_to_run_HS23.html). Accessed on: 01 Dec 2023.
- <span id="page-6-6"></span>[7] Grafana Labs. Grafana, 2024. URL <https://grafana.com/>. Accessed on: 29 July 2024.
- <span id="page-6-7"></span>[8] Wikipedia. Bare-metal server. URL [https://en.wikipedia.org/wiki/Bare-metal\\_server](https://en.wikipedia.org/wiki/Bare-metal_server). Accessed on: 18 Jul 2024.
- <span id="page-6-8"></span>[9] The ATLAS Collaboration et al. The atlas experiment at the cern large hadron collider. Journal of Instrumentation, 3(08):S08003, 2008. doi: 10.1088/1748-0221/3/08/S08003.
- <span id="page-6-9"></span>[10] The LHCb Collaboration et al. The lhcb detector at the lhc. Journal of Instrumentation, 3(08): S08005, 2008. doi: 10.1088/1748-0221/3/08/S08005.
- <span id="page-6-10"></span>[11] DIRAC Collaboration. Dirac, . URL <http://lhcb-portal-dirac.cern.ch/DIRAC/>. Accessed on: 28 Nov 2023.
- <span id="page-6-11"></span>[12] HammerCloud Collaboration. Hammercloud, . URL <http://hammercloud.cern.ch/hc/>. Accessed on: 28 Nov 2023.
- <span id="page-6-12"></span>[13] BigPanda Collaboration. Bigpanda, . URL <https://bigpanda.cern.ch/>. Accessed on: 28 Nov 2023.
- <span id="page-6-13"></span>[14] Inc. Red Hat. Cpu frequency governors. URL [https://docs.redhat.com/en/documentation/](https://docs.redhat.com/en/documentation/red_hat_enterprise_linux/6/html/power_management_guide/cpufreq_governors#cpufreq_governors) [red\\_hat\\_enterprise\\_linux/6/html/power\\_management\\_guide/cpufreq\\_governors#cpufreq\\_](https://docs.redhat.com/en/documentation/red_hat_enterprise_linux/6/html/power_management_guide/cpufreq_governors#cpufreq_governors) [governors](https://docs.redhat.com/en/documentation/red_hat_enterprise_linux/6/html/power_management_guide/cpufreq_governors#cpufreq_governors). Accessed on: 18 Jul 2024.
- <span id="page-6-14"></span>[15] Linux man page. ipmitool, 2024. URL <https://linux.die.net/man/1/ipmitool>. Accessed on: 8 August 2024.
- <span id="page-6-15"></span>[16] Emanuele Simili et al. Arming hep for the future energy efficiency of wlcg sites (arm vs. x86). EPJ Web of Conf., 295:11007, 2024. doi: 10.1051/epjconf/202429511007. URL [https://doi.org/10.](https://doi.org/10.1051/epjconf/202429511007) [1051/epjconf/202429511007](https://doi.org/10.1051/epjconf/202429511007).

<span id="page-7-0"></span>[17] Arm architecture family. URL [https://en.wikipedia.org/wiki/ARM\\_architecture\\_family](https://en.wikipedia.org/wiki/ARM_architecture_family). Accessed on: 17 July 2024.