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