/diqt

Formalization of hashtables with Radix trees and PArray in Coq

Primary LanguageCoqOtherNOASSERTION

Diqt: Formalization of hashtables with Radix trees and PArray in Coq

This library provides two hashtable structures. They use either Radix trees and positive integers, or persistent arrays Coq.PArray and machine integers. Their purpose is to be efficient when evaluating the code with Coq's virtual machine vm_compute.

Overview of the development

Development

The main branch is currently developed using Coq version 8.17.1.

Build

coq_makefile -f _CoqProject -o Makefile
make

Docs

Full documentation: diqt

Function (A: Keys, B: Value):

create: Set -> int -> t B
add: t B -> A -> B -> t B
find: t B -> A -> option B
find_all: t B -> A -> list B
mem: t B -> A -> bool
remove: t B -> A -> t B
replace: t B -> A -> B -> t B

Hashtable Int keys functor

Module Type HashI.
  Parameter A: Set.
  Parameter eq: A -> A -> bool.
  Parameter eq_spec: forall x y: A, reflect (x = y) (eq x y).
  Parameter hash: A -> int.
End HashI.

HashTable Positive keys functor

Module Type HashP.
  Parameter A: Set.
  Parameter eq: A -> A -> bool.
  Parameter eq_spec: forall x y: A, reflect (x = y) (eq x y).
  Parameter hash: A -> positive.
End HashP.

Tests

  • Table [Type keys]: HashTable with PArray
  • Positive [Type keys]: HashTable with Tree
  • FMap AVL: Associative structure with FMAP AVL
  • PosMap Pos: Associative structure with PosMap

Pascal Function

pascal

Syracuse Function

Syracuse