package rocq-stdpp
An extended "Standard Library" for Rocq
Install
Dune Dependency
Authors
Maintainers
Sources
stdpp-1.13.0.tar.gz
sha512=ba0477e0a7f3adea3baf726133294171724e57de107bd79d397392881ee9093f8055334958fdf9db6c3b72a99763510c8e9b4e6eca51dbe0c5676fd6f5a78a73
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 = m2iff∀ 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
donetactic for finishing trivial goals, a simple breadth-first solvernaive_solver, an equality simplifiersimplify_eq, a solversolve_properfor proving compatibility of functions with respect to relations, and a solverset_solverfor goals involving set operations. - It is entirely dependency- and axiom-free.
Dependencies (1)
Dev Dependencies (1)
-
rocq-core
(>= "9.0" & < "9.3~") | (= "dev")
Used by (2)
Conflicts (1)
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
On This Page