sig
  type 'a typ = [ `Benum of 'a ]
  type 'a typdef = [ `Benum of 'a array ]
  type 'a t = { typ : string; reg : 'Reg.t; }
  type dt = Cudd.Man.d Enum.t
  type vt = Cudd.Man.v Enum.t
  val of_label :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
    '-> 'Enum.t
  val is_cst : 'Enum.t -> bool
  val to_code : 'Enum.t -> int
  val to_label :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
    'Enum.t -> 'a
  val equal_label :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
    'Enum.t -> '-> 'Cudd.Bdd.t
  val equal :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
    'Enum.t -> 'Enum.t -> 'Cudd.Bdd.t
  val ite : 'Cudd.Bdd.t -> 'Enum.t -> 'Enum.t -> 'Enum.t
  val guard_of_label :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
    'Enum.t -> '-> 'Cudd.Bdd.t
  val guardlabels :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
    'Enum.t -> ('Cudd.Bdd.t * 'a) list
  val cofactor : 'Enum.t -> 'Cudd.Bdd.t -> 'Enum.t
  val restrict : 'Enum.t -> 'Cudd.Bdd.t -> 'Enum.t
  val tdrestrict : 'Enum.t -> 'Cudd.Bdd.t -> 'Enum.t
  val print :
    (Format.formatter -> int -> unit) ->
    Format.formatter -> 'Enum.t -> unit
  val print_minterm :
    (Format.formatter -> 'Cudd.Bdd.t -> unit) ->
    ('b, [> 'Env.typ ], [> 'Env.typdef ], 'a, 'c) Env.O.t ->
    Format.formatter -> 'Enum.t -> unit
  val size_of_typ :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t -> '-> int
  val maxcode_of_typ :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t -> '-> int
  val mem_typcode :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
    '-> int -> bool
  val labels_of_typ :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
    '-> 'a array
  val code_of_label :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t -> '-> int
  val label_of_typcode :
    ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
    '-> int -> 'a
  module Minterm :
    sig
      val iter :
        ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
        '-> ('-> unit) -> Reg.Minterm.t -> unit
      val map :
        ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b, 'c) Env.O.t ->
        '-> ('-> 'd) -> Reg.Minterm.t -> 'd list
    end
  val permute : ?memo:Cudd.Memo.t -> 'Enum.t -> int array -> 'Enum.t
  val varmap : 'Enum.t -> 'Enum.t
  val vectorcompose :
    ?memo:Cudd.Memo.t -> 'Cudd.Bdd.t array -> 'Enum.t -> 'Enum.t
end