sig   type ('a, 'b) t = 'a * 'b   val make : '-> '-> 'a * 'b   external first : 'a * '-> 'a = "%field0"   external second : 'a * '-> 'b = "%field1"   val swap : 'a * '-> 'b * 'a   val map : ('-> 'c) -> ('-> 'd) -> 'a * '-> 'c * 'd   val mapn : ('-> 'b) -> 'a * '-> 'b * 'b   val map1 : ('-> 'c) -> 'a * '-> 'c * 'b   val map2 : ('-> 'c) -> 'a * '-> 'a * 'c   val curry : ('a * '-> 'c) -> '-> '-> 'c   val uncurry : ('-> '-> 'c) -> 'a * '-> 'c   val print :     ?first:string ->     ?sep:string ->     ?last:string ->     ('BatIO.output -> '-> unit) ->     ('BatIO.output -> '-> unit) -> 'BatIO.output -> 'a * '-> unit   val printn :     ?first:string ->     ?sep:string ->     ?last:string ->     ('BatIO.output -> '-> unit) -> 'BatIO.output -> 'a * '-> unit   val compare :     ?cmp1:('-> '-> int) ->     ?cmp2:('-> '-> int) -> 'a * '-> 'a * '-> int   type 'a enumerable = 'a * 'a   val enum : 'a enumerable -> 'BatEnum.t   val of_enum : 'BatEnum.t -> 'a enumerable   val eq : 'BatOrd.eq -> 'BatOrd.eq -> ('a * 'b) BatOrd.eq   val ord : 'BatOrd.ord -> 'BatOrd.ord -> ('a * 'b) BatOrd.ord   val comp : 'BatOrd.comp -> 'BatOrd.comp -> ('a * 'b) BatOrd.comp   module Eq :     functor (T1 : BatOrd.Eq) (T2 : BatOrd.Eq->       sig type t = T1.t * T2.t val eq : t BatOrd.eq end   module Ord :     functor (T1 : BatOrd.Ord) (T2 : BatOrd.Ord->       sig type t = T1.t * T2.t val ord : t BatOrd.ord end   module Comp :     functor (T1 : BatOrd.Comp) (T2 : BatOrd.Comp->       sig type t = T1.t * T2.t val compare : t BatOrd.comp end end