sig
  module O :
    sig
      module Bool :
        sig
          type ('a, 'b) t =
              (('a, 'b) Cond.O.t, ('a, 'b) Expr1.O.Bool.t) Bdd.Cond.value
            constraint 'b =
              ('a, [> 'Env.typ ] as 'c, [> 'Env.typdef ] as 'd, 'e)
              Env.O.t
          val of_expr0 :
            ?normalize:bool ->
            ?reduce:bool ->
            ?careset:bool ->
            ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd) Env.O.t ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Cond.O.t ->
            'Expr0.Bool.t -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.Bool.t
          val of_expr1 :
            ?normalize:bool ->
            ?reduce:bool ->
            ?careset:bool ->
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Cond.O.t ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr1.O.Bool.t ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.Bool.t
          val get_env :
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Expr2.O.Bool.t -> ('a, 'b, 'c, 'd) Env.O.t
          val get_cond :
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Expr2.O.Bool.t -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Cond.O.t
          val to_expr0 :
            ('a, ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b) Env.O.t)
            Expr2.O.Bool.t -> 'Expr0.Bool.t
          val to_expr1 :
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Expr2.O.Bool.t -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr1.O.Bool.t
          val of_expr :
            (('a,
              ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
              Env.O.t)
             Cond.O.t,
             (('a, 'b, 'c, 'd) Env.O.t, [> `Bool of 'Expr0.Bool.t ])
             Env.value)
            Bdd.Cond.value -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.Bool.t
          val to_expr :
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Expr2.O.Bool.t ->
            (('a, ('a, 'b, 'c, 'd) Env.O.t) Cond.O.t,
             (('a, 'b, 'c, 'd) Env.O.t, [> `Bool of 'Expr0.Bool.t ])
             Env.value)
            Bdd.Cond.value
          val extend_environment :
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Expr2.O.Bool.t ->
            ('a, 'b, 'c, 'd) Env.O.t ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.Bool.t
          val is_false :
            ('a, ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b) Env.O.t)
            Expr2.O.Bool.t -> bool
          val is_true :
            ('a, ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b) Env.O.t)
            Expr2.O.Bool.t -> bool
          val print :
            Format.formatter ->
            ('a, ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b) Env.O.t)
            Expr2.O.Bool.t -> unit
        end
      type ('a, 'b) t =
          (('a, 'b) Cond.O.t, ('a, 'b) Expr1.O.t) Bdd.Cond.value
        constraint 'b =
          ('a, [> 'Env.typ ] as 'c, [> 'Env.typdef ] as 'd, 'e) Env.O.t
      type ('a, 'b) expr = ('a, 'b) Expr2.O.t
        constraint 'b =
          ('a, [> 'Env.typ ] as 'c, [> 'Env.typdef ] as 'd, 'e) Env.O.t
      val of_expr0 :
        ?normalize:bool ->
        ?reduce:bool ->
        ?careset:bool ->
        ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd) Env.O.t ->
        ('a, ('a, 'b, 'c, 'd) Env.O.t) Cond.O.t ->
        'Expr0.t -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.t
      val of_expr1 :
        ?normalize:bool ->
        ?reduce:bool ->
        ?careset:bool ->
        ('a,
         ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd) Env.O.t)
        Cond.O.t ->
        ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr1.O.t ->
        ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.t
      val get_env :
        ('a,
         ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd) Env.O.t)
        Expr2.O.t -> ('a, 'b, 'c, 'd) Env.O.t
      val get_cond :
        ('a,
         ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd) Env.O.t)
        Expr2.O.t -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Cond.O.t
      val to_expr0 :
        ('a, ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b) Env.O.t) Expr2.O.t ->
        'Expr0.t
      val to_expr1 :
        ('a,
         ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd) Env.O.t)
        Expr2.O.t -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr1.O.t
      val extend_environment :
        ('a,
         ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd) Env.O.t)
        Expr2.O.t ->
        ('a, 'b, 'c, 'd) Env.O.t -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.t
      val print :
        Format.formatter ->
        ('a, ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b) Env.O.t) Expr2.O.t ->
        unit
      module List :
        sig
          type ('a, 'b) t =
              (('a, 'b) Cond.O.t, ('a, 'b) Expr1.O.List.t) Bdd.Cond.value
            constraint 'b =
              ('a, [> 'Env.typ ] as 'c, [> 'Env.typdef ] as 'd, 'e)
              Env.O.t
          val of_lexpr0 :
            ?normalize:bool ->
            ?reduce:bool ->
            ?careset:bool ->
            ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd) Env.O.t ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Cond.O.t ->
            'Expr0.t list -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.List.t
          val of_lexpr1 :
            ?normalize:bool ->
            ?reduce:bool ->
            ?careset:bool ->
            ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd) Env.O.t ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Cond.O.t ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr1.O.t list ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.List.t
          val of_listexpr1 :
            ?normalize:bool ->
            ?reduce:bool ->
            ?careset:bool ->
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Cond.O.t ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr1.O.List.t ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.List.t
          val get_env :
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Expr2.O.List.t -> ('a, 'b, 'c, 'd) Env.O.t
          val get_cond :
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Expr2.O.List.t -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Cond.O.t
          val to_lexpr0 :
            ('a, ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b) Env.O.t)
            Expr2.O.List.t -> 'Expr0.t list
          val to_lexpr1 :
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Expr2.O.List.t -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr1.O.t list
          val to_listexpr1 :
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Expr2.O.List.t -> ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr1.O.List.t
          val extend_environment :
            ('a,
             ('a, [> 'Env.typ ] as 'b, [> 'Env.typdef ] as 'c, 'd)
             Env.O.t)
            Expr2.O.List.t ->
            ('a, 'b, 'c, 'd) Env.O.t ->
            ('a, ('a, 'b, 'c, 'd) Env.O.t) Expr2.O.List.t
          val print :
            Format.formatter ->
            ('a, ('a, [> 'Env.typ ], [> 'Env.typdef ], 'b) Env.O.t)
            Expr2.O.List.t -> unit
        end
    end
  type 'a t = ('Cond.t, 'Expr1.t) Bdd.Cond.value
  type 'a expr = 'Expr2.t
  val of_expr0 :
    ?normalize:bool ->
    ?reduce:bool ->
    ?careset:bool -> 'Env.t -> 'Cond.t -> 'Expr0.t -> 'Expr2.t
  val of_expr1 :
    ?normalize:bool ->
    ?reduce:bool -> ?careset:bool -> 'Cond.t -> 'Expr1.t -> 'Expr2.t
  val get_env : 'Expr2.t -> 'Env.t
  val get_cond : 'Expr2.t -> 'Cond.t
  val to_expr0 : 'Expr2.t -> 'Expr0.t
  val to_expr1 : 'Expr2.t -> 'Expr1.t
  val extend_environment : 'Expr2.t -> 'Env.t -> 'Expr2.t
  val print : Format.formatter -> 'Expr2.t -> unit
  module Bool :
    sig
      type 'a t = ('Cond.t, 'Expr1.Bool.t) Bdd.Cond.value
      val of_expr0 :
        ?normalize:bool ->
        ?reduce:bool ->
        ?careset:bool ->
        'Env.t -> 'Cond.t -> 'Expr0.Bool.t -> 'Expr2.Bool.t
      val of_expr1 :
        ?normalize:bool ->
        ?reduce:bool ->
        ?careset:bool -> 'Cond.t -> 'Expr1.Bool.t -> 'Expr2.Bool.t
      val get_env : 'Expr2.Bool.t -> 'Env.t
      val get_cond : 'Expr2.Bool.t -> 'Cond.t
      val to_expr0 : 'Expr2.Bool.t -> 'Expr0.Bool.t
      val to_expr1 : 'Expr2.Bool.t -> 'Expr1.Bool.t
      val of_expr : 'Expr2.expr -> 'Expr2.Bool.t
      val to_expr : 'Expr2.Bool.t -> 'Expr2.expr
      val extend_environment : 'Expr2.Bool.t -> 'Env.t -> 'Expr2.Bool.t
      val is_false : 'Expr2.Bool.t -> bool
      val is_true : 'Expr2.Bool.t -> bool
      val print : Format.formatter -> 'Expr2.Bool.t -> unit
    end
  module List :
    sig
      type 'a t = ('Cond.t, 'Expr1.List.t) Bdd.Cond.value
      val of_lexpr0 :
        ?normalize:bool ->
        ?reduce:bool ->
        ?careset:bool ->
        'Env.t -> 'Cond.t -> 'Expr0.t list -> 'Expr2.List.t
      val of_lexpr1 :
        ?normalize:bool ->
        ?reduce:bool ->
        ?careset:bool ->
        'Env.t -> 'Cond.t -> 'Expr1.t list -> 'Expr2.List.t
      val of_listexpr1 :
        ?normalize:bool ->
        ?reduce:bool ->
        ?careset:bool -> 'Cond.t -> 'Expr1.List.t -> 'Expr2.List.t
      val get_env : 'Expr2.List.t -> 'Env.t
      val get_cond : 'Expr2.List.t -> 'Cond.t
      val to_lexpr0 : 'Expr2.List.t -> 'Expr0.t list
      val to_listexpr1 : 'Expr2.List.t -> 'Expr1.List.t
      val to_lexpr1 : 'Expr2.List.t -> 'Expr1.t list
      val extend_environment : 'Expr2.List.t -> 'Env.t -> 'Expr2.List.t
      val print : Format.formatter -> 'Expr2.List.t -> unit
    end
end