sig   module type OrderedType =     sig       type t       val compare : Map.OrderedType.t -> Map.OrderedType.t -> int     end   module type S =     sig       type key       type +'a t       val empty : 'Map.S.t       val is_empty : 'Map.S.t -> bool       val mem : Map.S.key -> 'Map.S.t -> bool       val add : Map.S.key -> '-> 'Map.S.t -> 'Map.S.t       val singleton : Map.S.key -> '-> 'Map.S.t       val remove : Map.S.key -> 'Map.S.t -> 'Map.S.t       val merge :         (Map.S.key -> 'a option -> 'b option -> 'c option) ->         'Map.S.t -> 'Map.S.t -> 'Map.S.t       val union :         (Map.S.key -> '-> '-> 'a option) ->         'Map.S.t -> 'Map.S.t -> 'Map.S.t       val compare : ('-> '-> int) -> 'Map.S.t -> 'Map.S.t -> int       val equal : ('-> '-> bool) -> 'Map.S.t -> 'Map.S.t -> bool       val iter : (Map.S.key -> '-> unit) -> 'Map.S.t -> unit       val fold : (Map.S.key -> '-> '-> 'b) -> 'Map.S.t -> '-> 'b       val for_all : (Map.S.key -> '-> bool) -> 'Map.S.t -> bool       val exists : (Map.S.key -> '-> bool) -> 'Map.S.t -> bool       val filter : (Map.S.key -> '-> bool) -> 'Map.S.t -> 'Map.S.t       val partition :         (Map.S.key -> '-> bool) -> 'Map.S.t -> 'Map.S.t * 'Map.S.t       val cardinal : 'Map.S.t -> int       val bindings : 'Map.S.t -> (Map.S.key * 'a) list       val min_binding : 'Map.S.t -> Map.S.key * 'a       val max_binding : 'Map.S.t -> Map.S.key * 'a       val choose : 'Map.S.t -> Map.S.key * 'a       val split :         Map.S.key -> 'Map.S.t -> 'Map.S.t * 'a option * 'Map.S.t       val find : Map.S.key -> 'Map.S.t -> 'a       val map : ('-> 'b) -> 'Map.S.t -> 'Map.S.t       val mapi : (Map.S.key -> '-> 'b) -> 'Map.S.t -> 'Map.S.t     end   module Make :     functor (Ord : OrderedType->       sig         type key = Ord.t         type +'a t         val empty : 'a t         val is_empty : 'a t -> bool         val mem : key -> 'a t -> bool         val add : key -> '-> 'a t -> 'a t         val singleton : key -> '-> 'a t         val remove : key -> 'a t -> 'a t         val merge :           (key -> 'a option -> 'b option -> 'c option) ->           'a t -> 'b t -> 'c t         val union : (key -> '-> '-> 'a option) -> 'a t -> 'a t -> 'a t         val compare : ('-> '-> int) -> 'a t -> 'a t -> int         val equal : ('-> '-> bool) -> 'a t -> 'a t -> bool         val iter : (key -> '-> unit) -> 'a t -> unit         val fold : (key -> '-> '-> 'b) -> 'a t -> '-> 'b         val for_all : (key -> '-> bool) -> 'a t -> bool         val exists : (key -> '-> bool) -> 'a t -> bool         val filter : (key -> '-> bool) -> 'a t -> 'a t         val partition : (key -> '-> bool) -> 'a t -> 'a t * 'a t         val cardinal : 'a t -> int         val bindings : 'a t -> (key * 'a) list         val min_binding : 'a t -> key * 'a         val max_binding : 'a t -> key * 'a         val choose : 'a t -> key * 'a         val split : key -> 'a t -> 'a t * 'a option * 'a t         val find : key -> 'a t -> 'a         val map : ('-> 'b) -> 'a t -> 'b t         val mapi : (key -> '-> 'b) -> 'a t -> 'b t       end end