import { aK as I, aL as qe, aM as O, ah as y, ag as Te, aN as Xe, aO as Qe, aP as We, aQ as Ee, aR as G, ae as X, aS as Je, aT as Oe, aU as ze, aV as C, aW as R, an as $e, a8 as me, aX as Ve, aY as Z, aZ as ke, a_ as en, a$ as L, am as nn, b0 as rn, af as tn, b1 as re, b2 as sn, b3 as an, al as un, ak as we, ai as fn, b4 as B, ac as on, b5 as dn, ao as M, z as te, b6 as ie } from "./mermaid-00886c59.js";
var hn = "[object Symbol]";
function Q(e) {
  return typeof e == "symbol" || I(e) && qe(e) == hn;
}
function ve(e, n) {
  for (var r = -1, t = e == null ? 0 : e.length, i = Array(t); ++r < t; )
    i[r] = n(e[r], r, e);
  return i;
}
var ln = 1 / 0, se = O ? O.prototype : void 0, ae = se ? se.toString : void 0;
function Pe(e) {
  if (typeof e == "string")
    return e;
  if (y(e))
    return ve(e, Pe) + "";
  if (Q(e))
    return ae ? ae.call(e) : "";
  var n = e + "";
  return n == "0" && 1 / e == -ln ? "-0" : n;
}
function gn() {
}
function Le(e, n) {
  for (var r = -1, t = e == null ? 0 : e.length; ++r < t && n(e[r], r, e) !== !1; )
    ;
  return e;
}
function cn(e, n, r, t) {
  for (var i = e.length, s = r + (t ? 1 : -1); t ? s-- : ++s < i; )
    if (n(e[s], s, e))
      return s;
  return -1;
}
function _n(e) {
  return e !== e;
}
function pn(e, n, r) {
  for (var t = r - 1, i = e.length; ++t < i; )
    if (e[t] === n)
      return t;
  return -1;
}
function bn(e, n, r) {
  return n === n ? pn(e, n, r) : cn(e, _n, r);
}
function yn(e, n) {
  var r = e == null ? 0 : e.length;
  return !!r && bn(e, n, 0) > -1;
}
function T(e) {
  return Te(e) ? Xe(e) : Qe(e);
}
var An = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, Tn = /^\w*$/;
function W(e, n) {
  if (y(e))
    return !1;
  var r = typeof e;
  return r == "number" || r == "symbol" || r == "boolean" || e == null || Q(e) ? !0 : Tn.test(e) || !An.test(e) || n != null && e in Object(n);
}
var En = 500;
function On(e) {
  var n = We(e, function(t) {
    return r.size === En && r.clear(), t;
  }), r = n.cache;
  return n;
}
var $n = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g, mn = /\\(\\)?/g, wn = On(function(e) {
  var n = [];
  return e.charCodeAt(0) === 46 && n.push(""), e.replace($n, function(r, t, i, s) {
    n.push(i ? s.replace(mn, "$1") : t || r);
  }), n;
});
const vn = wn;
function Pn(e) {
  return e == null ? "" : Pe(e);
}
function Ie(e, n) {
  return y(e) ? e : W(e, n) ? [e] : vn(Pn(e));
}
var Ln = 1 / 0;
function U(e) {
  if (typeof e == "string" || Q(e))
    return e;
  var n = e + "";
  return n == "0" && 1 / e == -Ln ? "-0" : n;
}
function Ce(e, n) {
  n = Ie(n, e);
  for (var r = 0, t = n.length; e != null && r < t; )
    e = e[U(n[r++])];
  return r && r == t ? e : void 0;
}
function In(e, n, r) {
  var t = e == null ? void 0 : Ce(e, n);
  return t === void 0 ? r : t;
}
function J(e, n) {
  for (var r = -1, t = n.length, i = e.length; ++r < t; )
    e[i + r] = n[r];
  return e;
}
var ue = O ? O.isConcatSpreadable : void 0;
function Cn(e) {
  return y(e) || Ee(e) || !!(ue && e && e[ue]);
}
function Se(e, n, r, t, i) {
  var s = -1, a = e.length;
  for (r || (r = Cn), i || (i = []); ++s < a; ) {
    var u = e[s];
    n > 0 && r(u) ? n > 1 ? Se(u, n - 1, r, t, i) : J(i, u) : t || (i[i.length] = u);
  }
  return i;
}
function Sn(e, n, r, t) {
  var i = -1, s = e == null ? 0 : e.length;
  for (t && s && (r = e[++i]); ++i < s; )
    r = n(r, e[i], i, e);
  return r;
}
function Nn(e, n) {
  return e && G(n, T(n), e);
}
function Fn(e, n) {
  return e && G(n, X(n), e);
}
function Ne(e, n) {
  for (var r = -1, t = e == null ? 0 : e.length, i = 0, s = []; ++r < t; ) {
    var a = e[r];
    n(a, r, e) && (s[i++] = a);
  }
  return s;
}
function Fe() {
  return [];
}
var Mn = Object.prototype, xn = Mn.propertyIsEnumerable, fe = Object.getOwnPropertySymbols, Dn = fe ? function(e) {
  return e == null ? [] : (e = Object(e), Ne(fe(e), function(n) {
    return xn.call(e, n);
  }));
} : Fe;
const z = Dn;
function Rn(e, n) {
  return G(e, z(e), n);
}
var Gn = Object.getOwnPropertySymbols, Un = Gn ? function(e) {
  for (var n = []; e; )
    J(n, z(e)), e = Je(e);
  return n;
} : Fe;
const Me = Un;
function Bn(e, n) {
  return G(e, Me(e), n);
}
function xe(e, n, r) {
  var t = n(e);
  return y(e) ? t : J(t, r(e));
}
function q(e) {
  return xe(e, T, z);
}
function jn(e) {
  return xe(e, X, Me);
}
var Kn = Object.prototype, Hn = Kn.hasOwnProperty;
function Yn(e) {
  var n = e.length, r = new e.constructor(n);
  return n && typeof e[0] == "string" && Hn.call(e, "index") && (r.index = e.index, r.input = e.input), r;
}
function Zn(e, n) {
  var r = n ? Oe(e.buffer) : e.buffer;
  return new e.constructor(r, e.byteOffset, e.byteLength);
}
var qn = /\w*$/;
function Xn(e) {
  var n = new e.constructor(e.source, qn.exec(e));
  return n.lastIndex = e.lastIndex, n;
}
var oe = O ? O.prototype : void 0, de = oe ? oe.valueOf : void 0;
function Qn(e) {
  return de ? Object(de.call(e)) : {};
}
var Wn = "[object Boolean]", Jn = "[object Date]", zn = "[object Map]", Vn = "[object Number]", kn = "[object RegExp]", er = "[object Set]", nr = "[object String]", rr = "[object Symbol]", tr = "[object ArrayBuffer]", ir = "[object DataView]", sr = "[object Float32Array]", ar = "[object Float64Array]", ur = "[object Int8Array]", fr = "[object Int16Array]", or = "[object Int32Array]", dr = "[object Uint8Array]", hr = "[object Uint8ClampedArray]", lr = "[object Uint16Array]", gr = "[object Uint32Array]";
function cr(e, n, r) {
  var t = e.constructor;
  switch (n) {
    case tr:
      return Oe(e);
    case Wn:
    case Jn:
      return new t(+e);
    case ir:
      return Zn(e, r);
    case sr:
    case ar:
    case ur:
    case fr:
    case or:
    case dr:
    case hr:
    case lr:
    case gr:
      return ze(e, r);
    case zn:
      return new t();
    case Vn:
    case nr:
      return new t(e);
    case kn:
      return Xn(e);
    case er:
      return new t();
    case rr:
      return Qn(e);
  }
}
var _r = "[object Map]";
function pr(e) {
  return I(e) && C(e) == _r;
}
var he = R && R.isMap, br = he ? $e(he) : pr;
const yr = br;
var Ar = "[object Set]";
function Tr(e) {
  return I(e) && C(e) == Ar;
}
var le = R && R.isSet, Er = le ? $e(le) : Tr;
const Or = Er;
var $r = 1, mr = 2, wr = 4, De = "[object Arguments]", vr = "[object Array]", Pr = "[object Boolean]", Lr = "[object Date]", Ir = "[object Error]", Re = "[object Function]", Cr = "[object GeneratorFunction]", Sr = "[object Map]", Nr = "[object Number]", Ge = "[object Object]", Fr = "[object RegExp]", Mr = "[object Set]", xr = "[object String]", Dr = "[object Symbol]", Rr = "[object WeakMap]", Gr = "[object ArrayBuffer]", Ur = "[object DataView]", Br = "[object Float32Array]", jr = "[object Float64Array]", Kr = "[object Int8Array]", Hr = "[object Int16Array]", Yr = "[object Int32Array]", Zr = "[object Uint8Array]", qr = "[object Uint8ClampedArray]", Xr = "[object Uint16Array]", Qr = "[object Uint32Array]", h = {};
h[De] = h[vr] = h[Gr] = h[Ur] = h[Pr] = h[Lr] = h[Br] = h[jr] = h[Kr] = h[Hr] = h[Yr] = h[Sr] = h[Nr] = h[Ge] = h[Fr] = h[Mr] = h[xr] = h[Dr] = h[Zr] = h[qr] = h[Xr] = h[Qr] = !0;
h[Ir] = h[Re] = h[Rr] = !1;
function j(e, n, r, t, i, s) {
  var a, u = n & $r, f = n & mr, g = n & wr;
  if (r && (a = i ? r(e, t, i, s) : r(e)), a !== void 0)
    return a;
  if (!me(e))
    return e;
  var l = y(e);
  if (l) {
    if (a = Yn(e), !u)
      return Ve(e, a);
  } else {
    var o = C(e), d = o == Re || o == Cr;
    if (Z(e))
      return ke(e, u);
    if (o == Ge || o == De || d && !i) {
      if (a = f || d ? {} : en(e), !u)
        return f ? Bn(e, Fn(a, e)) : Rn(e, Nn(a, e));
    } else {
      if (!h[o])
        return i ? e : {};
      a = cr(e, o, u);
    }
  }
  s || (s = new L());
  var A = s.get(e);
  if (A)
    return A;
  s.set(e, a), Or(e) ? e.forEach(function(c) {
    a.add(j(c, n, r, c, e, s));
  }) : yr(e) && e.forEach(function(c, _) {
    a.set(_, j(c, n, r, _, e, s));
  });
  var p = g ? f ? jn : q : f ? X : T, b = l ? void 0 : p(e);
  return Le(b || e, function(c, _) {
    b && (_ = c, c = e[_]), nn(a, _, j(c, n, r, _, e, s));
  }), a;
}
var Wr = "__lodash_hash_undefined__";
function Jr(e) {
  return this.__data__.set(e, Wr), this;
}
function zr(e) {
  return this.__data__.has(e);
}
function S(e) {
  var n = -1, r = e == null ? 0 : e.length;
  for (this.__data__ = new rn(); ++n < r; )
    this.add(e[n]);
}
S.prototype.add = S.prototype.push = Jr;
S.prototype.has = zr;
function Vr(e, n) {
  for (var r = -1, t = e == null ? 0 : e.length; ++r < t; )
    if (n(e[r], r, e))
      return !0;
  return !1;
}
function Ue(e, n) {
  return e.has(n);
}
var kr = 1, et = 2;
function Be(e, n, r, t, i, s) {
  var a = r & kr, u = e.length, f = n.length;
  if (u != f && !(a && f > u))
    return !1;
  var g = s.get(e), l = s.get(n);
  if (g && l)
    return g == n && l == e;
  var o = -1, d = !0, A = r & et ? new S() : void 0;
  for (s.set(e, n), s.set(n, e); ++o < u; ) {
    var p = e[o], b = n[o];
    if (t)
      var c = a ? t(b, p, o, n, e, s) : t(p, b, o, e, n, s);
    if (c !== void 0) {
      if (c)
        continue;
      d = !1;
      break;
    }
    if (A) {
      if (!Vr(n, function(_, $) {
        if (!Ue(A, $) && (p === _ || i(p, _, r, t, s)))
          return A.push($);
      })) {
        d = !1;
        break;
      }
    } else if (!(p === b || i(p, b, r, t, s))) {
      d = !1;
      break;
    }
  }
  return s.delete(e), s.delete(n), d;
}
function nt(e) {
  var n = -1, r = Array(e.size);
  return e.forEach(function(t, i) {
    r[++n] = [i, t];
  }), r;
}
function V(e) {
  var n = -1, r = Array(e.size);
  return e.forEach(function(t) {
    r[++n] = t;
  }), r;
}
var rt = 1, tt = 2, it = "[object Boolean]", st = "[object Date]", at = "[object Error]", ut = "[object Map]", ft = "[object Number]", ot = "[object RegExp]", dt = "[object Set]", ht = "[object String]", lt = "[object Symbol]", gt = "[object ArrayBuffer]", ct = "[object DataView]", ge = O ? O.prototype : void 0, K = ge ? ge.valueOf : void 0;
function _t(e, n, r, t, i, s, a) {
  switch (r) {
    case ct:
      if (e.byteLength != n.byteLength || e.byteOffset != n.byteOffset)
        return !1;
      e = e.buffer, n = n.buffer;
    case gt:
      return !(e.byteLength != n.byteLength || !s(new re(e), new re(n)));
    case it:
    case st:
    case ft:
      return tn(+e, +n);
    case at:
      return e.name == n.name && e.message == n.message;
    case ot:
    case ht:
      return e == n + "";
    case ut:
      var u = nt;
    case dt:
      var f = t & rt;
      if (u || (u = V), e.size != n.size && !f)
        return !1;
      var g = a.get(e);
      if (g)
        return g == n;
      t |= tt, a.set(e, n);
      var l = Be(u(e), u(n), t, i, s, a);
      return a.delete(e), l;
    case lt:
      if (K)
        return K.call(e) == K.call(n);
  }
  return !1;
}
var pt = 1, bt = Object.prototype, yt = bt.hasOwnProperty;
function At(e, n, r, t, i, s) {
  var a = r & pt, u = q(e), f = u.length, g = q(n), l = g.length;
  if (f != l && !a)
    return !1;
  for (var o = f; o--; ) {
    var d = u[o];
    if (!(a ? d in n : yt.call(n, d)))
      return !1;
  }
  var A = s.get(e), p = s.get(n);
  if (A && p)
    return A == n && p == e;
  var b = !0;
  s.set(e, n), s.set(n, e);
  for (var c = a; ++o < f; ) {
    d = u[o];
    var _ = e[d], $ = n[d];
    if (t)
      var ne = a ? t($, _, d, n, e, s) : t(_, $, d, e, n, s);
    if (!(ne === void 0 ? _ === $ || i(_, $, r, t, s) : ne)) {
      b = !1;
      break;
    }
    c || (c = d == "constructor");
  }
  if (b && !c) {
    var N = e.constructor, F = n.constructor;
    N != F && "constructor" in e && "constructor" in n && !(typeof N == "function" && N instanceof N && typeof F == "function" && F instanceof F) && (b = !1);
  }
  return s.delete(e), s.delete(n), b;
}
var Tt = 1, ce = "[object Arguments]", _e = "[object Array]", x = "[object Object]", Et = Object.prototype, pe = Et.hasOwnProperty;
function Ot(e, n, r, t, i, s) {
  var a = y(e), u = y(n), f = a ? _e : C(e), g = u ? _e : C(n);
  f = f == ce ? x : f, g = g == ce ? x : g;
  var l = f == x, o = g == x, d = f == g;
  if (d && Z(e)) {
    if (!Z(n))
      return !1;
    a = !0, l = !1;
  }
  if (d && !l)
    return s || (s = new L()), a || sn(e) ? Be(e, n, r, t, i, s) : _t(e, n, f, r, t, i, s);
  if (!(r & Tt)) {
    var A = l && pe.call(e, "__wrapped__"), p = o && pe.call(n, "__wrapped__");
    if (A || p) {
      var b = A ? e.value() : e, c = p ? n.value() : n;
      return s || (s = new L()), i(b, c, r, t, s);
    }
  }
  return d ? (s || (s = new L()), At(e, n, r, t, i, s)) : !1;
}
function k(e, n, r, t, i) {
  return e === n ? !0 : e == null || n == null || !I(e) && !I(n) ? e !== e && n !== n : Ot(e, n, r, t, k, i);
}
var $t = 1, mt = 2;
function wt(e, n, r, t) {
  var i = r.length, s = i, a = !t;
  if (e == null)
    return !s;
  for (e = Object(e); i--; ) {
    var u = r[i];
    if (a && u[2] ? u[1] !== e[u[0]] : !(u[0] in e))
      return !1;
  }
  for (; ++i < s; ) {
    u = r[i];
    var f = u[0], g = e[f], l = u[1];
    if (a && u[2]) {
      if (g === void 0 && !(f in e))
        return !1;
    } else {
      var o = new L();
      if (t)
        var d = t(g, l, f, e, n, o);
      if (!(d === void 0 ? k(l, g, $t | mt, t, o) : d))
        return !1;
    }
  }
  return !0;
}
function je(e) {
  return e === e && !me(e);
}
function vt(e) {
  for (var n = T(e), r = n.length; r--; ) {
    var t = n[r], i = e[t];
    n[r] = [t, i, je(i)];
  }
  return n;
}
function Ke(e, n) {
  return function(r) {
    return r == null ? !1 : r[e] === n && (n !== void 0 || e in Object(r));
  };
}
function Pt(e) {
  var n = vt(e);
  return n.length == 1 && n[0][2] ? Ke(n[0][0], n[0][1]) : function(r) {
    return r === e || wt(r, e, n);
  };
}
function Lt(e, n) {
  return e != null && n in Object(e);
}
function He(e, n, r) {
  n = Ie(n, e);
  for (var t = -1, i = n.length, s = !1; ++t < i; ) {
    var a = U(n[t]);
    if (!(s = e != null && r(e, a)))
      break;
    e = e[a];
  }
  return s || ++t != i ? s : (i = e == null ? 0 : e.length, !!i && an(i) && un(a, i) && (y(e) || Ee(e)));
}
function It(e, n) {
  return e != null && He(e, n, Lt);
}
var Ct = 1, St = 2;
function Nt(e, n) {
  return W(e) && je(n) ? Ke(U(e), n) : function(r) {
    var t = In(r, e);
    return t === void 0 && t === n ? It(r, e) : k(n, t, Ct | St);
  };
}
function Ft(e) {
  return function(n) {
    return n == null ? void 0 : n[e];
  };
}
function Mt(e) {
  return function(n) {
    return Ce(n, e);
  };
}
function xt(e) {
  return W(e) ? Ft(U(e)) : Mt(e);
}
function Ye(e) {
  return typeof e == "function" ? e : e == null ? we : typeof e == "object" ? y(e) ? Nt(e[0], e[1]) : Pt(e) : xt(e);
}
function Dt(e, n) {
  return e && fn(e, n, T);
}
function Rt(e, n) {
  return function(r, t) {
    if (r == null)
      return r;
    if (!Te(r))
      return e(r, t);
    for (var i = r.length, s = n ? i : -1, a = Object(r); (n ? s-- : ++s < i) && t(a[s], s, a) !== !1; )
      ;
    return r;
  };
}
var Gt = Rt(Dt);
const ee = Gt;
function Ut(e, n, r) {
  for (var t = -1, i = e == null ? 0 : e.length; ++t < i; )
    if (r(n, e[t]))
      return !0;
  return !1;
}
function Bt(e) {
  return typeof e == "function" ? e : we;
}
function m(e, n) {
  var r = y(e) ? Le : ee;
  return r(e, Bt(n));
}
function jt(e, n) {
  var r = [];
  return ee(e, function(t, i, s) {
    n(t, i, s) && r.push(t);
  }), r;
}
function D(e, n) {
  var r = y(e) ? Ne : jt;
  return r(e, Ye(n));
}
var Kt = Object.prototype, Ht = Kt.hasOwnProperty;
function Yt(e, n) {
  return e != null && Ht.call(e, n);
}
function E(e, n) {
  return e != null && He(e, n, Yt);
}
function Zt(e, n) {
  return ve(n, function(r) {
    return e[r];
  });
}
function H(e) {
  return e == null ? [] : Zt(e, T(e));
}
function v(e) {
  return e === void 0;
}
function qt(e, n, r, t, i) {
  return i(e, function(s, a, u) {
    r = t ? (t = !1, s) : n(r, s, a, u);
  }), r;
}
function Xt(e, n, r) {
  var t = y(e) ? Sn : qt, i = arguments.length < 3;
  return t(e, Ye(n), r, i, ee);
}
var Qt = 1 / 0, Wt = B && 1 / V(new B([, -0]))[1] == Qt ? function(e) {
  return new B(e);
} : gn;
const Jt = Wt;
var zt = 200;
function Vt(e, n, r) {
  var t = -1, i = yn, s = e.length, a = !0, u = [], f = u;
  if (r)
    a = !1, i = Ut;
  else if (s >= zt) {
    var g = n ? null : Jt(e);
    if (g)
      return V(g);
    a = !1, i = Ue, f = new S();
  } else
    f = n ? [] : u;
  e:
    for (; ++t < s; ) {
      var l = e[t], o = n ? n(l) : l;
      if (l = r || l !== 0 ? l : 0, a && o === o) {
        for (var d = f.length; d--; )
          if (f[d] === o)
            continue e;
        n && f.push(o), u.push(l);
      } else
        i(f, o, r) || (f !== u && f.push(o), u.push(l));
    }
  return u;
}
var kt = on(function(e) {
  return Vt(Se(e, 1, dn, !0));
});
const ei = kt;
var ni = "\0", w = "\0", be = "";
class Ze {
  constructor(n = {}) {
    this._isDirected = E(n, "directed") ? n.directed : !0, this._isMultigraph = E(n, "multigraph") ? n.multigraph : !1, this._isCompound = E(n, "compound") ? n.compound : !1, this._label = void 0, this._defaultNodeLabelFn = M(void 0), this._defaultEdgeLabelFn = M(void 0), this._nodes = {}, this._isCompound && (this._parent = {}, this._children = {}, this._children[w] = {}), this._in = {}, this._preds = {}, this._out = {}, this._sucs = {}, this._edgeObjs = {}, this._edgeLabels = {};
  }
  /* === Graph functions ========= */
  isDirected() {
    return this._isDirected;
  }
  isMultigraph() {
    return this._isMultigraph;
  }
  isCompound() {
    return this._isCompound;
  }
  setGraph(n) {
    return this._label = n, this;
  }
  graph() {
    return this._label;
  }
  /* === Node functions ========== */
  setDefaultNodeLabel(n) {
    return te(n) || (n = M(n)), this._defaultNodeLabelFn = n, this;
  }
  nodeCount() {
    return this._nodeCount;
  }
  nodes() {
    return T(this._nodes);
  }
  sources() {
    var n = this;
    return D(this.nodes(), function(r) {
      return ie(n._in[r]);
    });
  }
  sinks() {
    var n = this;
    return D(this.nodes(), function(r) {
      return ie(n._out[r]);
    });
  }
  setNodes(n, r) {
    var t = arguments, i = this;
    return m(n, function(s) {
      t.length > 1 ? i.setNode(s, r) : i.setNode(s);
    }), this;
  }
  setNode(n, r) {
    return E(this._nodes, n) ? (arguments.length > 1 && (this._nodes[n] = r), this) : (this._nodes[n] = arguments.length > 1 ? r : this._defaultNodeLabelFn(n), this._isCompound && (this._parent[n] = w, this._children[n] = {}, this._children[w][n] = !0), this._in[n] = {}, this._preds[n] = {}, this._out[n] = {}, this._sucs[n] = {}, ++this._nodeCount, this);
  }
  node(n) {
    return this._nodes[n];
  }
  hasNode(n) {
    return E(this._nodes, n);
  }
  removeNode(n) {
    var r = this;
    if (E(this._nodes, n)) {
      var t = function(i) {
        r.removeEdge(r._edgeObjs[i]);
      };
      delete this._nodes[n], this._isCompound && (this._removeFromParentsChildList(n), delete this._parent[n], m(this.children(n), function(i) {
        r.setParent(i);
      }), delete this._children[n]), m(T(this._in[n]), t), delete this._in[n], delete this._preds[n], m(T(this._out[n]), t), delete this._out[n], delete this._sucs[n], --this._nodeCount;
    }
    return this;
  }
  setParent(n, r) {
    if (!this._isCompound)
      throw new Error("Cannot set parent in a non-compound graph");
    if (v(r))
      r = w;
    else {
      r += "";
      for (var t = r; !v(t); t = this.parent(t))
        if (t === n)
          throw new Error("Setting " + r + " as parent of " + n + " would create a cycle");
      this.setNode(r);
    }
    return this.setNode(n), this._removeFromParentsChildList(n), this._parent[n] = r, this._children[r][n] = !0, this;
  }
  _removeFromParentsChildList(n) {
    delete this._children[this._parent[n]][n];
  }
  parent(n) {
    if (this._isCompound) {
      var r = this._parent[n];
      if (r !== w)
        return r;
    }
  }
  children(n) {
    if (v(n) && (n = w), this._isCompound) {
      var r = this._children[n];
      if (r)
        return T(r);
    } else {
      if (n === w)
        return this.nodes();
      if (this.hasNode(n))
        return [];
    }
  }
  predecessors(n) {
    var r = this._preds[n];
    if (r)
      return T(r);
  }
  successors(n) {
    var r = this._sucs[n];
    if (r)
      return T(r);
  }
  neighbors(n) {
    var r = this.predecessors(n);
    if (r)
      return ei(r, this.successors(n));
  }
  isLeaf(n) {
    var r;
    return this.isDirected() ? r = this.successors(n) : r = this.neighbors(n), r.length === 0;
  }
  filterNodes(n) {
    var r = new this.constructor({
      directed: this._isDirected,
      multigraph: this._isMultigraph,
      compound: this._isCompound
    });
    r.setGraph(this.graph());
    var t = this;
    m(this._nodes, function(a, u) {
      n(u) && r.setNode(u, a);
    }), m(this._edgeObjs, function(a) {
      r.hasNode(a.v) && r.hasNode(a.w) && r.setEdge(a, t.edge(a));
    });
    var i = {};
    function s(a) {
      var u = t.parent(a);
      return u === void 0 || r.hasNode(u) ? (i[a] = u, u) : u in i ? i[u] : s(u);
    }
    return this._isCompound && m(r.nodes(), function(a) {
      r.setParent(a, s(a));
    }), r;
  }
  /* === Edge functions ========== */
  setDefaultEdgeLabel(n) {
    return te(n) || (n = M(n)), this._defaultEdgeLabelFn = n, this;
  }
  edgeCount() {
    return this._edgeCount;
  }
  edges() {
    return H(this._edgeObjs);
  }
  setPath(n, r) {
    var t = this, i = arguments;
    return Xt(n, function(s, a) {
      return i.length > 1 ? t.setEdge(s, a, r) : t.setEdge(s, a), a;
    }), this;
  }
  /*
   * setEdge(v, w, [value, [name]])
   * setEdge({ v, w, [name] }, [value])
   */
  setEdge() {
    var n, r, t, i, s = !1, a = arguments[0];
    typeof a == "object" && a !== null && "v" in a ? (n = a.v, r = a.w, t = a.name, arguments.length === 2 && (i = arguments[1], s = !0)) : (n = a, r = arguments[1], t = arguments[3], arguments.length > 2 && (i = arguments[2], s = !0)), n = "" + n, r = "" + r, v(t) || (t = "" + t);
    var u = P(this._isDirected, n, r, t);
    if (E(this._edgeLabels, u))
      return s && (this._edgeLabels[u] = i), this;
    if (!v(t) && !this._isMultigraph)
      throw new Error("Cannot set a named edge when isMultigraph = false");
    this.setNode(n), this.setNode(r), this._edgeLabels[u] = s ? i : this._defaultEdgeLabelFn(n, r, t);
    var f = ri(this._isDirected, n, r, t);
    return n = f.v, r = f.w, Object.freeze(f), this._edgeObjs[u] = f, ye(this._preds[r], n), ye(this._sucs[n], r), this._in[r][u] = f, this._out[n][u] = f, this._edgeCount++, this;
  }
  edge(n, r, t) {
    var i = arguments.length === 1 ? Y(this._isDirected, arguments[0]) : P(this._isDirected, n, r, t);
    return this._edgeLabels[i];
  }
  hasEdge(n, r, t) {
    var i = arguments.length === 1 ? Y(this._isDirected, arguments[0]) : P(this._isDirected, n, r, t);
    return E(this._edgeLabels, i);
  }
  removeEdge(n, r, t) {
    var i = arguments.length === 1 ? Y(this._isDirected, arguments[0]) : P(this._isDirected, n, r, t), s = this._edgeObjs[i];
    return s && (n = s.v, r = s.w, delete this._edgeLabels[i], delete this._edgeObjs[i], Ae(this._preds[r], n), Ae(this._sucs[n], r), delete this._in[r][i], delete this._out[n][i], this._edgeCount--), this;
  }
  inEdges(n, r) {
    var t = this._in[n];
    if (t) {
      var i = H(t);
      return r ? D(i, function(s) {
        return s.v === r;
      }) : i;
    }
  }
  outEdges(n, r) {
    var t = this._out[n];
    if (t) {
      var i = H(t);
      return r ? D(i, function(s) {
        return s.w === r;
      }) : i;
    }
  }
  nodeEdges(n, r) {
    var t = this.inEdges(n, r);
    if (t)
      return t.concat(this.outEdges(n, r));
  }
}
Ze.prototype._nodeCount = 0;
Ze.prototype._edgeCount = 0;
function ye(e, n) {
  e[n] ? e[n]++ : e[n] = 1;
}
function Ae(e, n) {
  --e[n] || delete e[n];
}
function P(e, n, r, t) {
  var i = "" + n, s = "" + r;
  if (!e && i > s) {
    var a = i;
    i = s, s = a;
  }
  return i + be + s + be + (v(t) ? ni : t);
}
function ri(e, n, r, t) {
  var i = "" + n, s = "" + r;
  if (!e && i > s) {
    var a = i;
    i = s, s = a;
  }
  var u = { v: i, w: s };
  return t && (u.name = t), u;
}
function Y(e, n) {
  return P(e, n.v, n.w, n.name);
}
export {
  Ze as G,
  Q as a,
  Se as b,
  j as c,
  Ye as d,
  cn as e,
  m as f,
  ee as g,
  E as h,
  v as i,
  ve as j,
  T as k,
  Bt as l,
  Dt as m,
  Ie as n,
  Ce as o,
  It as p,
  Pn as q,
  D as r,
  Xt as s,
  U as t,
  H as v
};