package coq-stdpp

  1. Overview
  2. No Docs
An extended "Standard Library" for Coq

Install

Dune Dependency

Authors

Maintainers

Sources

coq-stdpp-1.11.0.tar.gz
sha512=0f8e6d9b07171da515f258516d6f430a97da0b07e111ceff89b760a6cac5bc443db9e60e256eab719768ed8fe5b86af42b66d0bf9fba4dba6ef2afa011b92244

Description

The key features of this library are as follows:

  • It provides a great number of definitions and lemmas for common data structures such as lists, finite maps, finite sets, and finite multisets.
  • It uses type classes for common notations (like , , and Haskell-style monad notations) so that these can be overloaded for different data structures.
  • It uses type classes to keep track of common properties of types, like it having decidable equality or being countable or finite.
  • Most data structures are represented in canonical ways so that Leibniz equality can be used as much as possible (for example, for maps we have m1 = m2 iff ∀ i, m1 !! i = m2 !! i). On top of that, the library provides setoid instances for most types and operations.
  • It provides various tactics for common tasks, like an ssreflect inspired done tactic for finishing trivial goals, a simple breadth-first solver naive_solver, an equality simplifier simplify_eq, a solver solve_proper for proving compatibility of functions with respect to relations, and a solver set_solver for goals involving set operations.
  • It is entirely dependency- and axiom-free.

Tags

date:2024-10-31 logpath:stdpp

Published: 31 Oct 2024

Dependencies

None

Dev Dependencies (1)

  1. coq (>= "8.18" & < "8.21~") | (= "dev")

Used by (3)

  1. coq-iris >= "4.3.0"
  2. coq-stdpp-bitvector >= "1.11.0"
  3. coq-vlsm >= "1.3"

Conflicts

None