H-Revolve: A Framework for Adjoint Computation on Synchrone Hierarchical Platforms - INRIA - Institut National de Recherche en Informatique et en Automatique Accéder directement au contenu
Pré-Publication, Document De Travail Année : 2019

H-Revolve: A Framework for Adjoint Computation on Synchrone Hierarchical Platforms

Résumé

In this work, we study the problem of checkpointing strategies for adjoint computation on synchrone hierarchical platforms. Specifically we consider computational platforms with several levels of storage with different writing and reading costs. When reversing a large adjoint chain, choosing which data to checkpoint and where is a critical decision for the overall performance of the computation. We introduce H-Revolve, an optimal algorithm for this problem. We make it available in a public Python library along with the implementation of several state-of-the-art algorithms for the variant of the problem with two levels of storage. We provide a detailed description of how one can use this library in an adjoint computation software in the field of automatic differentiation or backpropagation. Finally, we evaluate the performance of H-Revolve and other checkpointing heuristics though an extensive campaign of simulation.
Fichier principal
Vignette du fichier
hrevolve.pdf (1.47 Mo) Télécharger le fichier
Origine : Fichiers produits par l'(les) auteur(s)
Loading...

Dates et versions

hal-02080706 , version 1 (27-03-2019)
hal-02080706 , version 2 (28-02-2020)

Identifiants

  • HAL Id : hal-02080706 , version 1

Citer

Guillaume Aupy, Julien Herrmann. H-Revolve: A Framework for Adjoint Computation on Synchrone Hierarchical Platforms. 2019. ⟨hal-02080706v1⟩
177 Consultations
368 Téléchargements

Partager

Gmail Facebook X LinkedIn More