sig
  type ('a, 'b) t = ('a * 'b) list
  val add :
    ('a, 'b) List.Assoc.t ->
    ?equal:('-> '-> bool) -> '-> '-> ('a, 'b) List.Assoc.t
  val find :
    ('a, 'b) List.Assoc.t ->
    ?equal:('-> '-> bool) -> '-> 'b option
  val find_exn :
    ('a, 'b) List.Assoc.t -> ?equal:('-> '-> bool) -> '-> 'b
  val mem :
    ('a, 'b) List.Assoc.t -> ?equal:('-> '-> bool) -> '-> bool
  val remove :
    ('a, 'b) List.Assoc.t ->
    ?equal:('-> '-> bool) -> '-> ('a, 'b) List.Assoc.t
  val map :
    ('a, 'b) List.Assoc.t -> f:('-> 'c) -> ('a, 'c) List.Assoc.t
  val inverse : ('a, 'b) List.Assoc.t -> ('b, 'a) List.Assoc.t
  val t_of_sexp :
    (Sexplib.Sexp.t -> 'a) ->
    (Sexplib.Sexp.t -> 'b) -> Sexplib.Sexp.t -> ('a, 'b) List.Assoc.t
  val sexp_of_t :
    ('-> Sexplib.Sexp.t) ->
    ('-> Sexplib.Sexp.t) -> ('a, 'b) List.Assoc.t -> Sexplib.Sexp.t
end