sig
  type 'a t
  type 'a elt_ = 'a
  type 'a heap = 'a t
  val empty : 'a heap
  val is_empty : 'a heap -> bool
  val singleton : 'a elt_ -> 'a heap
  val insert : 'a elt_ -> 'a heap -> 'a heap
  val merge : 'a heap -> 'a heap -> 'a heap
  val find_min : 'a heap -> 'a elt_
  val delete_min : 'a heap -> 'a heap
  val to_string : ('-> string) -> 'a heap -> string
end