Search papers, labs, and topics across Lattice.
This paper introduces a novel approach to optimize checkpointing in HPC applications by identifying and excluding unused data elements within variables. They leverage automatic differentiation (AD) to scrutinize each element's impact on the application output, distinguishing between critical and uncritical elements for checkpointing. Empirical validation on NAS Parallel Benchmarks demonstrates storage savings of up to 20% by eliminating uncritical elements from checkpoints.
Save up to 20% on checkpoint storage in HPC apps by surgically excluding unused data elements, identified via automatic differentiation.
Checkpoint/Restart (C/R) saves the running state of the programs periodically, which consumes considerable system resources. We observe that not every piece of data is involved in the computation in typical HPC applications; such unused data should be excluded from checkpointing for better storage/compute efficiency. To find out, we propose a systematic approach that leverages automatic differentiation (AD) to scrutinize every element within variables (e.g., arrays) for checkpointing allowing us to identify critical/uncritical elements and eliminate uncritical elements from checkpointing. Specifically, we inspect every single element within a variable for checkpointing with an AD tool to determine whether the element has an impact on the application output or not. We empirically validate our approach with eight benchmarks from the NAS Parallel Benchmark (NPB) suite. We successfully visualize critical/uncritical elements/regions within a variable with respect to its impact (yes or no) on the application output. We find patterns/distributions of critical/uncritical elements/regions quite interesting and follow the physical formulation/logic of the algorithm.The evaluation on NPB benchmarks shows that our approach saves storage for checkpointing by up to 20%.