sig
  type key = Circuit.node
  type 'a t = 'Node.NSet.t
  val create : int -> 'Circuit.NSet.t
  val clear : 'Circuit.NSet.t -> unit
  val copy : 'Circuit.NSet.t -> 'Circuit.NSet.t
  val remove : 'Circuit.NSet.t -> Circuit.NSet.key -> unit
  val find : 'Circuit.NSet.t -> Circuit.NSet.key -> 'a
  val find_all : 'Circuit.NSet.t -> Circuit.NSet.key -> 'a list
  val replace : 'Circuit.NSet.t -> Circuit.NSet.key -> '-> unit
  val mem : 'Circuit.NSet.t -> Circuit.NSet.key -> bool
  val length : 'Circuit.NSet.t -> int
  val add : unit Circuit.NSet.t -> Circuit.NSet.key -> unit
  val iter : (Circuit.NSet.key -> unit) -> unit Circuit.NSet.t -> unit
  val fold :
    (Circuit.NSet.key -> '-> 'a) -> unit Circuit.NSet.t -> '-> 'a
  val to_list : unit Circuit.NSet.t -> Circuit.NSet.key list
  val sum_map : (Circuit.NSet.key -> int) -> unit Circuit.NSet.t -> int
  val sumf_map : (Circuit.NSet.key -> float) -> unit Circuit.NSet.t -> float
  val filter : (Circuit.NSet.key -> bool) -> unit Circuit.NSet.t -> unit
end