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