sig
  exception Empty
  type 'a t = 'Heap.t
  type 'a heap_el = 'Heap.heap_el
  val heap_el_is_valid : 'a heap_el -> bool
  val heap_el_get_el : 'a heap_el -> 'a
  val length : 'a t -> int
  val is_empty : 'a t -> bool
  val get_cmp : 'a t -> '-> '-> int
  val create : ?min_size:int -> ('-> '-> int) -> 'a t
  val of_array : ?min_size:int -> ('-> '-> int) -> 'a array -> 'a t
  val copy : 'a t -> 'a t
  val mem : 'a t -> '-> bool
  val heap_el_mem : 'a t -> 'a heap_el -> bool
  val find_heap_el : 'a t -> '-> 'a heap_el
  val top : 'a t -> 'a
  val maybe_top : 'a t -> 'a option
  val iter : 'a t -> f:('-> unit) -> unit
  val pop : 'a t -> 'a
  val maybe_pop : 'a t -> 'a option
  val pop_heap_el : 'a t -> 'a heap_el
  val maybe_pop_heap_el : 'a t -> 'a heap_el option
  val cond_pop : 'a t -> ('-> bool) -> 'a option
  val cond_pop_heap_el : 'a t -> ('-> bool) -> 'a heap_el option
  val push : 'a t -> '-> 'a heap_el
  val push_heap_el : 'a t -> 'a heap_el -> unit
  val remove : 'a heap_el -> unit
  val update : 'a heap_el -> '-> unit
  val check_heap_property : 'a t -> bool
end