sig
  type 'a t
  val empty : 'Bag.t
  val elt : '-> 'Bag.t
  val add : '-> 'Bag.t -> 'Bag.t
  val append : 'Bag.t -> '-> 'Bag.t
  val list : 'a list -> 'Bag.t
  val ulist : 'Bag.t list -> 'Bag.t
  val concat : 'Bag.t -> 'Bag.t -> 'Bag.t
  val map : ('-> 'b) -> 'Bag.t -> 'Bag.t
  val umap : ('-> 'Bag.t) -> 'Bag.t -> 'Bag.t
  val iter : ('-> unit) -> 'Bag.t -> unit
  val fold_left : ('-> '-> 'b) -> '-> 'Bag.t -> 'b
  val fold_right : ('-> '-> 'b) -> 'Bag.t -> '-> 'b
  val filter : ('-> bool) -> 'Bag.t -> 'Bag.t
  val partition : ('-> bool) -> 'Bag.t -> 'Bag.t * 'Bag.t
  val length : 'Bag.t -> int
  val is_empty : 'Bag.t -> bool
  val singleton : 'Bag.t -> 'a option
  val elements : 'Bag.t -> 'a list
  val sort : ('-> '-> int) -> 'Bag.t -> 'a list
end