sig   type ('a, 'b, 'c, 'd, 'e) t = 'a * 'b * 'c * 'd * 'e   val make : '-> '-> '-> '-> '-> 'a * 'b * 'c * 'd * 'e   val first : 'a * 'b * 'c * 'd * '-> 'a   val second : 'a * 'b * 'c * 'd * '-> 'b   val third : 'a * 'b * 'c * 'd * '-> 'c   val fourth : 'a * 'b * 'c * 'd * '-> 'd   val fifth : 'a * 'b * 'c * 'd * '-> 'e   val get12 : 'a * 'b * 'c * 'd * '-> 'a * 'b   val get13 : 'a * 'b * 'c * 'd * '-> 'a * 'c   val get14 : 'a * 'b * 'c * 'd * '-> 'a * 'd   val get15 : 'a * 'b * 'c * 'd * '-> 'a * 'e   val get23 : 'a * 'b * 'c * 'd * '-> 'b * 'c   val get24 : 'a * 'b * 'c * 'd * '-> 'b * 'd   val get25 : 'a * 'b * 'c * 'd * '-> 'b * 'e   val get34 : 'a * 'b * 'c * 'd * '-> 'c * 'd   val get35 : 'a * 'b * 'c * 'd * '-> 'c * 'e   val get45 : 'a * 'b * 'c * 'd * '-> 'd * 'e   val get123 : 'a * 'b * 'c * 'd * '-> 'a * 'b * 'c   val get124 : 'a * 'b * 'c * 'd * '-> 'a * 'b * 'd   val get125 : 'a * 'b * 'c * 'd * '-> 'a * 'b * 'e   val get134 : 'a * 'b * 'c * 'd * '-> 'a * 'c * 'd   val get135 : 'a * 'b * 'c * 'd * '-> 'a * 'c * 'e   val get145 : 'a * 'b * 'c * 'd * '-> 'a * 'd * 'e   val get234 : 'a * 'b * 'c * 'd * '-> 'b * 'c * 'd   val get235 : 'a * 'b * 'c * 'd * '-> 'b * 'c * 'e   val get245 : 'a * 'b * 'c * 'd * '-> 'b * 'd * 'e   val get345 : 'a * 'b * 'c * 'd * '-> 'c * 'd * 'e   val get1234 : 'a * 'b * 'c * 'd * '-> 'a * 'b * 'c * 'd   val get1235 : 'a * 'b * 'c * 'd * '-> 'a * 'b * 'c * 'e   val get1245 : 'a * 'b * 'c * 'd * '-> 'a * 'b * 'd * 'e   val get1345 : 'a * 'b * 'c * 'd * '-> 'a * 'c * 'd * 'e   val get2345 : 'a * 'b * 'c * 'd * '-> 'b * 'c * 'd * 'e   val map :     ('-> 'f) ->     ('-> 'g) ->     ('-> 'h) ->     ('-> 'i) ->     ('-> 'j) -> 'a * 'b * 'c * 'd * '-> 'f * 'g * 'h * 'i * 'j   val mapn : ('-> 'b) -> 'a * 'a * 'a * 'a * '-> 'b * 'b * 'b * 'b * 'b   val map1 : ('-> 'f) -> 'a * 'b * 'c * 'd * '-> 'f * 'b * 'c * 'd * 'e   val map2 : ('-> 'f) -> 'a * 'b * 'c * 'd * '-> 'a * 'f * 'c * 'd * 'e   val map3 : ('-> 'f) -> 'a * 'b * 'c * 'd * '-> 'a * 'b * 'f * 'd * 'e   val map4 : ('-> 'f) -> 'a * 'b * 'c * 'd * '-> 'a * 'b * 'c * 'f * 'e   val map5 : ('-> 'f) -> 'a * 'b * 'c * 'd * '-> 'a * 'b * 'c * 'd * 'f   val curry :     ('a * 'b * 'c * 'd * '-> 'f) -> '-> '-> '-> '-> '-> 'f   val uncurry :     ('-> '-> '-> '-> '-> 'f) -> 'a * 'b * 'c * 'd * '-> 'f   val print :     ?first:string ->     ?sep:string ->     ?last:string ->     ('BatIO.output -> '-> unit) ->     ('BatIO.output -> '-> unit) ->     ('BatIO.output -> '-> unit) ->     ('BatIO.output -> '-> unit) ->     ('BatIO.output -> '-> unit) ->     'BatIO.output -> 'a * 'b * 'c * 'd * '-> unit   val printn :     ?first:string ->     ?sep:string ->     ?last:string ->     ('BatIO.output -> '-> unit) ->     'BatIO.output -> 'a * 'a * 'a * 'a * '-> unit   val compare :     ?cmp1:('-> '-> int) ->     ?cmp2:('-> '-> int) ->     ?cmp3:('-> '-> int) ->     ?cmp4:('-> '-> int) ->     ?cmp5:('-> '-> int) ->     'a * 'b * 'c * 'd * '-> 'a * 'b * 'c * 'd * '-> int   type 'a enumerable = 'a * 'a * 'a * 'a * 'a   val enum : 'a enumerable -> 'BatEnum.t   val of_enum : 'BatEnum.t -> 'a enumerable   val eq :     'BatOrd.eq ->     'BatOrd.eq ->     'BatOrd.eq ->     'BatOrd.eq -> 'BatOrd.eq -> ('a * 'b * 'c * 'd * 'e) BatOrd.eq   val ord :     'BatOrd.ord ->     'BatOrd.ord ->     'BatOrd.ord ->     'BatOrd.ord -> 'BatOrd.ord -> ('a * 'b * 'c * 'd * 'e) BatOrd.ord   val comp :     'BatOrd.comp ->     'BatOrd.comp ->     'BatOrd.comp ->     'BatOrd.comp -> 'BatOrd.comp -> ('a * 'b * 'c * 'd * 'e) BatOrd.comp   module Eq :     functor       (T1 : BatOrd.Eq) (T2 : BatOrd.Eq) (T3 : BatOrd.Eq) (T4 : BatOrd.Eq) (T5 : BatOrd.Eq->       sig type t = T1.t * T2.t * T3.t * T4.t * T5.t val eq : t BatOrd.eq end   module Ord :     functor       (T1 : BatOrd.Ord) (T2 : BatOrd.Ord) (T3 : BatOrd.Ord) (T4 : BatOrd.Ord) (T5 : BatOrd.Ord->       sig         type t = T1.t * T2.t * T3.t * T4.t * T5.t         val ord : t BatOrd.ord       end   module Comp :     functor       (T1 : BatOrd.Comp) (T2 : BatOrd.Comp) (T3 : BatOrd.Comp) (T4 : BatOrd.Comp) (T5 : BatOrd.Comp->       sig         type t = T1.t * T2.t * T3.t * T4.t * T5.t         val compare : t BatOrd.comp       end end