sig
  type ('a, 'b, 'c) t = 'a * 'b * 'c
  val first : 'a * 'b * 'c -> 'a
  val second : 'a * 'b * 'c -> 'b
  val third : 'a * 'b * 'c -> 'c
  val get12 : 'a * 'b * 'c -> 'a * 'b
  val get13 : 'a * 'b * 'c -> 'a * 'c
  val get23 : 'a * 'b * 'c -> 'b * 'c
  val map :
    ('a -> 'b) -> ('c -> 'd) -> ('e -> 'f) -> 'a * 'c * 'e -> 'b * 'd * 'f
  val mapn : ('a -> 'b) -> 'a * 'a * 'a -> 'b * 'b * 'b
  val map1 : ('a -> 'b) -> 'a * 'c * 'd -> 'b * 'c * 'd
  val map2 : ('a -> 'b) -> 'c * 'a * 'd -> 'c * 'b * 'd
  val map3 : ('a -> 'b) -> 'c * 'd * 'a -> 'c * 'd * 'b
  val curry : ('a * 'b * 'c -> 'd) -> 'a -> 'b -> 'c -> 'd
  val uncurry : ('a -> 'b -> 'c -> 'd) -> 'a * 'b * 'c -> 'd
  val print :
    ?first:string ->
    ?sep:string ->
    ?last:string ->
    ('a BatIO.output -> 'b -> unit) ->
    ('a BatIO.output -> 'c -> unit) ->
    ('a BatIO.output -> 'd -> unit) ->
    'a BatIO.output -> 'b * 'c * 'd -> unit
  val printn :
    ?first:string ->
    ?sep:string ->
    ?last:string ->
    ('a BatIO.output -> 'b -> unit) ->
    'a BatIO.output -> 'b * 'b * 'b -> unit
  val compare :
    ?cmp1:('a -> 'a -> int) ->
    ?cmp2:('b -> 'b -> int) ->
    ?cmp3:('c -> 'c -> int) -> 'a * 'b * 'c -> 'a * 'b * 'c -> int
  type 'a enumerable = 'a * 'a * 'a
  val enum : 'a enumerable -> 'a BatEnum.t
  val of_enum : 'a BatEnum.t -> 'a enumerable
  val eq :
    'a BatOrd.eq -> 'b BatOrd.eq -> 'c BatOrd.eq -> ('a * 'b * 'c) BatOrd.eq
  val ord :
    'a BatOrd.ord ->
    'b BatOrd.ord -> 'c BatOrd.ord -> ('a * 'b * 'c) BatOrd.ord
  val comp :
    'a BatOrd.comp ->
    'b BatOrd.comp -> 'c BatOrd.comp -> ('a * 'b * 'c) BatOrd.comp
  module Eq :
    functor (T1 : BatOrd.Eq) ->
      functor (T2 : BatOrd.Eq) ->
        functor (T3 : BatOrd.Eq) ->
          sig type t = T1.t * T2.t * T3.t val eq : t BatOrd.eq end
  module Ord :
    functor (T1 : BatOrd.Ord) ->
      functor (T2 : BatOrd.Ord) ->
        functor (T3 : BatOrd.Ord) ->
          sig type t = T1.t * T2.t * T3.t val ord : t BatOrd.ord end
  module Comp :
    functor (T1 : BatOrd.Comp) ->
      functor (T2 : BatOrd.Comp) ->
        functor (T3 : BatOrd.Comp) ->
          sig type t = T1.t * T2.t * T3.t val compare : t BatOrd.comp end
  val make : 'a -> 'b -> 'c -> 'a * 'b * 'c
end