Robbert Krebbers ; Bas Spitters - Type classes for efficient exact real arithmetic in Coq

lmcs:958 - Logical Methods in Computer Science, February 14, 2013, Volume 9, Issue 1 - https://doi.org/10.2168/LMCS-9(1:1)2013
Type classes for efficient exact real arithmetic in CoqArticle

Authors: Robbert Krebbers ; Bas Spitters

    Floating point operations are fast, but require continuous effort on the part of the user in order to ensure that the results are correct. This burden can be shifted away from the user by providing a library of exact analysis in which the computer handles the error estimates. Previously, we [Krebbers/Spitters 2011] provided a fast implementation of the exact real numbers in the Coq proof assistant. Our implementation improved on an earlier implementation by O'Connor by using type classes to describe an abstract specification of the underlying dense set from which the real numbers are built. In particular, we used dyadic rationals built from Coq's machine integers to obtain a 100 times speed up of the basic operations already. This article is a substantially expanded version of [Krebbers/Spitters 2011] in which the implementation is extended in the various ways. First, we implement and verify the sine and cosine function. Secondly, we create an additional implementation of the dense set based on Coq's fast rational numbers. Thirdly, we extend the hierarchy to capture order on undecidable structures, while it was limited to decidable structures before. This hierarchy, based on type classes, allows us to share theory on the naturals, integers, rationals, dyadics, and reals in a convenient way. Finally, we obtain another dramatic speed-up by avoiding evaluation of termination proofs at runtime.


    Volume: Volume 9, Issue 1
    Published on: February 14, 2013
    Imported on: June 16, 2011
    Keywords: Computer Science - Logic in Computer Science,Mathematics - Numerical Analysis,D.2.4,F.4.1,G.1
    Funding:
      Source : OpenAIRE Graph
    • Formalisation of Mathematics; Funder: European Commission; Code: 243847

    14 Documents citing this article

    Consultation statistics

    This page has been seen 1003 times.
    This article's PDF has been downloaded 456 times.