# Comparative evaluation of bandwidth-bound applications on the Intel Xeon CPU MAX Series

[István Z Reguly](https://orcid.org/0000-0002-4385-4204)

reguly.istvan@itk.ppke.hu

Pázmány Péter Catholic University, Faculty of Information Technology and Bionics

Budapest, Hungary

## ABSTRACT

In this paper we explore the performance of Intel® Xeon® MAX CPU Series, representing the most significant new variation upon the classical CPU architecture since the Intel® Xeon Phi™ Processor. Given the availability of a large on-package high-bandwidth memory, the bandwidth-to-compute ratio has significantly shifted compared to other CPUs on the market. Since a large fraction of HPC workloads are sensitive to the available bandwidth, we explore how this architecture performs on a selection of HPC proxies and applications that are mostly sensitive to bandwidth, and how it compares to the previous 3rd generation Intel® Xeon® Scalable processors (codenamed Ice Lake) and an AMD EPYC™ 7003 Series Processor with 3D V-Cache Technology (codenamed Milan-X). We explore performance with different parallel implementations (MPI, MPI+OpenMP, MPI+SYCL), compiled with different compilers and flags, and executed with or without hyperthreading. We show how performance bottlenecks are shifted from bandwidth to communication latencies for some applications, and demonstrate speedups compared to the previous generation between 2.0x-4.3x.

# CCS CONCEPTS

• Software and its engineering  $\rightarrow$  Parallel programming languages; Distributed programming languages; • Computing methodologies  $\rightarrow$  Vector / streaming algorithms.

#### **KEYWORDS**

Benchmarking, Xeon CPU MAX Series, HBM, CFD

#### ACM Reference Format:

István Z Reguly. 2023. Comparative evaluation of bandwidth-bound applications on the Intel Xeon CPU MAX Series. In Workshops of The International Conference on High Performance Computing, Network, Storage, and Analysis (SC-W 2023), November 12–17, 2023, Denver, CO, USA. ACM, New York, NY, USA, [9](#page-8-0) pages. <https://doi.org/10.1145/3624062.3624195>

#### 1 INTRODUCTION

Over the past several decades, the advancement in technology has led to a remarkable increase in computational power, with this progression following an exponential curve [\[3\]](#page-7-0). This trajectory,

SC-W 2023, November 12–17, 2023, Denver, CO, USA

© 2023 Copyright held by the owner/author(s). Publication rights licensed to ACM. ACM ISBN 979-8-4007-0785-8/23/11. . . \$15.00 <https://doi.org/10.1145/3624062.3624195>

described by Moore's Law, has seen the number of transistors on a chip double approximately every two years, thereby significantly boosting the processing capabilities of microprocessors. Computation however, is just one side of the coin: data has to be moved to be computed upon. While the performance of memory systems both in capacity and bandwidth has also been growing at an exponential rate, but with a lower coefficient - leading to a growing gap between how many computations can be performed per second, and how much data can be moved per second. This can be characterized as the "flop/byte" ratio, which increased from around 1.0 in the 90s to well over a 100 on today's graphics processing units (GPUs).

In an attempt to mitigate this growing disparity, known as the "memory wall", recent technological innovations have focused on tighter integration between memory and processors. High Bandwidth Memory (HBM) [\[9\]](#page-7-1), a high-speed RAM interface designed to be used in conjunction with compute-heavy architectures, has been a significant player in this arena. HBM allows for increased bandwidth by placing memory stacks closer to the processor, thereby reducing latency and power consumption. For a few years now, this technology has been incorporated in GPUs to maximize their memory-intensive operations. The Intel Xeon Phi Processors, a series of manycore CPUs (now discontinued), also leveraged HBM - the first to do so with an x86 architecture. Fujitsu®'s A64FX integrated HBM memory with 48 ARM cores, becoming the building block for the Fugaku supercomputer which was #1 on the Top500 list in 2020 and 2021. The latest development in this trend has been the introduction of HBM in the Intel Xeon CPU Max Series, marking another crucial milestone in the journey towards improving the balance between compute power and memory bandwidth. While previous CPU architectures with HBM utilized light-weight cores, the Xeon CPU MAX Series uses heavy-weight cores, representing a step up even in terms of single-thread performance compared to earlier Intel CPUs - making it a very interesting architecture for highly complex, yet fundamentally bandwidth-limited codes.

High-performance computing (HPC) applications have a critical dependency on memory bandwidth, as many of these applications are essentially bandwidth-bound, as identified in a recent study [\[4\]](#page-7-2). Traditional benchmarks, such as the High-Performance Linpack (HPL) [\[5\]](#page-7-3), which has become an industry-standard ranking for HPC systems, are not fully representative of the memory bandwidth requirements in most real-world HPC applications. Recognizing the shift to being constrained by the speed of memory movement, there is an increasing focus on building HPC machines with an emphasis on memory movement rather than just computational capacity with Japan's supercomputers (Earth Simulator, K computer, Fugaku) pioneering these efforts.

As of July 2023, we could not find a single paper carrying out performance studies on the Intel Xeon CPU MAX Series - only

Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than the author(s) must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from permissions@acm.org.

a preprint focusing on a particular seismic application, showing a single data point [\[8\]](#page-7-4), websites showing performance overviews [\[10\]](#page-7-5), and marketing materials. We therefore endeavor to give one of the first overviews and detailed studies of performance on the Xeon CPU MAX 9480, focusing on primarily bandwidth-bound codes where this platform can truly challenge the status quo.

In this paper, we make the following contributions:

- (1) We benchmark core-to-core latency and memory bandwidth on Intel Xeon CPU MAX 9480 Processor, as well as the Intel Xeon Platinum 8360Y Processor, and the AMD EPYC 7V73X processors, and contrast their raw performance figures,
- (2) We explore the effects of choice of compiler, compiler flags (use of AVX512 instructions in particular), Hyperthreading, and parallelization approach on overall performance on the Intel Xeon CPU MAX Series running a range of applications,
- (3) We carry out a detailed analysis of different parallelizations such as pure MPI, MPI+OpenMP, and MPI+SYCL, quantifying bottlenecks, and absolute performance metrics,
- (4) We compare the best performance achieved on each application on the Intel Xeon CPU MAX 9480 Processor, the Intel Xeon Platinum 8360Y Processor, and the AMD EPYC 7V73X.

The paper is structured as follows: Section [2](#page-1-0) introduces the platforms, raw performance figures, and evaluates core-to-core latency and achieved bandwidth, Section [3](#page-2-0) introduces the applications benchmarked, Section [4](#page-2-1) discusses the different parallelizations for each application, then Section [5](#page-3-0) gives an overview of compilers, configurations, and parallelizations. Section [6](#page-6-0) compares absolute performance metrics and to the other CPUs. Finally, Section [7](#page-7-6) draws conclusions.

#### <span id="page-1-0"></span>2 SYSTEMS AND BASELINE PERFORMANCE

For this study, we evaluate the following systems, in the given hardware/software configuration.

- (1) Intel Xeon CPU MAX 9480 Processor with HBM, available in the Intel Developer Cloud. Two sockets, each with 56 cores, Hyperthreading on. 2x4 NUMA regions, with 2x64 GB HBM in HBM-only mode, with SNC4. Clock frequencies between 1.9 GHz (base frequency) - 2.6 GHz (all-core turbo), giving a theoretical 13.6-18.6 FP32 TFLOPS/s. Software: Intel OneAPI Base and HPC toolkits, 2023.1 (including Intel MPI). Benchmarked Jun 4, 2023.
- (2) Intel Xeon Platinum 8360Y Processor, available in the Baskerville cluster at the University of Birmingham. Two sockets, each with 36 cores, Hyperthreading on. 512 GB DDR4 RAM. Clock frequencies between 2.4 GHz (base frequency) - 2.8 GHz (all-core turbo), giving a theoretical 11-13 FP32 TFLOPS/s. Software: RHEL 8.5, Intel OneAPI Base and HPC toolkits, 2023.1 (including Intel MPI). Benchmarked July 11, 2023.
- (3) AMD EPYC 7V73X with 3D V-Cache Technology, available as an Azure HB120rs\_v3 virtual machine. Two sockets, each with 60 available cores, Hyperthreading off. 2x2 NUMA regions, with 448 GB DDR4 RAM. Clock frequencies between 2.2 GHz (base frequency) - 3.5 GHz (turbo), giving a theoretical 8.45-13.45 FP32 TFLOPS/s. Software: Ubuntu 22.04, GCC 12.3 and AMD Optimizing C/C++ Compiler 4.0. Benchmarked July 15, 2023.

The biggest highlight of the Intel Xeon CPU MAX Series is the massive improvement in memory bandwidth, thanks to the on-package high-bandwidth memory. While the theoretical peak bandwidth on Xeon 8360Y and EPYC 7V73X are 2x204.8 GB/s, on Intel Xeon CPU MAX Series this is around 2x1300 GB/s [\[12\]](#page-7-7). Therefore, we first benchmark the achievable memory bandwidth using the BabelSTREAM OpenMP Triad benchmark. Results are shown in Figure [1](#page-2-2) – measuring bandwidth from a single NUMA domain, one socket, or both sockets, at different array sizes. At the largest sizes, the Xeon Platinum 8360Y and the EPYC 7V73X achieve close to 75% of peak at 296 GB/s and 310 GB/s respectively. In comparison, on the Intel Xeon CPU MAX Series we also evaluate two sets of compiler flags – one used on other platforms and in the applications, and one fine-tuned for the STREAM benchmark [\[1\]](#page-7-8) (marked with SS for streaming stores). The former achieves 1446 GB/s, a 4.8x increase over the Xeon Platinum 8360Y and the EPYC 7V73X, the latter 1643 GB/s, a 5.5x increase over Xeon Platinum 8360Y/EPYC 7V73X. Still, only 55%/63% of peak is reached respectively – the reasons for this are explored in [\[12\]](#page-7-7). At smaller array sizes one can observe bandwidth to on-chip cache – what is particularly relevant here, is the ratio between cache and main memory bandwidth, which at 3.8x on Intel Xeon CPU MAX 9480 is significantly lower compared to 6x on the Xeon Platinum 8360Y and 14x on the EPYC 7V73X.

At base clock frequencies, the three platforms have a peak FP32 computational capacity of 13.6 TFLOPS/s (Intel Xeon CPU MAX 9480), 11 TFLOPS/s (Xeon Platinum 8360Y), and 8.45 TFLOPS/s (EPYC 7V73X). The theoretical flop/byte ratio, indicating the balance between memory movement and compute is significantly reduced on the Intel Xeon CPU MAX 9480 Processor to 9.4, compared to 36 on the Xeon Platinum 8360Y and 28 on the EPYC 7V73X – indicating that bandwidth-bound applications on other platforms may become compute-bound (or latency-bound) on Intel Xeon CPU MAX Series. The flip side of this is that while the Intel Xeon CPU MAX 9480 Processor does have the highest computational capacity, it is only 24% and 61% higher compared to Xeon 8360Y and EPYC 7V73X respectively, therefore computationally bound applications are not expected to gain as much speedup compared to previous generation as bandwidth-bound ones.

Another important factor in HPC is the communication latency between CPU cores, because threads may need to synchronize, or processes may need to exchange data. To measure this, we use the core-to-core-latency test [\[6\]](#page-7-9) and evaluate message passing latency with the one writer/one reader on many cache lines test between (1) hyperthreads, (2) adjacent cores, and (3) cores on different sockets. While there were some noise in the measurements, Figure [2](#page-2-3) shows that there hasn't been a significant improvement (in some cases even slight regression) in communication latencies compared to the Xeon Platinum 8360Y – while this is not surprising given the lower clock frequency, higher core counts, and chiplet architecture, it is important to note as with the reduction of the bandwidth bottleneck, applications may become bound by this latency. For EPYC 7V73X, since simultaneous multithreading was disabled, we show latencies to the adjacent core, a core in a different NUMA domain, but the same socket (different chiplet), and a core in the other socket. While overall latencies are comparable to the Xeon Platinum 8360Y and the Xeon CPU MAX 9480, the latency across

#### Comparative evaluation of bandwidth-bound applications on the Intel Xeon CPU MAX Series SC-W 2023, November 12–17, 2023, Denver, CO, USA

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



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

Figure 2: Message passing latency on the three platforms

different sockets is 1.6x times worse (note that this node was run as a virtual machine in Azure cloud, which might affect results).

## <span id="page-2-0"></span>3 APPLICATIONS

In the following, we briefly introduce the benchmarked applications and their key characteristics. All measurements were done 4 times, and averaged (variance in results was <5%, and is not explicitly shown).

- (1) miniBUDE [\[16\]](#page-7-10) proxy molecular docking code, representative of BUDE. Compute and latency bound. Single precision, bm1 testcase, 30 iterations.
- (2) CloverLeaf 2D/3D [\[11\]](#page-7-11) structured-mesh Eulerian hydrodynamics simulation, representative of nuclear security codes. Mostly bandwidth-bound, with some operations on faces/edges that may be latency bound. Double precision, 7680<sup>2</sup>(2D), 408<sup>3</sup> (3D) problem size, 50 iterations.
- (3) Acoustic structured-mesh high-order (8th) finite difference acoustic wave propagation solver. Bandwidth and cache locality bound, with large communications volume over MPI. Single precision, 320<sup>3</sup> problem size, 10 time iterations.
- (4) OpenSBLI SA & SN [\[7\]](#page-7-12) structured mesh finite difference Navier-Stokes solver for capturing shock-boundary layer interactions. Production code with 2 varians – Store All (SA), which is bandwidth-bound, and Store None (SN), which

recomputes derivatives on the fly, reducing data movement pressure, but still mostly bandwidth bound. Double precision,  $320<sup>3</sup>$  problem size, 20 time iterations.

- (5) MG-CFD [\[15\]](#page-7-13) unstructured mesh finite volume Euler equations solver with multigrid – proxy for Rolls-Royce's CFD simulator Hydra. Bound by latencies and indirect memory accesses. Double precision, NASA Rotor37 case with 8 million vertices, 25 iterations.
- (6) Volna [\[19\]](#page-7-14) unstructured mesh finite volume Nonlinear Shallow Water Equations solver. Also sensitive to indirect memory accesses as MG-CFD, but less so. Single precision, Indian ocean case with 30 million vertices, 200 time iterations.
- (7) miniWeather [\[14\]](#page-7-15) structured mesh proxy code implementing basic dynamics seen in atmospheric weather and climate simulations. Bandwidth bound. Double precision,  $4000x2000$ problem size, simulation time 1.0.

#### <span id="page-2-1"></span>4 PARALLELIZATIONS

All except two (miniWeather, miniBUDE) applications are implemented in the OPS [\[22\]](#page-8-1) or OP2 [\[17\]](#page-7-16) domain specific languages for structured/unstructured mesh applications. This enables these applications to automatically generate a variety of different parallel implementations, including MPI, MPI+OpenMP, MPI+SYCL

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

Application

#### Figure 3: Configurations of structured mesh benchmarks normalized to the best for each application

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

#### Figure 4: Configurations of unstructured mesh benchmarks normalized to the best for each application

and more. The performance of OPS/OP2 versions of applications have been thoroughly studied in prior work and shown to match hand-coded variants [\[13,](#page-7-17) [18,](#page-7-18) [20\]](#page-8-2). For structured mesh computations (including miniWeather) a standard cartesian mesh decomposition is used over MPI, with ghost cell exchanges triggered as needed before each bulk parallel computational step. Within each process, OpenMP or SYCL parallelization may be applied – parallelizing across all grid points – using OpenMP's collapse and simd pragmas, or in SYCL creating a work item for each grid point. For SYCL, there is an additional variation: "flat" uses a plain parallel\_for loop specifying the whole domain to be executed on, whereas "ndrange" uses

a parallel\_for loop with an nd\_range argument, explicitly specifying workgroup shapes. Internally, the "flat" scheme is still mapped to workgroups by the runtime, however, the runtime may choose the exact shape for each kernel on each target architecture. For unstructured mesh computations, we perform a standard ownercompute decomposition of the mesh over MPI using PT-Scotch [\[2\]](#page-7-19). Within each process for the MPI-only version we sequentially process elements, and can optionally use an explicitly auto-vectorizing implementation, where the generated code packs and unpacks vector registers. For OpenMP and SYCL one needs to explicitly avoid race conditions – for which we use a coloring scheme [\[23\]](#page-8-3). While the OpenMP version does not auto-vectorize, we can generate SYCL code that vectorizes.

# <span id="page-3-0"></span>5 OVERVIEW OF APPLICATIONS, COMPILERS, AND CONFIGURATIONS

In this section, we explore the impact of basic configuration combinations on performance. Namely, we evaluate the various (feasible) combinations of the following:

- (1) Compiler versions: Intel C++ Compiler Classic (ICC/ICPC) or Intel oneAPI DPC++/C++ Compiler (ICX/ICPX)
- (2) ZMM usage set to default or high affecting whether AVX-256 or AVX-512 instructions are generated. For bandwidthbound applications it is not always clear which one is better, since the use of AVX-512 leads to fewer instructions, but lower clock speeds.
- (3) Hyperthreading 1 or 2 threads used per hardware core
- (4) Parallelization approaches: (1) Pure MPI: assigning a process to each physical/logical core. No threading overheads, but significant message passing overheads. (2) MPI + OpenMP: assigning one MPI process to each NUMA domain, and 1

OpenMP thread to each physical/logical core, (3) MPI + SYCL – assigning one MPI process to each NUMA domain, then using that as a SYCL sub-device.

Overall results from structured mesh applications are shown in Figure [3,](#page-3-1) showing relative runtime (slowdown) vs. best for the given application, rows in ascending order by their average. As expected, the newer OneAPI compilers outperform the Classical compilers on average, although the absolute best performance is still achieved with the classical compilers on 3 out of 6 applications, with OneAPI within 4-6%. On the other hand, for Acoustic the Classical compilers are 15% slower, and for miniWeather 34% slower.

MPI+OpenMP works best on average, performing best or only being 1% slower for 4 applications – for OpenSBLI SN it is 4% slower than pure MPI, and for miniWeather it is 7% slower than MPI+SYCL. Hyperthreading disabled leads to marginally (2%) better performance with the MPI+OpenMP codes, except for the Clover-Leaf applications, but even there it's within 3% of the HT-enabled counterparts. The choice of ZMM usage does not have a substantial effect on these primarily bandwidth-bound codes – across all variants, ZMM default is only 0.2% faster. It is only on the two most computationally intensive applications (Acoustic and OpenSBLI SN) is ZMM high consistently better (4-6%).

Overall the best performing combination appears to be MPI+OpenMP, with OneAPI, ZMM high, and HT disabled. Yet this choice is still 6.2% slower than picking the best option for each application individually.

Results from unstructured mesh applications are shown in Fig [4.](#page-3-2) Across both applications, MPI vec implementations (where autovectorizing code is generated for kernels with race conditions) perform the best – on average by 66% compared to others. Here, ZMM high usage is required to match generated vector sizes, and the new oneAPI compilers work best for Volna, whereas the Classical compilers work better for MG-CFD. With critical kernels not vectorizing for either implementation, pure MPI variants are still on average faster than MPI+OpenMP due to the further loss in data locality. Here, the OneAPI compilers perform consistently better than the Classical compilers. For these cases, Hyperthreading enabled also improves performance by 13% on average.

Finally, for the largely compute bound code miniBUDE, the Classical compilers generate code that stalls, therefore we could only measure with the OneAPI compilers. We achieve 6 TFLOPS/s with OneAPI, without HT and ZMM high. As a compute bound code, ZMM high improves performance by 45% - however, one has to enable this explicitly. One thread per physical core can saturate pipelines – HT enabled reduces performance by 28%. The SYCL implementation is not competitive, reaching only 50% of OpenMP.

This analysis shows that the Xeon CPU MAX Series platform is particularly sensitive to the right configuration for bandwidthlimited codes. While we expect larger variations for the unstructured mesh applications, due to significant differences in data locality and vectorization between the different parallelizations, for the structured mesh codes there is much less inherent difference. The mean slowdown vs the best configuration on structured meshes is 1.25, with the median at 1.12. In comparison, the mean slowdown on the Xeon Platinum 8360Y is only 1.11, with the median at 1.05.

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

Figure 5: Relative speedup of different parallelizations on the Intel Xeon CPU MAX 9480 Processor compared to pure MPI

# 5.1 Comparison of parallelizations on Intel Xeon CPU MAX Series

Figure [5](#page-4-0) shows that a hybrid MPI+OpenMP implementation (1 process per NUMA domain) performs best on average on structured mesh applications – especially if they are more limited by communications (Acoustic). On unstructured mesh applications (MG-CFD and volna), the MPI version auto-vectorizes, significantly outperforming (1.6-1.8x) MPI+OpenMP (which does not). MPI+SYCL at this point does not match the performance of MPI+OpenMP due to the higher scheduling overheads (having to go through the OpenCL drivers): this is more pronounced on CloverLeaf 2D/3D due to the higher number of small boundary kernels – less so on the more computationally intensive applications (OpenSBLI SN, Acoustic, volna). On MG-CFD, while the SYCL version does vectorize (flat version), it is still slower than the ndrange version with 1 work item (which disables vectorization) - reasons for this are explored in [\[23\]](#page-8-3). SYCL has two variants for structured meshes: "flat", where the runtime chooses workgroup sizes for each kernel, and "ndrange", where the user specifies one workgroup size to be used for all kernels in a given application. The latter we fine-tuned through exhaustive search, but we can see that at the level of the whole application, the runtime does a very good job at picking good workgroup sizes. Looking at an individual kernel for OpenSBLI SN, we can observe that better performance is achieved when the workgroup size in the contiguous dimension matches the size of the domain, and the other dimensions are small – in this case a shape of 160x4x4 gave 2% faster execution than the default size with "flat". This is consistent with our understanding of cache prefetchers and task granularity – for GPUs of course this would be different, where the maximum workgroup size is 1024. This highlights the importance of choosing workgroup sizes specific to a kernel and a target architecture, which

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

Figure 6: Best performance of applications on different platforms and the speedup of the Intel Xeon CPU MAX 9480 in comparison

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

Figure 7: Fraction of total runtime spent in MPI communications on different platforms for the different applications

the runtime – given the right heuristics – is better equipped to do compared to the user hard-coding these parameters.

# <span id="page-6-0"></span>6 COMPARISON TO OTHER PLATFORMS

Figure [6](#page-5-0) shows a performance comparison of the Intel Xeon CPU MAX Series platform to the previous-generation Xeon 8360Y CPU, the EPYC 7V73X CPU, and an NVIDIA A100 (40GB PCI-e), with the data labels indicating the best performing implementation on the given hardware, and a table underneath showing speedups on Intel Xeon CPU MAX 9480 vs. Xeon 8360Y and EPYC 7V73X. The most bandwidth-bound codes (CloverLeaf 2D and OpenSBLI SA achieve a speedup of 4.2/3.8x respectively – slightly less than the difference in peak bandwidth (4.8x), due to a lower bandwidth utilization efficiency. Communications latency and cache performance is a more significant factor in the overall performance of OpenSBLI SN and Acoustic, but speedups are still over 2.5/1.98x. It is interesting to note that the OpenSBLI SA and SN are different formulations of solving the same problem, with SN doing more compute and SA moving more data – the speedup between these two is just below 2x on Intel Xeon CPU MAX 9480, but over 2.5x on Xeon 8360Y/EPYC 7V73X, showing that trading off data movement for computations is still worthwhile, but less effective than on more bandwidth-constrained platforms. For the MG-CFD unstructured mesh applications there is an overhead of packing and unpacking vector registers – since EPYC 7V73X only has 256-bit AVX2, this overhead is smaller, and thanks to its large cache, locality is significantly improved compared to Xeon 8360Y – leading to lower speedups on Intel Xeon CPU MAX 9480 at 2.5/2x respectively. Finally, miniBUDE is much more bound by latency and compute, but there is still significant speedup thanks to the availability of AVX512 on Intel Xeon CPU MAX 9480 – 1.9/1.36x respectively.

GPUs, generally speaking, excel at streaming computations such as these (the structured mesh ones in particular) thanks to their high memory bandwidth, but of course the Xeon CPU MAX Series comes equipped with a similar memory technology - and so we take a brief look at comparing performance to and NVIDIA A100 GPU - which has an achievable peak memory bandwidth of 1310 GB/s - 10% lower than that measured on the Intel Xeon CPU MAX 9480. Yet, as shown in Figure [6](#page-5-0) the A100 is significantly (1.1-2.1×) faster. The difference is notably lower on more bandwidth-bound codes, but more pronounced on the more compute-bound codes such as OpenSBLI SN and Acoustic. The difference in part comes down partly to better bandwidth utilization (thanks to the massive SMT capabilities of GPUs), and no MPI communications overheads.

As previously discussed, the communication latencies on Intel Xeon CPU MAX Series did not improve by as much as bandwidth did, resulting in a shift of bottlenecks. In Figure [7](#page-5-1) we quantify this overhead by measuring the time spent in MPI\_Wait for different applications on the three hardware platforms with pure MPI and MPI+OpenMP implementations. The first clear difference is that for all but one application (volna), the MPI+OpenMP implementation has significantly lower MPI overhead - which is as expected, given that fewer messages are being sent and the overall communications volume is smaller as well. As shown in Figure [6,](#page-5-0) this does not mean that MPI+OpenMP performs best overall - notably for CloverLeaf 2D/3D and OpenSBLI SN pure MPI runs faster - OpenMP has its



Figure 8: Achieved effective bandwidth of applications on the Intel Xeon CPU MAX 9480 Processor

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

Figure 9: CloverLeaf 2D with the cache-blocking tiling optimization - comparison of different platforms

own overheads with the need for synchronization and data sharing between threads (neither applies to pure MPI). Whereas the average improvement in communications overheads when going from MPI to MPI+OpenMP for the Xeon Platinum 8360Y and the EPYC 7V73X are at 15%, for the Xeon CPU MAX 9480 this is only 8.2% - once again underlining the shift from the bandwidth bottleneck to the latency bottleneck. Aside from CloverLeaf 2D, we can see that the percentage of time spent in MPI on Intel Xeon CPU MAX 9480 is 1.2-5.3x higher compared to Xeon Platinum 8360Y – of course in absolute terms MPI is still only 0.8x slower on OpenSBLI SA and 2.7x faster on OpenSBLI SN.

We also evaluated absolute performance metrics – namely achieved effective memory bandwidth of the kernels. This was calculated by OPS automatically, by measuring the execution time of the kernel (excluding MPI communications), and estimating the effective data movement, based on the iteration ranges, datasets accessed, and types of access (read or read+write). CloverLeaf 2D achieves 75% of peak – it is the application with the simplest access patterns, and low data re-use. The CloverLeaf 3D and OpenSBLI SA applications are also memory intensive, but given they are in 3D, their access patterns are more complicated – they still achieve over 65% of peak. OpenSBLI SN and Acoustic are more computationally intensive, and Acoustic in particular is also very cache-intensive due to the

high-order stencils - these achieve only 53% and 41% of peak respectively. In comparison, Xeon 8360Y achieves 75-85% of peak and EPYC 7V73X achieves 79-96% of peak on these applications, showing that the bandwidth bottleneck on Intel Xeon CPU MAX Series is significantly reduced.

Finally, we take the still most bandwidth-bound code, CloverLeaf 2D, and apply the cache-blocking tiling algorithm in OPS. This algorithm [\[21\]](#page-8-4) re-arranges the execution of parallel loops within and across different loops to improve memory locality. It also reduces MPI communications volume and frequency, at the cost of redundant computations along the MPI boundaries. Here we used the OneAPI compilers with ZMM usage high, running pure MPI with hyperthreading on Intel, and AMD Optimizing C/C++ Compiler (AOCC) on the AMD EPYC 7V73X. Figure [9](#page-6-1) shows the improvements in runtime – for reference we also added the performance of CUDA running on an A100 40GB GPU as well. We can see that performance on the Intel Xeon CPU MAX 9480 CPU can be improved by a further 1.84x by increasing cache re-use, at this point outperforming an A100 GPU by 1.5x. It is also interesting to note that the same improves performance by 2.7x on the Xeon Platinum 8360Y and 4x on the EPYC 7V73X, a significantly higher factor, but it correlates well with the difference between measured cache bandwidth and HBM/DDR4, which is 3.8x on Intel Xeon CPU MAX 9480, 6.3x on the Xeon Platinum 8360Y, and 14x on the EPYC 7V73X.

#### <span id="page-7-6"></span>7 CONCLUSIONS

In this paper we have conducted a qualitative and quantitative benchmarking of the Intel Xeon CPU MAX 9480 Processor - with a particular focus on traditionally bandwidth-bound HPC applications. After measuring basic achievable bandwidth and messagepassing latency figures, we explored how the choice of compiler, compiler flags, parallelization approaches, and hyperthreading affects performance, showing a significantly higher variation compared to previous generations. Having quantified the reduction in the bandwidth bottleneck, but only moderate improvements in terms of communication latencies, we contrasted the performance of pure MPI, MPI+OpenMP and MPI+SYCL implementations of the same codes, trading off communications overheads for threading overheads, showing improvements in the communications overheads, but still overall a mixed picture in terms of which implementation performs best. We then proceeded to calculate the effective bandwidth utilization, reaching 41-75% of peak (as measured by BabelStream). The comparison with the previous-generation Xeon Platinum 8360Y and the AMD EPYC 7V73X clearly shows the shift away from the bandwidth bottleneck - revealing the importance of minimizing communications and best utilizing the vector units. Despite a lower architectural efficiency (i.e. lower fraction of peak bandwidth), the Xeon CPU MAX 9480 still outperformed the other CPUs studied by 2-4.3× on these benchmarks, suggesting that it could offer significant benefits compared to traditional DDR-only systems. With the right optimizations on bandwidth-bound applications (CloverLeaf 2D with cache-blocking tiling), the Xeon CPU MAX Series is even capable of outperforming modern GPUs - an NVIDIA A100 40GB PCI-e by 50% in this case.

#### ACKNOWLEDGMENTS

We are grateful for the support of the OneAPI Innovator program, and the advice and assistance of Mark Lubin, Xiao Zhu, and Rob Muller-Albrecht at Intel in particular.

This research was supported by Rolls-Royce plc., and by the UK EPSRC (EP/S005072/1 – Strategic Partnership in Computational Science for Advanced Simulation and Modelling of Engineering Systems – ASiMoV). This work was also supported in part by the Hungarian Academy of Sciences under Grant POST-COVID2021-64.

#### REFERENCES

- <span id="page-7-8"></span>[1] [n. d.]. [https://www.intel.com/content/www/us/en/content-details/769060/intel](https://www.intel.com/content/www/us/en/content-details/769060/intel-xeon-cpu-max-series-configuration-and-tuning-guide.html)[xeon-cpu-max-series-configuration-and-tuning-guide.html](https://www.intel.com/content/www/us/en/content-details/769060/intel-xeon-cpu-max-series-configuration-and-tuning-guide.html)
- <span id="page-7-19"></span>[2] Cédric Chevalier and François Pellegrini. 2008. PT-Scotch: A tool for efficient parallel graph ordering. Parallel computing 34, 6-8 (2008), 318–331.
- <span id="page-7-0"></span>Peter J Denning and Ted G Lewis. 2016. Exponential laws of computing growth. Commun. ACM 60, 1 (2016), 54–65.
- <span id="page-7-2"></span>[4] J. Domke, E. Vatai, A. Drozd, P. ChenT, Y. Oyama, L. Zhang, S. Salaria, D. Mukunoki, A. Podobas, M. WahibT, and S. Matsuoka. 2021. Matrix Engines for High Performance Computing: A Paragon of Performance or Grasping at Straws?. In 2021 IEEE International Parallel and Distributed Processing Symposium (IPDPS). IEEE Computer Society, Los Alamitos, CA, USA, 1056–1065. <https://doi.org/10.1109/IPDPS49936.2021.00114>
- <span id="page-7-3"></span>[5] Jack J Dongarra, Piotr Luszczek, and Antoine Petitet. 2003. The LINPACK benchmark: past, present and future. Concurrency and Computation: practice and experience 15, 9 (2003), 803–820.
- <span id="page-7-9"></span>[6] github. 2023. core-to-core-latency. [https://github.com/nviennot/core-to-core](https://github.com/nviennot/core-to-core-latency)[latency](https://github.com/nviennot/core-to-core-latency)
- <span id="page-7-12"></span>[7] C. T. Jacobs, S. P. Jammy, and N. D. Sandham. 2017. OpenSBLI: A framework for the automated derivation and parallel execution of finite difference solvers on a range of computer architectures. Journal of Computational Science 18 (2017), 12–23. <https://doi.org/10.1016/j.jocs.2016.11.001>
- <span id="page-7-4"></span>[8] Om Gangadhar Jadhav, Sandeep Agrawal, Abhishek Srivastava, Richa Rastogi, Sanjay Wandhekar, Vinutha SV, and Jyotsna Khemka. [n. d.]. Migration of a Cuda Based Seismic Modeling Application to Sycl Codebase for Heterogeneous Architectures. Available at SSRN 4515781 ([n. d.]).
- <span id="page-7-1"></span>[9] Hongshin Jun, Jinhee Cho, Kangseol Lee, Ho-Young Son, Kwiwook Kim, Hanho Jin, and Keith Kim. 2017. Hbm (high bandwidth memory) dram technology and architecture. In 2017 IEEE International Memory Workshop (IMW). IEEE, 1–4.
- <span id="page-7-5"></span>[10] Michael Larabel. [n. d.]. Intel Xeon Max 9480/9468 show significant uplift in HPC & AI workloads with HBM2e Review. [https://www.phoronix.com/review/xeon](https://www.phoronix.com/review/xeon-max-9468-9480-hbm2e)[max-9468-9480-hbm2e](https://www.phoronix.com/review/xeon-max-9468-9480-hbm2e)
- <span id="page-7-11"></span>[11] Andrew Mallinson, David A Beckingsale, Wayne Gaudin, J Herdman, John Levesque, and Stephen A Jarvis. 2013. Cloverleaf: Preparing hydrodynamics codes for exascale. The Cray User Group 2013 (2013).
- <span id="page-7-7"></span>[12] John D McCalpin. 2023. Bandwidth Limits in the Intel Xeon Max (Sapphire Rapids with HBM) Processors. In ISC 2023 IXPUG Workshop. 1–4.
- <span id="page-7-17"></span>[13] Gihan R Mudalige, IZ Reguly, Satya P Jammy, Christian T Jacobs, Michael B Giles, and Neil D Sandham. 2019. Large-scale performance of a DSL-based multi-block structured-mesh application for Direct Numerical Simulation. J. Parallel and Distrib. Comput. 131 (2019), 130–146.
- <span id="page-7-15"></span>[14] Matthew R Norman. 2020. miniWeather. Technical Report. Oak Ridge National Lab.(ORNL), Oak Ridge, TN (United States).
- <span id="page-7-13"></span>[15] AMB Owenson, Steven A Wright, Richard A Bunt, YK Ho, Matthew J Street, and Stephen A Jarvis. 2020. An unstructured CFD mini-application for the performance prediction of a production CFD code. Concurrency and Computation: Practice and Experience 32, 10 (2020), e5443.
- <span id="page-7-10"></span>[16] Andrei Poenaru, Wei-Chen Lin, and Simon McIntosh-Smith. 2021. A Performance Analysis of Modern Parallel Programming Models Using a Compute-Bound Application. In High Performance Computing, Bradford L. Chamberlain, Ana-Lucia Varbanescu, Hatem Ltaief, and Piotr Luszczek (Eds.). Springer International Publishing, Cham, 332–350.
- <span id="page-7-16"></span>[17] I Reguly. 2012. Op2: An active library framework for solving unstructured meshbased applications on multi-core and many-core architectures. In 2012 Innovative Parallel Computing (InPar). IEEE, 1-12.
- <span id="page-7-18"></span>[18] IZ Reguly, AC Mallinson, WP Gaudin, and JA Herdman. 2015. Performance analysis of a high-level abstractions-based hydrocode on future computing systems. In High Performance Computing Systems. Performance Modeling, Benchmarking, and Simulation: 5th International Workshop, PMBS 2014, New Orleans, LA, USA, November 16, 2014. Revised Selected Papers 5. Springer, 85–104.
- <span id="page-7-14"></span>[19] Istvan Z Reguly, Daniel Giles, Devaraj Gopinathan, Laure Quivy, Joakim H Beck, Michael B Giles, Serge Guillas, and Frederic Dias. 2018. The VOLNA-OP2 tsunami code (version 1.5). Geoscientific Model Development 11, 11 (2018), 4621–4635.

<span id="page-8-0"></span>Comparative evaluation of bandwidth-bound applications on the Intel Xeon CPU MAX Series SC-W 2023, November 12–17, 2023, Denver, CO, USA

- <span id="page-8-2"></span>[20] István Z. Reguly, Gihan R. Mudalige, Carlo Bertolli, Michael B. Giles, Adam Betts, Paul H.J. Kelly, and David Radford. 2016. Acceleration of a Full-Scale Industrial CFD Application with OP2. IEEE Transactions on Parallel and Distributed Systems
- <span id="page-8-4"></span>27, 5 (2016), 1265–1278. <https://doi.org/10.1109/TPDS.2015.2453972> [21] István Z Reguly, Gihan R Mudalige, and Michael B Giles. 2017. Loop tiling in large-scale stencil codes at run-time with OPS. IEEE Transactions on Parallel and Distributed Systems 29, 4 (2017), 873–886.
- <span id="page-8-1"></span>[22] István Z Reguly, Gihan R Mudalige, Michael B Giles, Dan Curran, and Simon McIntosh-Smith. 2014. The ops domain specific abstraction for multi-block

structured grid computations. In 2014 Fourth International Workshop on Domain-Specific Languages and High-Level Frameworks for High Performance Computing. IEEE, 58–67.

<span id="page-8-3"></span>[23] Istvan Z Reguly, Andrew MB Owenson, Archie Powell, Stephen A Jarvis, and Gihan R Mudalige. 2021. Under the hood of sycl–an initial performance analysis with an unstructured-mesh cfd application. In High Performance Computing: 36th International Conference, ISC High Performance 2021, Virtual Event, June 24–July 2, 2021, Proceedings 36. Springer, 391–410.