sig
  type ('a, 'b, 'c, 'd) poly
  val instantiate :
    'Type.t ->
    'Type.t ->
    'Type.t -> 'Type.t -> ('a, 'b, 'c, 'd) poly Type.t * bool
  val is_instance_of : 'Type.t -> bool
  val get_instance :
    ('a, 'b, 'c, 'd) poly Type.t ->
    'Type.t * 'Type.t * 'Type.t * 'Type.t
  module Make :
    functor (T1 : S->
      functor (T2 : S->
        functor (T3 : S->
          functor (T4 : S->
            sig
              type t = (T1.t, T2.t, T3.t, T4.t) poly
              val ty : t Type.t
              val name : string
              val descr : t Descr.t
              val packed_descr : Structural_descr.pack
              val reprs : t list
              val equal : t -> t -> bool
              val compare : t -> t -> int
              val hash : t -> int
              val pretty_code : Format.formatter -> t -> unit
              val internal_pretty_code :
                Type.precedence -> Format.formatter -> t -> unit
              val pretty : Format.formatter -> t -> unit
              val varname : t -> string
              val mem_project : (Project_skeleton.t -> bool) -> t -> bool
              val copy : t -> t
            end
end