Extracting a Data Flow Analyser in Constructive Logic - Archive ouverte HAL Accéder directement au contenu
Communication Dans Un Congrès Année : 2004

Extracting a Data Flow Analyser in Constructive Logic

David Cachera
Thomas Jensen
  • Fonction : Auteur
  • PersonId : 874110
David Pichardie

Résumé

We show how to formalise a constraint-based data flow analysis in the specification language of the Coq proof assistant. This involves defining a dependent type of lattices together with a library of lattice functors for modular construction of complex abstract domains. Constraints are expressed in an intermediate representation that allows for both efficient constraint resolution and correctness proof of the analysis with respect to an operational semantics. The proof of existence of a correct, minimal solution to the constraints is constructive which means that the extraction mechanism of Coq provides a provably correct data flow analyser in ocaml. The library of lattices together with the intermediate representation of constraints are defined in an analysis-independent fashion that provides a basis for a generic framework for proving and extracting static analysers in Coq.
Fichier principal
Vignette du fichier
extractDataFlow-ESOP-nospringerlogo.pdf (245.21 Ko) Télécharger le fichier
Origine : Fichiers produits par l'(les) auteur(s)

Dates et versions

inria-00564633 , version 1 (09-02-2011)

Identifiants

  • HAL Id : inria-00564633 , version 1

Citer

David Cachera, Thomas Jensen, David Pichardie, Vlad Rusu. Extracting a Data Flow Analyser in Constructive Logic. ESOP, 2004, Barcelona, Spain. ⟨inria-00564633⟩
401 Consultations
264 Téléchargements

Partager

Gmail Facebook X LinkedIn More