You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

10885 lines
277 KiB

!(function () {
function n(n) {
return n && (n.ownerDocument || n.document || n).documentElement;
}
function t(n) {
return (
n &&
((n.ownerDocument && n.ownerDocument.defaultView) ||
(n.document && n) ||
n.defaultView)
);
}
function e(n, t) {
return t > n ? -1 : n > t ? 1 : n >= t ? 0 : NaN;
}
function r(n) {
return null === n ? NaN : +n;
}
function i(n) {
return !isNaN(n);
}
function u(n) {
return {
left: function (t, e, r, i) {
for (
arguments.length < 3 && (r = 0),
arguments.length < 4 && (i = t.length);
i > r;
) {
var u = (r + i) >>> 1;
n(t[u], e) < 0 ? (r = u + 1) : (i = u);
}
return r;
},
right: function (t, e, r, i) {
for (
arguments.length < 3 && (r = 0),
arguments.length < 4 && (i = t.length);
i > r;
) {
var u = (r + i) >>> 1;
n(t[u], e) > 0 ? (i = u) : (r = u + 1);
}
return r;
},
};
}
function o(n) {
return n.length;
}
function a(n) {
for (var t = 1; (n * t) % 1; ) t *= 10;
return t;
}
function l(n, t) {
for (var e in t)
Object.defineProperty(n.prototype, e, { value: t[e], enumerable: !1 });
}
function c() {
this._ = Object.create(null);
}
function f(n) {
return (n += "") === bo || n[0] === _o ? _o + n : n;
}
function s(n) {
return (n += "")[0] === _o ? n.slice(1) : n;
}
function h(n) {
return f(n) in this._;
}
function p(n) {
return (n = f(n)) in this._ && delete this._[n];
}
function g() {
var n = [];
for (var t in this._) n.push(s(t));
return n;
}
function v() {
var n = 0;
for (var t in this._) ++n;
return n;
}
function d() {
for (var n in this._) return !1;
return !0;
}
function y() {
this._ = Object.create(null);
}
function m(n) {
return n;
}
function M(n, t, e) {
return function () {
var r = e.apply(t, arguments);
return r === t ? n : r;
};
}
function x(n, t) {
if (t in n) return t;
t = t.charAt(0).toUpperCase() + t.slice(1);
for (var e = 0, r = wo.length; r > e; ++e) {
var i = wo[e] + t;
if (i in n) return i;
}
}
function b() {}
function _() {}
function w(n) {
function t() {
for (var t, r = e, i = -1, u = r.length; ++i < u; )
(t = r[i].on) && t.apply(this, arguments);
return n;
}
var e = [],
r = new c();
return (
(t.on = function (t, i) {
var u,
o = r.get(t);
return arguments.length < 2
? o && o.on
: (o &&
((o.on = null),
(e = e.slice(0, (u = e.indexOf(o))).concat(e.slice(u + 1))),
r.remove(t)),
i && e.push(r.set(t, { on: i })),
n);
}),
t
);
}
function S() {
ao.event.preventDefault();
}
function k() {
for (var n, t = ao.event; (n = t.sourceEvent); ) t = n;
return t;
}
function N(n) {
for (var t = new _(), e = 0, r = arguments.length; ++e < r; )
t[arguments[e]] = w(t);
return (
(t.of = function (e, r) {
return function (i) {
try {
var u = (i.sourceEvent = ao.event);
(i.target = n), (ao.event = i), t[i.type].apply(e, r);
} finally {
ao.event = u;
}
};
}),
t
);
}
function E(n) {
return ko(n, Co), n;
}
function A(n) {
return "function" == typeof n
? n
: function () {
return No(n, this);
};
}
function C(n) {
return "function" == typeof n
? n
: function () {
return Eo(n, this);
};
}
function z(n, t) {
function e() {
this.removeAttribute(n);
}
function r() {
this.removeAttributeNS(n.space, n.local);
}
function i() {
this.setAttribute(n, t);
}
function u() {
this.setAttributeNS(n.space, n.local, t);
}
function o() {
var e = t.apply(this, arguments);
null == e ? this.removeAttribute(n) : this.setAttribute(n, e);
}
function a() {
var e = t.apply(this, arguments);
null == e
? this.removeAttributeNS(n.space, n.local)
: this.setAttributeNS(n.space, n.local, e);
}
return (
(n = ao.ns.qualify(n)),
null == t
? n.local
? r
: e
: "function" == typeof t
? n.local
? a
: o
: n.local
? u
: i
);
}
function L(n) {
return n.trim().replace(/\s+/g, " ");
}
function q(n) {
return new RegExp("(?:^|\\s+)" + ao.requote(n) + "(?:\\s+|$)", "g");
}
function T(n) {
return (n + "").trim().split(/^|\s+/);
}
function R(n, t) {
function e() {
for (var e = -1; ++e < i; ) n[e](this, t);
}
function r() {
for (var e = -1, r = t.apply(this, arguments); ++e < i; ) n[e](this, r);
}
n = T(n).map(D);
var i = n.length;
return "function" == typeof t ? r : e;
}
function D(n) {
var t = q(n);
return function (e, r) {
if ((i = e.classList)) return r ? i.add(n) : i.remove(n);
var i = e.getAttribute("class") || "";
r
? ((t.lastIndex = 0),
t.test(i) || e.setAttribute("class", L(i + " " + n)))
: e.setAttribute("class", L(i.replace(t, " ")));
};
}
function P(n, t, e) {
function r() {
this.style.removeProperty(n);
}
function i() {
this.style.setProperty(n, t, e);
}
function u() {
var r = t.apply(this, arguments);
null == r
? this.style.removeProperty(n)
: this.style.setProperty(n, r, e);
}
return null == t ? r : "function" == typeof t ? u : i;
}
function U(n, t) {
function e() {
delete this[n];
}
function r() {
this[n] = t;
}
function i() {
var e = t.apply(this, arguments);
null == e ? delete this[n] : (this[n] = e);
}
return null == t ? e : "function" == typeof t ? i : r;
}
function j(n) {
function t() {
var t = this.ownerDocument,
e = this.namespaceURI;
return e === zo && t.documentElement.namespaceURI === zo
? t.createElement(n)
: t.createElementNS(e, n);
}
function e() {
return this.ownerDocument.createElementNS(n.space, n.local);
}
return "function" == typeof n ? n : (n = ao.ns.qualify(n)).local ? e : t;
}
function F() {
var n = this.parentNode;
n && n.removeChild(this);
}
function H(n) {
return { __data__: n };
}
function O(n) {
return function () {
return Ao(this, n);
};
}
function I(n) {
return (
arguments.length || (n = e),
function (t, e) {
return t && e ? n(t.__data__, e.__data__) : !t - !e;
}
);
}
function Y(n, t) {
for (var e = 0, r = n.length; r > e; e++)
for (var i, u = n[e], o = 0, a = u.length; a > o; o++)
(i = u[o]) && t(i, o, e);
return n;
}
function Z(n) {
return ko(n, qo), n;
}
function V(n) {
var t, e;
return function (r, i, u) {
var o,
a = n[u].update,
l = a.length;
for (
u != e && ((e = u), (t = 0)), i >= t && (t = i + 1);
!(o = a[t]) && ++t < l;
);
return o;
};
}
function X(n, t, e) {
function r() {
var t = this[o];
t && (this.removeEventListener(n, t, t.$), delete this[o]);
}
function i() {
var i = l(t, co(arguments));
r.call(this),
this.addEventListener(n, (this[o] = i), (i.$ = e)),
(i._ = t);
}
function u() {
var t,
e = new RegExp("^__on([^.]+)" + ao.requote(n) + "$");
for (var r in this)
if ((t = r.match(e))) {
var i = this[r];
this.removeEventListener(t[1], i, i.$), delete this[r];
}
}
var o = "__on" + n,
a = n.indexOf("."),
l = $;
a > 0 && (n = n.slice(0, a));
var c = To.get(n);
return c && ((n = c), (l = B)), a ? (t ? i : r) : t ? b : u;
}
function $(n, t) {
return function (e) {
var r = ao.event;
(ao.event = e), (t[0] = this.__data__);
try {
n.apply(this, t);
} finally {
ao.event = r;
}
};
}
function B(n, t) {
var e = $(n, t);
return function (n) {
var t = this,
r = n.relatedTarget;
(r && (r === t || 8 & r.compareDocumentPosition(t))) || e.call(t, n);
};
}
function W(e) {
var r = ".dragsuppress-" + ++Do,
i = "click" + r,
u = ao
.select(t(e))
.on("touchmove" + r, S)
.on("dragstart" + r, S)
.on("selectstart" + r, S);
if (
(null == Ro &&
(Ro = "onselectstart" in e ? !1 : x(e.style, "userSelect")),
Ro)
) {
var o = n(e).style,
a = o[Ro];
o[Ro] = "none";
}
return function (n) {
if ((u.on(r, null), Ro && (o[Ro] = a), n)) {
var t = function () {
u.on(i, null);
};
u.on(
i,
function () {
S(), t();
},
!0
),
setTimeout(t, 0);
}
};
}
function J(n, e) {
e.changedTouches && (e = e.changedTouches[0]);
var r = n.ownerSVGElement || n;
if (r.createSVGPoint) {
var i = r.createSVGPoint();
if (0 > Po) {
var u = t(n);
if (u.scrollX || u.scrollY) {
r = ao
.select("body")
.append("svg")
.style(
{
position: "absolute",
top: 0,
left: 0,
margin: 0,
padding: 0,
border: "none",
},
"important"
);
var o = r[0][0].getScreenCTM();
(Po = !(o.f || o.e)), r.remove();
}
}
return (
Po
? ((i.x = e.pageX), (i.y = e.pageY))
: ((i.x = e.clientX), (i.y = e.clientY)),
(i = i.matrixTransform(n.getScreenCTM().inverse())),
[i.x, i.y]
);
}
var a = n.getBoundingClientRect();
return [e.clientX - a.left - n.clientLeft, e.clientY - a.top - n.clientTop];
}
function G() {
return ao.event.changedTouches[0].identifier;
}
function K(n) {
return n > 0 ? 1 : 0 > n ? -1 : 0;
}
function Q(n, t, e) {
return (t[0] - n[0]) * (e[1] - n[1]) - (t[1] - n[1]) * (e[0] - n[0]);
}
function nn(n) {
return n > 1 ? 0 : -1 > n ? Fo : Math.acos(n);
}
function tn(n) {
return n > 1 ? Io : -1 > n ? -Io : Math.asin(n);
}
function en(n) {
return ((n = Math.exp(n)) - 1 / n) / 2;
}
function rn(n) {
return ((n = Math.exp(n)) + 1 / n) / 2;
}
function un(n) {
return ((n = Math.exp(2 * n)) - 1) / (n + 1);
}
function on(n) {
return (n = Math.sin(n / 2)) * n;
}
function an() {}
function ln(n, t, e) {
return this instanceof ln
? ((this.h = +n), (this.s = +t), void (this.l = +e))
: arguments.length < 2
? n instanceof ln
? new ln(n.h, n.s, n.l)
: _n("" + n, wn, ln)
: new ln(n, t, e);
}
function cn(n, t, e) {
function r(n) {
return (
n > 360 ? (n -= 360) : 0 > n && (n += 360),
60 > n
? u + ((o - u) * n) / 60
: 180 > n
? o
: 240 > n
? u + ((o - u) * (240 - n)) / 60
: u
);
}
function i(n) {
return Math.round(255 * r(n));
}
var u, o;
return (
(n = isNaN(n) ? 0 : (n %= 360) < 0 ? n + 360 : n),
(t = isNaN(t) ? 0 : 0 > t ? 0 : t > 1 ? 1 : t),
(e = 0 > e ? 0 : e > 1 ? 1 : e),
(o = 0.5 >= e ? e * (1 + t) : e + t - e * t),
(u = 2 * e - o),
new mn(i(n + 120), i(n), i(n - 120))
);
}
function fn(n, t, e) {
return this instanceof fn
? ((this.h = +n), (this.c = +t), void (this.l = +e))
: arguments.length < 2
? n instanceof fn
? new fn(n.h, n.c, n.l)
: n instanceof hn
? gn(n.l, n.a, n.b)
: gn((n = Sn((n = ao.rgb(n)).r, n.g, n.b)).l, n.a, n.b)
: new fn(n, t, e);
}
function sn(n, t, e) {
return (
isNaN(n) && (n = 0),
isNaN(t) && (t = 0),
new hn(e, Math.cos((n *= Yo)) * t, Math.sin(n) * t)
);
}
function hn(n, t, e) {
return this instanceof hn
? ((this.l = +n), (this.a = +t), void (this.b = +e))
: arguments.length < 2
? n instanceof hn
? new hn(n.l, n.a, n.b)
: n instanceof fn
? sn(n.h, n.c, n.l)
: Sn((n = mn(n)).r, n.g, n.b)
: new hn(n, t, e);
}
function pn(n, t, e) {
var r = (n + 16) / 116,
i = r + t / 500,
u = r - e / 200;
return (
(i = vn(i) * na),
(r = vn(r) * ta),
(u = vn(u) * ea),
new mn(
yn(3.2404542 * i - 1.5371385 * r - 0.4985314 * u),
yn(-0.969266 * i + 1.8760108 * r + 0.041556 * u),
yn(0.0556434 * i - 0.2040259 * r + 1.0572252 * u)
)
);
}
function gn(n, t, e) {
return n > 0
? new fn(Math.atan2(e, t) * Zo, Math.sqrt(t * t + e * e), n)
: new fn(NaN, NaN, n);
}
function vn(n) {
return n > 0.206893034 ? n * n * n : (n - 4 / 29) / 7.787037;
}
function dn(n) {
return n > 0.008856 ? Math.pow(n, 1 / 3) : 7.787037 * n + 4 / 29;
}
function yn(n) {
return Math.round(
255 * (0.00304 >= n ? 12.92 * n : 1.055 * Math.pow(n, 1 / 2.4) - 0.055)
);
}
function mn(n, t, e) {
return this instanceof mn
? ((this.r = ~~n), (this.g = ~~t), void (this.b = ~~e))
: arguments.length < 2
? n instanceof mn
? new mn(n.r, n.g, n.b)
: _n("" + n, mn, cn)
: new mn(n, t, e);
}
function Mn(n) {
return new mn(n >> 16, (n >> 8) & 255, 255 & n);
}
function xn(n) {
return Mn(n) + "";
}
function bn(n) {
return 16 > n
? "0" + Math.max(0, n).toString(16)
: Math.min(255, n).toString(16);
}
function _n(n, t, e) {
var r,
i,
u,
o = 0,
a = 0,
l = 0;
if ((r = /([a-z]+)\((.*)\)/.exec((n = n.toLowerCase()))))
switch (((i = r[2].split(",")), r[1])) {
case "hsl":
return e(
parseFloat(i[0]),
parseFloat(i[1]) / 100,
parseFloat(i[2]) / 100
);
case "rgb":
return t(Nn(i[0]), Nn(i[1]), Nn(i[2]));
}
return (u = ua.get(n))
? t(u.r, u.g, u.b)
: (null == n ||
"#" !== n.charAt(0) ||
isNaN((u = parseInt(n.slice(1), 16))) ||
(4 === n.length
? ((o = (3840 & u) >> 4),
(o = (o >> 4) | o),
(a = 240 & u),
(a = (a >> 4) | a),
(l = 15 & u),
(l = (l << 4) | l))
: 7 === n.length &&
((o = (16711680 & u) >> 16),
(a = (65280 & u) >> 8),
(l = 255 & u))),
t(o, a, l));
}
function wn(n, t, e) {
var r,
i,
u = Math.min((n /= 255), (t /= 255), (e /= 255)),
o = Math.max(n, t, e),
a = o - u,
l = (o + u) / 2;
return (
a
? ((i = 0.5 > l ? a / (o + u) : a / (2 - o - u)),
(r =
n == o
? (t - e) / a + (e > t ? 6 : 0)
: t == o
? (e - n) / a + 2
: (n - t) / a + 4),
(r *= 60))
: ((r = NaN), (i = l > 0 && 1 > l ? 0 : r)),
new ln(r, i, l)
);
}
function Sn(n, t, e) {
(n = kn(n)), (t = kn(t)), (e = kn(e));
var r = dn((0.4124564 * n + 0.3575761 * t + 0.1804375 * e) / na),
i = dn((0.2126729 * n + 0.7151522 * t + 0.072175 * e) / ta),
u = dn((0.0193339 * n + 0.119192 * t + 0.9503041 * e) / ea);
return hn(116 * i - 16, 500 * (r - i), 200 * (i - u));
}
function kn(n) {
return (n /= 255) <= 0.04045
? n / 12.92
: Math.pow((n + 0.055) / 1.055, 2.4);
}
function Nn(n) {
var t = parseFloat(n);
return "%" === n.charAt(n.length - 1) ? Math.round(2.55 * t) : t;
}
function En(n) {
return "function" == typeof n
? n
: function () {
return n;
};
}
function An(n) {
return function (t, e, r) {
return (
2 === arguments.length &&
"function" == typeof e &&
((r = e), (e = null)),
Cn(t, e, n, r)
);
};
}
function Cn(n, t, e, r) {
function i() {
var n,
t = l.status;
if ((!t && Ln(l)) || (t >= 200 && 300 > t) || 304 === t) {
try {
n = e.call(u, l);
} catch (r) {
return void o.error.call(u, r);
}
o.load.call(u, n);
} else o.error.call(u, l);
}
var u = {},
o = ao.dispatch("beforesend", "progress", "load", "error"),
a = {},
l = new XMLHttpRequest(),
c = null;
return (
!this.XDomainRequest ||
"withCredentials" in l ||
!/^(http(s)?:)?\/\//.test(n) ||
(l = new XDomainRequest()),
"onload" in l
? (l.onload = l.onerror = i)
: (l.onreadystatechange = function () {
l.readyState > 3 && i();
}),
(l.onprogress = function (n) {
var t = ao.event;
ao.event = n;
try {
o.progress.call(u, l);
} finally {
ao.event = t;
}
}),
(u.header = function (n, t) {
return (
(n = (n + "").toLowerCase()),
arguments.length < 2
? a[n]
: (null == t ? delete a[n] : (a[n] = t + ""), u)
);
}),
(u.mimeType = function (n) {
return arguments.length ? ((t = null == n ? null : n + ""), u) : t;
}),
(u.responseType = function (n) {
return arguments.length ? ((c = n), u) : c;
}),
(u.response = function (n) {
return (e = n), u;
}),
["get", "post"].forEach(function (n) {
u[n] = function () {
return u.send.apply(u, [n].concat(co(arguments)));
};
}),
(u.send = function (e, r, i) {
if (
(2 === arguments.length &&
"function" == typeof r &&
((i = r), (r = null)),
l.open(e, n, !0),
null == t || "accept" in a || (a.accept = t + ",*/*"),
l.setRequestHeader)
)
for (var f in a) l.setRequestHeader(f, a[f]);
return (
null != t && l.overrideMimeType && l.overrideMimeType(t),
null != c && (l.responseType = c),
null != i &&
u.on("error", i).on("load", function (n) {
i(null, n);
}),
o.beforesend.call(u, l),
l.send(null == r ? null : r),
u
);
}),
(u.abort = function () {
return l.abort(), u;
}),
ao.rebind(u, o, "on"),
null == r ? u : u.get(zn(r))
);
}
function zn(n) {
return 1 === n.length
? function (t, e) {
n(null == t ? e : null);
}
: n;
}
function Ln(n) {
var t = n.responseType;
return t && "text" !== t ? n.response : n.responseText;
}
function qn(n, t, e) {
var r = arguments.length;
2 > r && (t = 0), 3 > r && (e = Date.now());
var i = e + t,
u = { c: n, t: i, n: null };
return (
aa ? (aa.n = u) : (oa = u),
(aa = u),
la || ((ca = clearTimeout(ca)), (la = 1), fa(Tn)),
u
);
}
function Tn() {
var n = Rn(),
t = Dn() - n;
t > 24
? (isFinite(t) && (clearTimeout(ca), (ca = setTimeout(Tn, t))), (la = 0))
: ((la = 1), fa(Tn));
}
function Rn() {
for (var n = Date.now(), t = oa; t; )
n >= t.t && t.c(n - t.t) && (t.c = null), (t = t.n);
return n;
}
function Dn() {
for (var n, t = oa, e = 1 / 0; t; )
t.c
? (t.t < e && (e = t.t), (t = (n = t).n))
: (t = n ? (n.n = t.n) : (oa = t.n));
return (aa = n), e;
}
function Pn(n, t) {
return t - (n ? Math.ceil(Math.log(n) / Math.LN10) : 1);
}
function Un(n, t) {
var e = Math.pow(10, 3 * xo(8 - t));
return {
scale:
t > 8
? function (n) {
return n / e;
}
: function (n) {
return n * e;
},
symbol: n,
};
}
function jn(n) {
var t = n.decimal,
e = n.thousands,
r = n.grouping,
i = n.currency,
u =
r && e
? function (n, t) {
for (
var i = n.length, u = [], o = 0, a = r[0], l = 0;
i > 0 &&
a > 0 &&
(l + a + 1 > t && (a = Math.max(1, t - l)),
u.push(n.substring((i -= a), i + a)),
!((l += a + 1) > t));
)
a = r[(o = (o + 1) % r.length)];
return u.reverse().join(e);
}
: m;
return function (n) {
var e = ha.exec(n),
r = e[1] || " ",
o = e[2] || ">",
a = e[3] || "-",
l = e[4] || "",
c = e[5],
f = +e[6],
s = e[7],
h = e[8],
p = e[9],
g = 1,
v = "",
d = "",
y = !1,
m = !0;
switch (
(h && (h = +h.substring(1)),
(c || ("0" === r && "=" === o)) && ((c = r = "0"), (o = "=")),
p)
) {
case "n":
(s = !0), (p = "g");
break;
case "%":
(g = 100), (d = "%"), (p = "f");
break;
case "p":
(g = 100), (d = "%"), (p = "r");
break;
case "b":
case "o":
case "x":
case "X":
"#" === l && (v = "0" + p.toLowerCase());
case "c":
m = !1;
case "d":
(y = !0), (h = 0);
break;
case "s":
(g = -1), (p = "r");
}
"$" === l && ((v = i[0]), (d = i[1])),
"r" != p || h || (p = "g"),
null != h &&
("g" == p
? (h = Math.max(1, Math.min(21, h)))
: ("e" != p && "f" != p) || (h = Math.max(0, Math.min(20, h)))),
(p = pa.get(p) || Fn);
var M = c && s;
return function (n) {
var e = d;
if (y && n % 1) return "";
var i =
0 > n || (0 === n && 0 > 1 / n)
? ((n = -n), "-")
: "-" === a
? ""
: a;
if (0 > g) {
var l = ao.formatPrefix(n, h);
(n = l.scale(n)), (e = l.symbol + d);
} else n *= g;
n = p(n, h);
var x,
b,
_ = n.lastIndexOf(".");
if (0 > _) {
var w = m ? n.lastIndexOf("e") : -1;
0 > w
? ((x = n), (b = ""))
: ((x = n.substring(0, w)), (b = n.substring(w)));
} else (x = n.substring(0, _)), (b = t + n.substring(_ + 1));
!c && s && (x = u(x, 1 / 0));
var S = v.length + x.length + b.length + (M ? 0 : i.length),
k = f > S ? new Array((S = f - S + 1)).join(r) : "";
return (
M && (x = u(k + x, k.length ? f - b.length : 1 / 0)),
(i += v),
(n = x + b),
("<" === o
? i + n + k
: ">" === o
? k + i + n
: "^" === o
? k.substring(0, (S >>= 1)) + i + n + k.substring(S)
: i + (M ? n : k + n)) + e
);
};
};
}
function Fn(n) {
return n + "";
}
function Hn() {
this._ = new Date(
arguments.length > 1 ? Date.UTC.apply(this, arguments) : arguments[0]
);
}
function On(n, t, e) {
function r(t) {
var e = n(t),
r = u(e, 1);
return r - t > t - e ? e : r;
}
function i(e) {
return t((e = n(new va(e - 1))), 1), e;
}
function u(n, e) {
return t((n = new va(+n)), e), n;
}
function o(n, r, u) {
var o = i(n),
a = [];
if (u > 1) for (; r > o; ) e(o) % u || a.push(new Date(+o)), t(o, 1);
else for (; r > o; ) a.push(new Date(+o)), t(o, 1);
return a;
}
function a(n, t, e) {
try {
va = Hn;
var r = new Hn();
return (r._ = n), o(r, t, e);
} finally {
va = Date;
}
}
(n.floor = n), (n.round = r), (n.ceil = i), (n.offset = u), (n.range = o);
var l = (n.utc = In(n));
return (
(l.floor = l),
(l.round = In(r)),
(l.ceil = In(i)),
(l.offset = In(u)),
(l.range = a),
n
);
}
function In(n) {
return function (t, e) {
try {
va = Hn;
var r = new Hn();
return (r._ = t), n(r, e)._;
} finally {
va = Date;
}
};
}
function Yn(n) {
function t(n) {
function t(t) {
for (var e, i, u, o = [], a = -1, l = 0; ++a < r; )
37 === n.charCodeAt(a) &&
(o.push(n.slice(l, a)),
null != (i = ya[(e = n.charAt(++a))]) && (e = n.charAt(++a)),
(u = A[e]) && (e = u(t, null == i ? ("e" === e ? " " : "0") : i)),
o.push(e),
(l = a + 1));
return o.push(n.slice(l, a)), o.join("");
}
var r = n.length;
return (
(t.parse = function (t) {
var r = { y: 1900, m: 0, d: 1, H: 0, M: 0, S: 0, L: 0, Z: null },
i = e(r, n, t, 0);
if (i != t.length) return null;
"p" in r && (r.H = (r.H % 12) + 12 * r.p);
var u = null != r.Z && va !== Hn,
o = new (u ? Hn : va)();
return (
"j" in r
? o.setFullYear(r.y, 0, r.j)
: "W" in r || "U" in r
? ("w" in r || (r.w = "W" in r ? 1 : 0),
o.setFullYear(r.y, 0, 1),
o.setFullYear(
r.y,
0,
"W" in r
? ((r.w + 6) % 7) + 7 * r.W - ((o.getDay() + 5) % 7)
: r.w + 7 * r.U - ((o.getDay() + 6) % 7)
))
: o.setFullYear(r.y, r.m, r.d),
o.setHours(r.H + ((r.Z / 100) | 0), r.M + (r.Z % 100), r.S, r.L),
u ? o._ : o
);
}),
(t.toString = function () {
return n;
}),
t
);
}
function e(n, t, e, r) {
for (var i, u, o, a = 0, l = t.length, c = e.length; l > a; ) {
if (r >= c) return -1;
if (((i = t.charCodeAt(a++)), 37 === i)) {
if (
((o = t.charAt(a++)),
(u = C[o in ya ? t.charAt(a++) : o]),
!u || (r = u(n, e, r)) < 0)
)
return -1;
} else if (i != e.charCodeAt(r++)) return -1;
}
return r;
}
function r(n, t, e) {
_.lastIndex = 0;
var r = _.exec(t.slice(e));
return r ? ((n.w = w.get(r[0].toLowerCase())), e + r[0].length) : -1;
}
function i(n, t, e) {
x.lastIndex = 0;
var r = x.exec(t.slice(e));
return r ? ((n.w = b.get(r[0].toLowerCase())), e + r[0].length) : -1;
}
function u(n, t, e) {
N.lastIndex = 0;
var r = N.exec(t.slice(e));
return r ? ((n.m = E.get(r[0].toLowerCase())), e + r[0].length) : -1;
}
function o(n, t, e) {
S.lastIndex = 0;
var r = S.exec(t.slice(e));
return r ? ((n.m = k.get(r[0].toLowerCase())), e + r[0].length) : -1;
}
function a(n, t, r) {
return e(n, A.c.toString(), t, r);
}
function l(n, t, r) {
return e(n, A.x.toString(), t, r);
}
function c(n, t, r) {
return e(n, A.X.toString(), t, r);
}
function f(n, t, e) {
var r = M.get(t.slice(e, (e += 2)).toLowerCase());
return null == r ? -1 : ((n.p = r), e);
}
var s = n.dateTime,
h = n.date,
p = n.time,
g = n.periods,
v = n.days,
d = n.shortDays,
y = n.months,
m = n.shortMonths;
(t.utc = function (n) {
function e(n) {
try {
va = Hn;
var t = new va();
return (t._ = n), r(t);
} finally {
va = Date;
}
}
var r = t(n);
return (
(e.parse = function (n) {
try {
va = Hn;
var t = r.parse(n);
return t && t._;
} finally {
va = Date;
}
}),
(e.toString = r.toString),
e
);
}),
(t.multi = t.utc.multi = ct);
var M = ao.map(),
x = Vn(v),
b = Xn(v),
_ = Vn(d),
w = Xn(d),
S = Vn(y),
k = Xn(y),
N = Vn(m),
E = Xn(m);
g.forEach(function (n, t) {
M.set(n.toLowerCase(), t);
});
var A = {
a: function (n) {
return d[n.getDay()];
},
A: function (n) {
return v[n.getDay()];
},
b: function (n) {
return m[n.getMonth()];
},
B: function (n) {
return y[n.getMonth()];
},
c: t(s),
d: function (n, t) {
return Zn(n.getDate(), t, 2);
},
e: function (n, t) {
return Zn(n.getDate(), t, 2);
},
H: function (n, t) {
return Zn(n.getHours(), t, 2);
},
I: function (n, t) {
return Zn(n.getHours() % 12 || 12, t, 2);
},
j: function (n, t) {
return Zn(1 + ga.dayOfYear(n), t, 3);
},
L: function (n, t) {
return Zn(n.getMilliseconds(), t, 3);
},
m: function (n, t) {
return Zn(n.getMonth() + 1, t, 2);
},
M: function (n, t) {
return Zn(n.getMinutes(), t, 2);
},
p: function (n) {
return g[+(n.getHours() >= 12)];
},
S: function (n, t) {
return Zn(n.getSeconds(), t, 2);
},
U: function (n, t) {
return Zn(ga.sundayOfYear(n), t, 2);
},
w: function (n) {
return n.getDay();
},
W: function (n, t) {
return Zn(ga.mondayOfYear(n), t, 2);
},
x: t(h),
X: t(p),
y: function (n, t) {
return Zn(n.getFullYear() % 100, t, 2);
},
Y: function (n, t) {
return Zn(n.getFullYear() % 1e4, t, 4);
},
Z: at,
"%": function () {
return "%";
},
},
C = {
a: r,
A: i,
b: u,
B: o,
c: a,
d: tt,
e: tt,
H: rt,
I: rt,
j: et,
L: ot,
m: nt,
M: it,
p: f,
S: ut,
U: Bn,
w: $n,
W: Wn,
x: l,
X: c,
y: Gn,
Y: Jn,
Z: Kn,
"%": lt,
};
return t;
}
function Zn(n, t, e) {
var r = 0 > n ? "-" : "",
i = (r ? -n : n) + "",
u = i.length;
return r + (e > u ? new Array(e - u + 1).join(t) + i : i);
}
function Vn(n) {
return new RegExp("^(?:" + n.map(ao.requote).join("|") + ")", "i");
}
function Xn(n) {
for (var t = new c(), e = -1, r = n.length; ++e < r; )
t.set(n[e].toLowerCase(), e);
return t;
}
function $n(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e, e + 1));
return r ? ((n.w = +r[0]), e + r[0].length) : -1;
}
function Bn(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e));
return r ? ((n.U = +r[0]), e + r[0].length) : -1;
}
function Wn(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e));
return r ? ((n.W = +r[0]), e + r[0].length) : -1;
}
function Jn(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e, e + 4));
return r ? ((n.y = +r[0]), e + r[0].length) : -1;
}
function Gn(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e, e + 2));
return r ? ((n.y = Qn(+r[0])), e + r[0].length) : -1;
}
function Kn(n, t, e) {
return /^[+-]\d{4}$/.test((t = t.slice(e, e + 5)))
? ((n.Z = -t), e + 5)
: -1;
}
function Qn(n) {
return n + (n > 68 ? 1900 : 2e3);
}
function nt(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e, e + 2));
return r ? ((n.m = r[0] - 1), e + r[0].length) : -1;
}
function tt(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e, e + 2));
return r ? ((n.d = +r[0]), e + r[0].length) : -1;
}
function et(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e, e + 3));
return r ? ((n.j = +r[0]), e + r[0].length) : -1;
}
function rt(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e, e + 2));
return r ? ((n.H = +r[0]), e + r[0].length) : -1;
}
function it(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e, e + 2));
return r ? ((n.M = +r[0]), e + r[0].length) : -1;
}
function ut(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e, e + 2));
return r ? ((n.S = +r[0]), e + r[0].length) : -1;
}
function ot(n, t, e) {
ma.lastIndex = 0;
var r = ma.exec(t.slice(e, e + 3));
return r ? ((n.L = +r[0]), e + r[0].length) : -1;
}
function at(n) {
var t = n.getTimezoneOffset(),
e = t > 0 ? "-" : "+",
r = (xo(t) / 60) | 0,
i = xo(t) % 60;
return e + Zn(r, "0", 2) + Zn(i, "0", 2);
}
function lt(n, t, e) {
Ma.lastIndex = 0;
var r = Ma.exec(t.slice(e, e + 1));
return r ? e + r[0].length : -1;
}
function ct(n) {
for (var t = n.length, e = -1; ++e < t; ) n[e][0] = this(n[e][0]);
return function (t) {
for (var e = 0, r = n[e]; !r[1](t); ) r = n[++e];
return r[0](t);
};
}
function ft() {}
function st(n, t, e) {
var r = (e.s = n + t),
i = r - n,
u = r - i;
e.t = n - u + (t - i);
}
function ht(n, t) {
n && wa.hasOwnProperty(n.type) && wa[n.type](n, t);
}
function pt(n, t, e) {
var r,
i = -1,
u = n.length - e;
for (t.lineStart(); ++i < u; ) (r = n[i]), t.point(r[0], r[1], r[2]);
t.lineEnd();
}
function gt(n, t) {
var e = -1,
r = n.length;
for (t.polygonStart(); ++e < r; ) pt(n[e], t, 1);
t.polygonEnd();
}
function vt() {
function n(n, t) {
(n *= Yo), (t = (t * Yo) / 2 + Fo / 4);
var e = n - r,
o = e >= 0 ? 1 : -1,
a = o * e,
l = Math.cos(t),
c = Math.sin(t),
f = u * c,
s = i * l + f * Math.cos(a),
h = f * o * Math.sin(a);
ka.add(Math.atan2(h, s)), (r = n), (i = l), (u = c);
}
var t, e, r, i, u;
(Na.point = function (o, a) {
(Na.point = n),
(r = (t = o) * Yo),
(i = Math.cos((a = ((e = a) * Yo) / 2 + Fo / 4))),
(u = Math.sin(a));
}),
(Na.lineEnd = function () {
n(t, e);
});
}
function dt(n) {
var t = n[0],
e = n[1],
r = Math.cos(e);
return [r * Math.cos(t), r * Math.sin(t), Math.sin(e)];
}
function yt(n, t) {
return n[0] * t[0] + n[1] * t[1] + n[2] * t[2];
}
function mt(n, t) {
return [
n[1] * t[2] - n[2] * t[1],
n[2] * t[0] - n[0] * t[2],
n[0] * t[1] - n[1] * t[0],
];
}
function Mt(n, t) {
(n[0] += t[0]), (n[1] += t[1]), (n[2] += t[2]);
}
function xt(n, t) {
return [n[0] * t, n[1] * t, n[2] * t];
}
function bt(n) {
var t = Math.sqrt(n[0] * n[0] + n[1] * n[1] + n[2] * n[2]);
(n[0] /= t), (n[1] /= t), (n[2] /= t);
}
function _t(n) {
return [Math.atan2(n[1], n[0]), tn(n[2])];
}
function wt(n, t) {
return xo(n[0] - t[0]) < Uo && xo(n[1] - t[1]) < Uo;
}
function St(n, t) {
n *= Yo;
var e = Math.cos((t *= Yo));
kt(e * Math.cos(n), e * Math.sin(n), Math.sin(t));
}
function kt(n, t, e) {
++Ea, (Ca += (n - Ca) / Ea), (za += (t - za) / Ea), (La += (e - La) / Ea);
}
function Nt() {
function n(n, i) {
n *= Yo;
var u = Math.cos((i *= Yo)),
o = u * Math.cos(n),
a = u * Math.sin(n),
l = Math.sin(i),
c = Math.atan2(
Math.sqrt(
(c = e * l - r * a) * c +
(c = r * o - t * l) * c +
(c = t * a - e * o) * c
),
t * o + e * a + r * l
);
(Aa += c),
(qa += c * (t + (t = o))),
(Ta += c * (e + (e = a))),
(Ra += c * (r + (r = l))),
kt(t, e, r);
}
var t, e, r;
ja.point = function (i, u) {
i *= Yo;
var o = Math.cos((u *= Yo));
(t = o * Math.cos(i)),
(e = o * Math.sin(i)),
(r = Math.sin(u)),
(ja.point = n),
kt(t, e, r);
};
}
function Et() {
ja.point = St;
}
function At() {
function n(n, t) {
n *= Yo;
var e = Math.cos((t *= Yo)),
o = e * Math.cos(n),
a = e * Math.sin(n),
l = Math.sin(t),
c = i * l - u * a,
f = u * o - r * l,
s = r * a - i * o,
h = Math.sqrt(c * c + f * f + s * s),
p = r * o + i * a + u * l,
g = h && -nn(p) / h,
v = Math.atan2(h, p);
(Da += g * c),
(Pa += g * f),
(Ua += g * s),
(Aa += v),
(qa += v * (r + (r = o))),
(Ta += v * (i + (i = a))),
(Ra += v * (u + (u = l))),
kt(r, i, u);
}
var t, e, r, i, u;
(ja.point = function (o, a) {
(t = o), (e = a), (ja.point = n), (o *= Yo);
var l = Math.cos((a *= Yo));
(r = l * Math.cos(o)),
(i = l * Math.sin(o)),
(u = Math.sin(a)),
kt(r, i, u);
}),
(ja.lineEnd = function () {
n(t, e), (ja.lineEnd = Et), (ja.point = St);
});
}
function Ct(n, t) {
function e(e, r) {
return (e = n(e, r)), t(e[0], e[1]);
}
return (
n.invert &&
t.invert &&
(e.invert = function (e, r) {
return (e = t.invert(e, r)), e && n.invert(e[0], e[1]);
}),
e
);
}
function zt() {
return !0;
}
function Lt(n, t, e, r, i) {
var u = [],
o = [];
if (
(n.forEach(function (n) {
if (!((t = n.length - 1) <= 0)) {
var t,
e = n[0],
r = n[t];
if (wt(e, r)) {
i.lineStart();
for (var a = 0; t > a; ++a) i.point((e = n[a])[0], e[1]);
return void i.lineEnd();
}
var l = new Tt(e, n, null, !0),
c = new Tt(e, null, l, !1);
(l.o = c),
u.push(l),
o.push(c),
(l = new Tt(r, n, null, !1)),
(c = new Tt(r, null, l, !0)),
(l.o = c),
u.push(l),
o.push(c);
}
}),
o.sort(t),
qt(u),
qt(o),
u.length)
) {
for (var a = 0, l = e, c = o.length; c > a; ++a) o[a].e = l = !l;
for (var f, s, h = u[0]; ; ) {
for (var p = h, g = !0; p.v; ) if ((p = p.n) === h) return;
(f = p.z), i.lineStart();
do {
if (((p.v = p.o.v = !0), p.e)) {
if (g)
for (var a = 0, c = f.length; c > a; ++a)
i.point((s = f[a])[0], s[1]);
else r(p.x, p.n.x, 1, i);
p = p.n;
} else {
if (g) {
f = p.p.z;
for (var a = f.length - 1; a >= 0; --a)
i.point((s = f[a])[0], s[1]);
} else r(p.x, p.p.x, -1, i);
p = p.p;
}
(p = p.o), (f = p.z), (g = !g);
} while (!p.v);
i.lineEnd();
}
}
}
function qt(n) {
if ((t = n.length)) {
for (var t, e, r = 0, i = n[0]; ++r < t; )
(i.n = e = n[r]), (e.p = i), (i = e);
(i.n = e = n[0]), (e.p = i);
}
}
function Tt(n, t, e, r) {
(this.x = n),
(this.z = t),
(this.o = e),
(this.e = r),
(this.v = !1),
(this.n = this.p = null);
}
function Rt(n, t, e, r) {
return function (i, u) {
function o(t, e) {
var r = i(t, e);
n((t = r[0]), (e = r[1])) && u.point(t, e);
}
function a(n, t) {
var e = i(n, t);
d.point(e[0], e[1]);
}
function l() {
(m.point = a), d.lineStart();
}
function c() {
(m.point = o), d.lineEnd();
}
function f(n, t) {
v.push([n, t]);
var e = i(n, t);
x.point(e[0], e[1]);
}
function s() {
x.lineStart(), (v = []);
}
function h() {
f(v[0][0], v[0][1]), x.lineEnd();
var n,
t = x.clean(),
e = M.buffer(),
r = e.length;
if ((v.pop(), g.push(v), (v = null), r))
if (1 & t) {
n = e[0];
var i,
r = n.length - 1,
o = -1;
if (r > 0) {
for (b || (u.polygonStart(), (b = !0)), u.lineStart(); ++o < r; )
u.point((i = n[o])[0], i[1]);
u.lineEnd();
}
} else
r > 1 && 2 & t && e.push(e.pop().concat(e.shift())),
p.push(e.filter(Dt));
}
var p,
g,
v,
d = t(u),
y = i.invert(r[0], r[1]),
m = {
point: o,
lineStart: l,
lineEnd: c,
polygonStart: function () {
(m.point = f),
(m.lineStart = s),
(m.lineEnd = h),
(p = []),
(g = []);
},
polygonEnd: function () {
(m.point = o),
(m.lineStart = l),
(m.lineEnd = c),
(p = ao.merge(p));
var n = Ot(y, g);
p.length
? (b || (u.polygonStart(), (b = !0)), Lt(p, Ut, n, e, u))
: n &&
(b || (u.polygonStart(), (b = !0)),
u.lineStart(),
e(null, null, 1, u),
u.lineEnd()),
b && (u.polygonEnd(), (b = !1)),
(p = g = null);
},
sphere: function () {
u.polygonStart(),
u.lineStart(),
e(null, null, 1, u),
u.lineEnd(),
u.polygonEnd();
},
},
M = Pt(),
x = t(M),
b = !1;
return m;
};
}
function Dt(n) {
return n.length > 1;
}
function Pt() {
var n,
t = [];
return {
lineStart: function () {
t.push((n = []));
},
point: function (t, e) {
n.push([t, e]);
},
lineEnd: b,
buffer: function () {
var e = t;
return (t = []), (n = null), e;
},
rejoin: function () {
t.length > 1 && t.push(t.pop().concat(t.shift()));
},
};
}
function Ut(n, t) {
return (
((n = n.x)[0] < 0 ? n[1] - Io - Uo : Io - n[1]) -
((t = t.x)[0] < 0 ? t[1] - Io - Uo : Io - t[1])
);
}
function jt(n) {
var t,
e = NaN,
r = NaN,
i = NaN;
return {
lineStart: function () {
n.lineStart(), (t = 1);
},
point: function (u, o) {
var a = u > 0 ? Fo : -Fo,
l = xo(u - e);
xo(l - Fo) < Uo
? (n.point(e, (r = (r + o) / 2 > 0 ? Io : -Io)),
n.point(i, r),
n.lineEnd(),
n.lineStart(),
n.point(a, r),
n.point(u, r),
(t = 0))
: i !== a &&
l >= Fo &&
(xo(e - i) < Uo && (e -= i * Uo),
xo(u - a) < Uo && (u -= a * Uo),
(r = Ft(e, r, u, o)),
n.point(i, r),
n.lineEnd(),
n.lineStart(),
n.point(a, r),
(t = 0)),
n.point((e = u), (r = o)),
(i = a);
},
lineEnd: function () {
n.lineEnd(), (e = r = NaN);
},
clean: function () {
return 2 - t;
},
};
}
function Ft(n, t, e, r) {
var i,
u,
o = Math.sin(n - e);
return xo(o) > Uo
? Math.atan(
(Math.sin(t) * (u = Math.cos(r)) * Math.sin(e) -
Math.sin(r) * (i = Math.cos(t)) * Math.sin(n)) /
(i * u * o)
)
: (t + r) / 2;
}
function Ht(n, t, e, r) {
var i;
if (null == n)
(i = e * Io),
r.point(-Fo, i),
r.point(0, i),
r.point(Fo, i),
r.point(Fo, 0),
r.point(Fo, -i),
r.point(0, -i),
r.point(-Fo, -i),
r.point(-Fo, 0),
r.point(-Fo, i);
else if (xo(n[0] - t[0]) > Uo) {
var u = n[0] < t[0] ? Fo : -Fo;
(i = (e * u) / 2), r.point(-u, i), r.point(0, i), r.point(u, i);
} else r.point(t[0], t[1]);
}
function Ot(n, t) {
var e = n[0],
r = n[1],
i = [Math.sin(e), -Math.cos(e), 0],
u = 0,
o = 0;
ka.reset();
for (var a = 0, l = t.length; l > a; ++a) {
var c = t[a],
f = c.length;
if (f)
for (
var s = c[0],
h = s[0],
p = s[1] / 2 + Fo / 4,
g = Math.sin(p),
v = Math.cos(p),
d = 1;
;
) {
d === f && (d = 0), (n = c[d]);
var y = n[0],
m = n[1] / 2 + Fo / 4,
M = Math.sin(m),
x = Math.cos(m),
b = y - h,
_ = b >= 0 ? 1 : -1,
w = _ * b,
S = w > Fo,
k = g * M;
if (
(ka.add(Math.atan2(k * _ * Math.sin(w), v * x + k * Math.cos(w))),
(u += S ? b + _ * Ho : b),
S ^ (h >= e) ^ (y >= e))
) {
var N = mt(dt(s), dt(n));
bt(N);
var E = mt(i, N);
bt(E);
var A = (S ^ (b >= 0) ? -1 : 1) * tn(E[2]);
(r > A || (r === A && (N[0] || N[1]))) &&
(o += S ^ (b >= 0) ? 1 : -1);
}
if (!d++) break;
(h = y), (g = M), (v = x), (s = n);
}
}
return (-Uo > u || (Uo > u && -Uo > ka)) ^ (1 & o);
}
function It(n) {
function t(n, t) {
return Math.cos(n) * Math.cos(t) > u;
}
function e(n) {
var e, u, l, c, f;
return {
lineStart: function () {
(c = l = !1), (f = 1);
},
point: function (s, h) {
var p,
g = [s, h],
v = t(s, h),
d = o ? (v ? 0 : i(s, h)) : v ? i(s + (0 > s ? Fo : -Fo), h) : 0;
if (
(!e && (c = l = v) && n.lineStart(),
v !== l &&
((p = r(e, g)),
(wt(e, p) || wt(g, p)) &&
((g[0] += Uo), (g[1] += Uo), (v = t(g[0], g[1])))),
v !== l)
)
(f = 0),
v
? (n.lineStart(), (p = r(g, e)), n.point(p[0], p[1]))
: ((p = r(e, g)), n.point(p[0], p[1]), n.lineEnd()),
(e = p);
else if (a && e && o ^ v) {
var y;
d & u ||
!(y = r(g, e, !0)) ||
((f = 0),
o
? (n.lineStart(),
n.point(y[0][0], y[0][1]),
n.point(y[1][0], y[1][1]),
n.lineEnd())
: (n.point(y[1][0], y[1][1]),
n.lineEnd(),
n.lineStart(),
n.point(y[0][0], y[0][1])));
}
!v || (e && wt(e, g)) || n.point(g[0], g[1]),
(e = g),
(l = v),
(u = d);
},
lineEnd: function () {
l && n.lineEnd(), (e = null);
},
clean: function () {
return f | ((c && l) << 1);
},
};
}
function r(n, t, e) {
var r = dt(n),
i = dt(t),
o = [1, 0, 0],
a = mt(r, i),
l = yt(a, a),
c = a[0],
f = l - c * c;
if (!f) return !e && n;
var s = (u * l) / f,
h = (-u * c) / f,
p = mt(o, a),
g = xt(o, s),
v = xt(a, h);
Mt(g, v);
var d = p,
y = yt(g, d),
m = yt(d, d),
M = y * y - m * (yt(g, g) - 1);
if (!(0 > M)) {
var x = Math.sqrt(M),
b = xt(d, (-y - x) / m);
if ((Mt(b, g), (b = _t(b)), !e)) return b;
var _,
w = n[0],
S = t[0],
k = n[1],
N = t[1];
w > S && ((_ = w), (w = S), (S = _));
var E = S - w,
A = xo(E - Fo) < Uo,
C = A || Uo > E;
if (
(!A && k > N && ((_ = k), (k = N), (N = _)),
C
? A
? (k + N > 0) ^ (b[1] < (xo(b[0] - w) < Uo ? k : N))
: k <= b[1] && b[1] <= N
: (E > Fo) ^ (w <= b[0] && b[0] <= S))
) {
var z = xt(d, (-y + x) / m);
return Mt(z, g), [b, _t(z)];
}
}
}
function i(t, e) {
var r = o ? n : Fo - n,
i = 0;
return (
-r > t ? (i |= 1) : t > r && (i |= 2),
-r > e ? (i |= 4) : e > r && (i |= 8),
i
);
}
var u = Math.cos(n),
o = u > 0,
a = xo(u) > Uo,
l = ve(n, 6 * Yo);
return Rt(t, e, l, o ? [0, -n] : [-Fo, n - Fo]);
}
function Yt(n, t, e, r) {
return function (i) {
var u,
o = i.a,
a = i.b,
l = o.x,
c = o.y,
f = a.x,
s = a.y,
h = 0,
p = 1,
g = f - l,
v = s - c;
if (((u = n - l), g || !(u > 0))) {
if (((u /= g), 0 > g)) {
if (h > u) return;
p > u && (p = u);
} else if (g > 0) {
if (u > p) return;
u > h && (h = u);
}
if (((u = e - l), g || !(0 > u))) {
if (((u /= g), 0 > g)) {
if (u > p) return;
u > h && (h = u);
} else if (g > 0) {
if (h > u) return;
p > u && (p = u);
}
if (((u = t - c), v || !(u > 0))) {
if (((u /= v), 0 > v)) {
if (h > u) return;
p > u && (p = u);
} else if (v > 0) {
if (u > p) return;
u > h && (h = u);
}
if (((u = r - c), v || !(0 > u))) {
if (((u /= v), 0 > v)) {
if (u > p) return;
u > h && (h = u);
} else if (v > 0) {
if (h > u) return;
p > u && (p = u);
}
return (
h > 0 && (i.a = { x: l + h * g, y: c + h * v }),
1 > p && (i.b = { x: l + p * g, y: c + p * v }),
i
);
}
}
}
}
};
}
function Zt(n, t, e, r) {
function i(r, i) {
return xo(r[0] - n) < Uo
? i > 0
? 0
: 3
: xo(r[0] - e) < Uo
? i > 0
? 2
: 1
: xo(r[1] - t) < Uo
? i > 0
? 1
: 0
: i > 0
? 3
: 2;
}
function u(n, t) {
return o(n.x, t.x);
}
function o(n, t) {
var e = i(n, 1),
r = i(t, 1);
return e !== r
? e - r
: 0 === e
? t[1] - n[1]
: 1 === e
? n[0] - t[0]
: 2 === e
? n[1] - t[1]
: t[0] - n[0];
}
return function (a) {
function l(n) {
for (var t = 0, e = d.length, r = n[1], i = 0; e > i; ++i)
for (var u, o = 1, a = d[i], l = a.length, c = a[0]; l > o; ++o)
(u = a[o]),
c[1] <= r
? u[1] > r && Q(c, u, n) > 0 && ++t
: u[1] <= r && Q(c, u, n) < 0 && --t,
(c = u);
return 0 !== t;
}
function c(u, a, l, c) {
var f = 0,
s = 0;
if (
null == u ||
(f = i(u, l)) !== (s = i(a, l)) ||
(o(u, a) < 0) ^ (l > 0)
) {
do c.point(0 === f || 3 === f ? n : e, f > 1 ? r : t);
while ((f = (f + l + 4) % 4) !== s);
} else c.point(a[0], a[1]);
}
function f(i, u) {
return i >= n && e >= i && u >= t && r >= u;
}
function s(n, t) {
f(n, t) && a.point(n, t);
}
function h() {
(C.point = g), d && d.push((y = [])), (S = !0), (w = !1), (b = _ = NaN);
}
function p() {
v && (g(m, M), x && w && E.rejoin(), v.push(E.buffer())),
(C.point = s),
w && a.lineEnd();
}
function g(n, t) {
(n = Math.max(-Ha, Math.min(Ha, n))),
(t = Math.max(-Ha, Math.min(Ha, t)));
var e = f(n, t);
if ((d && y.push([n, t]), S))
(m = n),
(M = t),
(x = e),
(S = !1),
e && (a.lineStart(), a.point(n, t));
else if (e && w) a.point(n, t);
else {
var r = { a: { x: b, y: _ }, b: { x: n, y: t } };
A(r)
? (w || (a.lineStart(), a.point(r.a.x, r.a.y)),
a.point(r.b.x, r.b.y),
e || a.lineEnd(),
(k = !1))
: e && (a.lineStart(), a.point(n, t), (k = !1));
}
(b = n), (_ = t), (w = e);
}
var v,
d,
y,
m,
M,
x,
b,
_,
w,
S,
k,
N = a,
E = Pt(),
A = Yt(n, t, e, r),
C = {
point: s,
lineStart: h,
lineEnd: p,
polygonStart: function () {
(a = E), (v = []), (d = []), (k = !0);
},
polygonEnd: function () {
(a = N), (v = ao.merge(v));
var t = l([n, r]),
e = k && t,
i = v.length;
(e || i) &&
(a.polygonStart(),
e && (a.lineStart(), c(null, null, 1, a), a.lineEnd()),
i && Lt(v, u, t, c, a),
a.polygonEnd()),
(v = d = y = null);
},
};
return C;
};
}
function Vt(n) {
var t = 0,
e = Fo / 3,
r = ae(n),
i = r(t, e);
return (
(i.parallels = function (n) {
return arguments.length
? r((t = (n[0] * Fo) / 180), (e = (n[1] * Fo) / 180))
: [(t / Fo) * 180, (e / Fo) * 180];
}),
i
);
}
function Xt(n, t) {
function e(n, t) {
var e = Math.sqrt(u - 2 * i * Math.sin(t)) / i;
return [e * Math.sin((n *= i)), o - e * Math.cos(n)];
}
var r = Math.sin(n),
i = (r + Math.sin(t)) / 2,
u = 1 + r * (2 * i - r),
o = Math.sqrt(u) / i;
return (
(e.invert = function (n, t) {
var e = o - t;
return [
Math.atan2(n, e) / i,
tn((u - (n * n + e * e) * i * i) / (2 * i)),
];
}),
e
);
}
function $t() {
function n(n, t) {
(Ia += i * n - r * t), (r = n), (i = t);
}
var t, e, r, i;
($a.point = function (u, o) {
($a.point = n), (t = r = u), (e = i = o);
}),
($a.lineEnd = function () {
n(t, e);
});
}
function Bt(n, t) {
Ya > n && (Ya = n),
n > Va && (Va = n),
Za > t && (Za = t),
t > Xa && (Xa = t);
}
function Wt() {
function n(n, t) {
o.push("M", n, ",", t, u);
}
function t(n, t) {
o.push("M", n, ",", t), (a.point = e);
}
function e(n, t) {
o.push("L", n, ",", t);
}
function r() {
a.point = n;
}
function i() {
o.push("Z");
}
var u = Jt(4.5),
o = [],
a = {
point: n,
lineStart: function () {
a.point = t;
},
lineEnd: r,
polygonStart: function () {
a.lineEnd = i;
},
polygonEnd: function () {
(a.lineEnd = r), (a.point = n);
},
pointRadius: function (n) {
return (u = Jt(n)), a;
},
result: function () {
if (o.length) {
var n = o.join("");
return (o = []), n;
}
},
};
return a;
}
function Jt(n) {
return (
"m0," +
n +
"a" +
n +
"," +
n +
" 0 1,1 0," +
-2 * n +
"a" +
n +
"," +
n +
" 0 1,1 0," +
2 * n +
"z"
);
}
function Gt(n, t) {
(Ca += n), (za += t), ++La;
}
function Kt() {
function n(n, r) {
var i = n - t,
u = r - e,
o = Math.sqrt(i * i + u * u);
(qa += (o * (t + n)) / 2),
(Ta += (o * (e + r)) / 2),
(Ra += o),
Gt((t = n), (e = r));
}
var t, e;
Wa.point = function (r, i) {
(Wa.point = n), Gt((t = r), (e = i));
};
}
function Qt() {
Wa.point = Gt;
}
function ne() {
function n(n, t) {
var e = n - r,
u = t - i,
o = Math.sqrt(e * e + u * u);
(qa += (o * (r + n)) / 2),
(Ta += (o * (i + t)) / 2),
(Ra += o),
(o = i * n - r * t),
(Da += o * (r + n)),
(Pa += o * (i + t)),
(Ua += 3 * o),
Gt((r = n), (i = t));
}
var t, e, r, i;
(Wa.point = function (u, o) {
(Wa.point = n), Gt((t = r = u), (e = i = o));
}),
(Wa.lineEnd = function () {
n(t, e);
});
}
function te(n) {
function t(t, e) {
n.moveTo(t + o, e), n.arc(t, e, o, 0, Ho);
}
function e(t, e) {
n.moveTo(t, e), (a.point = r);
}
function r(t, e) {
n.lineTo(t, e);
}
function i() {
a.point = t;
}
function u() {
n.closePath();
}
var o = 4.5,
a = {
point: t,
lineStart: function () {
a.point = e;
},
lineEnd: i,
polygonStart: function () {
a.lineEnd = u;
},
polygonEnd: function () {
(a.lineEnd = i), (a.point = t);
},
pointRadius: function (n) {
return (o = n), a;
},
result: b,
};
return a;
}
function ee(n) {
function t(n) {
return (a ? r : e)(n);
}
function e(t) {
return ue(t, function (e, r) {
(e = n(e, r)), t.point(e[0], e[1]);
});
}
function r(t) {
function e(e, r) {
(e = n(e, r)), t.point(e[0], e[1]);
}
function r() {
(M = NaN), (S.point = u), t.lineStart();
}
function u(e, r) {
var u = dt([e, r]),
o = n(e, r);
i(
M,
x,
m,
b,
_,
w,
(M = o[0]),
(x = o[1]),
(m = e),
(b = u[0]),
(_ = u[1]),
(w = u[2]),
a,
t
),
t.point(M, x);
}
function o() {
(S.point = e), t.lineEnd();
}
function l() {
r(), (S.point = c), (S.lineEnd = f);
}
function c(n, t) {
u((s = n), (h = t)),
(p = M),
(g = x),
(v = b),
(d = _),
(y = w),
(S.point = u);
}
function f() {
i(M, x, m, b, _, w, p, g, s, v, d, y, a, t), (S.lineEnd = o), o();
}
var s,
h,
p,
g,
v,
d,
y,
m,
M,
x,
b,
_,
w,
S = {
point: e,
lineStart: r,
lineEnd: o,
polygonStart: function () {
t.polygonStart(), (S.lineStart = l);
},
polygonEnd: function () {
t.polygonEnd(), (S.lineStart = r);
},
};
return S;
}
function i(t, e, r, a, l, c, f, s, h, p, g, v, d, y) {
var m = f - t,
M = s - e,
x = m * m + M * M;
if (x > 4 * u && d--) {
var b = a + p,
_ = l + g,
w = c + v,
S = Math.sqrt(b * b + _ * _ + w * w),
k = Math.asin((w /= S)),
N =
xo(xo(w) - 1) < Uo || xo(r - h) < Uo
? (r + h) / 2
: Math.atan2(_, b),
E = n(N, k),
A = E[0],
C = E[1],
z = A - t,
L = C - e,
q = M * z - m * L;
((q * q) / x > u ||
xo((m * z + M * L) / x - 0.5) > 0.3 ||
o > a * p + l * g + c * v) &&
(i(t, e, r, a, l, c, A, C, N, (b /= S), (_ /= S), w, d, y),
y.point(A, C),
i(A, C, N, b, _, w, f, s, h, p, g, v, d, y));
}
}
var u = 0.5,
o = Math.cos(30 * Yo),
a = 16;
return (
(t.precision = function (n) {
return arguments.length
? ((a = (u = n * n) > 0 && 16), t)
: Math.sqrt(u);
}),
t
);
}
function re(n) {
var t = ee(function (t, e) {
return n([t * Zo, e * Zo]);
});
return function (n) {
return le(t(n));
};
}
function ie(n) {
this.stream = n;
}
function ue(n, t) {
return {
point: t,
sphere: function () {
n.sphere();
},
lineStart: function () {
n.lineStart();
},
lineEnd: function () {
n.lineEnd();
},
polygonStart: function () {
n.polygonStart();
},
polygonEnd: function () {
n.polygonEnd();
},
};
}
function oe(n) {
return ae(function () {
return n;
})();
}
function ae(n) {
function t(n) {
return (n = a(n[0] * Yo, n[1] * Yo)), [n[0] * h + l, c - n[1] * h];
}
function e(n) {
return (
(n = a.invert((n[0] - l) / h, (c - n[1]) / h)),
n && [n[0] * Zo, n[1] * Zo]
);
}
function r() {
a = Ct((o = se(y, M, x)), u);
var n = u(v, d);
return (l = p - n[0] * h), (c = g + n[1] * h), i();
}
function i() {
return f && ((f.valid = !1), (f = null)), t;
}
var u,
o,
a,
l,
c,
f,
s = ee(function (n, t) {
return (n = u(n, t)), [n[0] * h + l, c - n[1] * h];
}),
h = 150,
p = 480,
g = 250,
v = 0,
d = 0,
y = 0,
M = 0,
x = 0,
b = Fa,
_ = m,
w = null,
S = null;
return (
(t.stream = function (n) {
return f && (f.valid = !1), (f = le(b(o, s(_(n))))), (f.valid = !0), f;
}),
(t.clipAngle = function (n) {
return arguments.length
? ((b = null == n ? ((w = n), Fa) : It((w = +n) * Yo)), i())
: w;
}),
(t.clipExtent = function (n) {
return arguments.length
? ((S = n), (_ = n ? Zt(n[0][0], n[0][1], n[1][0], n[1][1]) : m), i())
: S;
}),
(t.scale = function (n) {
return arguments.length ? ((h = +n), r()) : h;
}),
(t.translate = function (n) {
return arguments.length ? ((p = +n[0]), (g = +n[1]), r()) : [p, g];
}),
(t.center = function (n) {
return arguments.length
? ((v = (n[0] % 360) * Yo), (d = (n[1] % 360) * Yo), r())
: [v * Zo, d * Zo];
}),
(t.rotate = function (n) {
return arguments.length
? ((y = (n[0] % 360) * Yo),
(M = (n[1] % 360) * Yo),
(x = n.length > 2 ? (n[2] % 360) * Yo : 0),
r())
: [y * Zo, M * Zo, x * Zo];
}),
ao.rebind(t, s, "precision"),
function () {
return (u = n.apply(this, arguments)), (t.invert = u.invert && e), r();
}
);
}
function le(n) {
return ue(n, function (t, e) {
n.point(t * Yo, e * Yo);
});
}
function ce(n, t) {
return [n, t];
}
function fe(n, t) {
return [n > Fo ? n - Ho : -Fo > n ? n + Ho : n, t];
}
function se(n, t, e) {
return n ? (t || e ? Ct(pe(n), ge(t, e)) : pe(n)) : t || e ? ge(t, e) : fe;
}
function he(n) {
return function (t, e) {
return (t += n), [t > Fo ? t - Ho : -Fo > t ? t + Ho : t, e];
};
}
function pe(n) {
var t = he(n);
return (t.invert = he(-n)), t;
}
function ge(n, t) {
function e(n, t) {
var e = Math.cos(t),
a = Math.cos(n) * e,
l = Math.sin(n) * e,
c = Math.sin(t),
f = c * r + a * i;
return [Math.atan2(l * u - f * o, a * r - c * i), tn(f * u + l * o)];
}
var r = Math.cos(n),
i = Math.sin(n),
u = Math.cos(t),
o = Math.sin(t);
return (
(e.invert = function (n, t) {
var e = Math.cos(t),
a = Math.cos(n) * e,
l = Math.sin(n) * e,
c = Math.sin(t),
f = c * u - l * o;
return [Math.atan2(l * u + c * o, a * r + f * i), tn(f * r - a * i)];
}),
e
);
}
function ve(n, t) {
var e = Math.cos(n),
r = Math.sin(n);
return function (i, u, o, a) {
var l = o * t;
null != i
? ((i = de(e, i)),
(u = de(e, u)),
(o > 0 ? u > i : i > u) && (i += o * Ho))
: ((i = n + o * Ho), (u = n - 0.5 * l));
for (var c, f = i; o > 0 ? f > u : u > f; f -= l)
a.point((c = _t([e, -r * Math.cos(f), -r * Math.sin(f)]))[0], c[1]);
};
}
function de(n, t) {
var e = dt(t);
(e[0] -= n), bt(e);
var r = nn(-e[1]);
return ((-e[2] < 0 ? -r : r) + 2 * Math.PI - Uo) % (2 * Math.PI);
}
function ye(n, t, e) {
var r = ao.range(n, t - Uo, e).concat(t);
return function (n) {
return r.map(function (t) {
return [n, t];
});
};
}
function me(n, t, e) {
var r = ao.range(n, t - Uo, e).concat(t);
return function (n) {
return r.map(function (t) {
return [t, n];
});
};
}
function Me(n) {
return n.source;
}
function xe(n) {
return n.target;
}
function be(n, t, e, r) {
var i = Math.cos(t),
u = Math.sin(t),
o = Math.cos(r),
a = Math.sin(r),
l = i * Math.cos(n),
c = i * Math.sin(n),
f = o * Math.cos(e),
s = o * Math.sin(e),
h = 2 * Math.asin(Math.sqrt(on(r - t) + i * o * on(e - n))),
p = 1 / Math.sin(h),
g = h
? function (n) {
var t = Math.sin((n *= h)) * p,
e = Math.sin(h - n) * p,
r = e * l + t * f,
i = e * c + t * s,
o = e * u + t * a;
return [
Math.atan2(i, r) * Zo,
Math.atan2(o, Math.sqrt(r * r + i * i)) * Zo,
];
}
: function () {
return [n * Zo, t * Zo];
};
return (g.distance = h), g;
}
function _e() {
function n(n, i) {
var u = Math.sin((i *= Yo)),
o = Math.cos(i),
a = xo((n *= Yo) - t),
l = Math.cos(a);
(Ja += Math.atan2(
Math.sqrt((a = o * Math.sin(a)) * a + (a = r * u - e * o * l) * a),
e * u + r * o * l
)),
(t = n),
(e = u),
(r = o);
}
var t, e, r;
(Ga.point = function (i, u) {
(t = i * Yo),
(e = Math.sin((u *= Yo))),
(r = Math.cos(u)),
(Ga.point = n);
}),
(Ga.lineEnd = function () {
Ga.point = Ga.lineEnd = b;
});
}
function we(n, t) {
function e(t, e) {
var r = Math.cos(t),
i = Math.cos(e),
u = n(r * i);
return [u * i * Math.sin(t), u * Math.sin(e)];
}
return (
(e.invert = function (n, e) {
var r = Math.sqrt(n * n + e * e),
i = t(r),
u = Math.sin(i),
o = Math.cos(i);
return [Math.atan2(n * u, r * o), Math.asin(r && (e * u) / r)];
}),
e
);
}
function Se(n, t) {
function e(n, t) {
o > 0 ? -Io + Uo > t && (t = -Io + Uo) : t > Io - Uo && (t = Io - Uo);
var e = o / Math.pow(i(t), u);
return [e * Math.sin(u * n), o - e * Math.cos(u * n)];
}
var r = Math.cos(n),
i = function (n) {
return Math.tan(Fo / 4 + n / 2);
},
u =
n === t
? Math.sin(n)
: Math.log(r / Math.cos(t)) / Math.log(i(t) / i(n)),
o = (r * Math.pow(i(n), u)) / u;
return u
? ((e.invert = function (n, t) {
var e = o - t,
r = K(u) * Math.sqrt(n * n + e * e);
return [
Math.atan2(n, e) / u,
2 * Math.atan(Math.pow(o / r, 1 / u)) - Io,
];
}),
e)
: Ne;
}
function ke(n, t) {
function e(n, t) {
var e = u - t;
return [e * Math.sin(i * n), u - e * Math.cos(i * n)];
}
var r = Math.cos(n),
i = n === t ? Math.sin(n) : (r - Math.cos(t)) / (t - n),
u = r / i + n;
return xo(i) < Uo
? ce
: ((e.invert = function (n, t) {
var e = u - t;
return [Math.atan2(n, e) / i, u - K(i) * Math.sqrt(n * n + e * e)];
}),
e);
}
function Ne(n, t) {
return [n, Math.log(Math.tan(Fo / 4 + t / 2))];
}
function Ee(n) {
var t,
e = oe(n),
r = e.scale,
i = e.translate,
u = e.clipExtent;
return (
(e.scale = function () {
var n = r.apply(e, arguments);
return n === e ? (t ? e.clipExtent(null) : e) : n;
}),
(e.translate = function () {
var n = i.apply(e, arguments);
return n === e ? (t ? e.clipExtent(null) : e) : n;
}),
(e.clipExtent = function (n) {
var o = u.apply(e, arguments);
if (o === e) {
if ((t = null == n)) {
var a = Fo * r(),
l = i();
u([
[l[0] - a, l[1] - a],
[l[0] + a, l[1] + a],
]);
}
} else t && (o = null);
return o;
}),
e.clipExtent(null)
);
}
function Ae(n, t) {
return [Math.log(Math.tan(Fo / 4 + t / 2)), -n];
}
function Ce(n) {
return n[0];
}
function ze(n) {
return n[1];
}
function Le(n) {
for (var t = n.length, e = [0, 1], r = 2, i = 2; t > i; i++) {
for (; r > 1 && Q(n[e[r - 2]], n[e[r - 1]], n[i]) <= 0; ) --r;
e[r++] = i;
}
return e.slice(0, r);
}
function qe(n, t) {
return n[0] - t[0] || n[1] - t[1];
}
function Te(n, t, e) {
return (e[0] - t[0]) * (n[1] - t[1]) < (e[1] - t[1]) * (n[0] - t[0]);
}
function Re(n, t, e, r) {
var i = n[0],
u = e[0],
o = t[0] - i,
a = r[0] - u,
l = n[1],
c = e[1],
f = t[1] - l,
s = r[1] - c,
h = (a * (l - c) - s * (i - u)) / (s * o - a * f);
return [i + h * o, l + h * f];
}
function De(n) {
var t = n[0],
e = n[n.length - 1];
return !(t[0] - e[0] || t[1] - e[1]);
}
function Pe() {
rr(this), (this.edge = this.site = this.circle = null);
}
function Ue(n) {
var t = cl.pop() || new Pe();
return (t.site = n), t;
}
function je(n) {
Be(n), ol.remove(n), cl.push(n), rr(n);
}
function Fe(n) {
var t = n.circle,
e = t.x,
r = t.cy,
i = { x: e, y: r },
u = n.P,
o = n.N,
a = [n];
je(n);
for (
var l = u;
l.circle && xo(e - l.circle.x) < Uo && xo(r - l.circle.cy) < Uo;
)
(u = l.P), a.unshift(l), je(l), (l = u);
a.unshift(l), Be(l);
for (
var c = o;
c.circle && xo(e - c.circle.x) < Uo && xo(r - c.circle.cy) < Uo;
)
(o = c.N), a.push(c), je(c), (c = o);
a.push(c), Be(c);
var f,
s = a.length;
for (f = 1; s > f; ++f)
(c = a[f]), (l = a[f - 1]), nr(c.edge, l.site, c.site, i);
(l = a[0]),
(c = a[s - 1]),
(c.edge = Ke(l.site, c.site, null, i)),
$e(l),
$e(c);
}
function He(n) {
for (var t, e, r, i, u = n.x, o = n.y, a = ol._; a; )
if (((r = Oe(a, o) - u), r > Uo)) a = a.L;
else {
if (((i = u - Ie(a, o)), !(i > Uo))) {
r > -Uo
? ((t = a.P), (e = a))
: i > -Uo
? ((t = a), (e = a.N))
: (t = e = a);
break;
}
if (!a.R) {
t = a;
break;
}
a = a.R;
}
var l = Ue(n);
if ((ol.insert(t, l), t || e)) {
if (t === e)
return (
Be(t),
(e = Ue(t.site)),
ol.insert(l, e),
(l.edge = e.edge = Ke(t.site, l.site)),
$e(t),
void $e(e)
);
if (!e) return void (l.edge = Ke(t.site, l.site));
Be(t), Be(e);
var c = t.site,
f = c.x,
s = c.y,
h = n.x - f,
p = n.y - s,
g = e.site,
v = g.x - f,
d = g.y - s,
y = 2 * (h * d - p * v),
m = h * h + p * p,
M = v * v + d * d,
x = { x: (d * m - p * M) / y + f, y: (h * M - v * m) / y + s };
nr(e.edge, c, g, x),
(l.edge = Ke(c, n, null, x)),
(e.edge = Ke(n, g, null, x)),
$e(t),
$e(e);
}
}
function Oe(n, t) {
var e = n.site,
r = e.x,
i = e.y,
u = i - t;
if (!u) return r;
var o = n.P;
if (!o) return -(1 / 0);
e = o.site;
var a = e.x,
l = e.y,
c = l - t;
if (!c) return a;
var f = a - r,
s = 1 / u - 1 / c,
h = f / c;
return s
? (-h +
Math.sqrt(
h * h - 2 * s * ((f * f) / (-2 * c) - l + c / 2 + i - u / 2)
)) /
s +
r
: (r + a) / 2;
}
function Ie(n, t) {
var e = n.N;
if (e) return Oe(e, t);
var r = n.site;
return r.y === t ? r.x : 1 / 0;
}
function Ye(n) {
(this.site = n), (this.edges = []);
}
function Ze(n) {
for (
var t,
e,
r,
i,
u,
o,
a,
l,
c,
f,
s = n[0][0],
h = n[1][0],
p = n[0][1],
g = n[1][1],
v = ul,
d = v.length;
d--;
)
if (((u = v[d]), u && u.prepare()))
for (a = u.edges, l = a.length, o = 0; l > o; )
(f = a[o].end()),
(r = f.x),
(i = f.y),
(c = a[++o % l].start()),
(t = c.x),
(e = c.y),
(xo(r - t) > Uo || xo(i - e) > Uo) &&
(a.splice(
o,
0,
new tr(
Qe(
u.site,
f,
xo(r - s) < Uo && g - i > Uo
? { x: s, y: xo(t - s) < Uo ? e : g }
: xo(i - g) < Uo && h - r > Uo
? { x: xo(e - g) < Uo ? t : h, y: g }
: xo(r - h) < Uo && i - p > Uo
? { x: h, y: xo(t - h) < Uo ? e : p }
: xo(i - p) < Uo && r - s > Uo
? { x: xo(e - p) < Uo ? t : s, y: p }
: null
),
u.site,
null
)
),
++l);
}
function Ve(n, t) {
return t.angle - n.angle;
}
function Xe() {
rr(this), (this.x = this.y = this.arc = this.site = this.cy = null);
}
function $e(n) {
var t = n.P,
e = n.N;
if (t && e) {
var r = t.site,
i = n.site,
u = e.site;
if (r !== u) {
var o = i.x,
a = i.y,
l = r.x - o,
c = r.y - a,
f = u.x - o,
s = u.y - a,
h = 2 * (l * s - c * f);
if (!(h >= -jo)) {
var p = l * l + c * c,
g = f * f + s * s,
v = (s * p - c * g) / h,
d = (l * g - f * p) / h,
s = d + a,
y = fl.pop() || new Xe();
(y.arc = n),
(y.site = i),
(y.x = v + o),
(y.y = s + Math.sqrt(v * v + d * d)),
(y.cy = s),
(n.circle = y);
for (var m = null, M = ll._; M; )
if (y.y < M.y || (y.y === M.y && y.x <= M.x)) {
if (!M.L) {
m = M.P;
break;
}
M = M.L;
} else {
if (!M.R) {
m = M;
break;
}
M = M.R;
}
ll.insert(m, y), m || (al = y);
}
}
}
}
function Be(n) {
var t = n.circle;
t &&
(t.P || (al = t.N), ll.remove(t), fl.push(t), rr(t), (n.circle = null));
}
function We(n) {
for (
var t, e = il, r = Yt(n[0][0], n[0][1], n[1][0], n[1][1]), i = e.length;
i--;
)
(t = e[i]),
(!Je(t, n) ||
!r(t) ||
(xo(t.a.x - t.b.x) < Uo && xo(t.a.y - t.b.y) < Uo)) &&
((t.a = t.b = null), e.splice(i, 1));
}
function Je(n, t) {
var e = n.b;
if (e) return !0;
var r,
i,
u = n.a,
o = t[0][0],
a = t[1][0],
l = t[0][1],
c = t[1][1],
f = n.l,
s = n.r,
h = f.x,
p = f.y,
g = s.x,
v = s.y,
d = (h + g) / 2,
y = (p + v) / 2;
if (v === p) {
if (o > d || d >= a) return;
if (h > g) {
if (u) {
if (u.y >= c) return;
} else u = { x: d, y: l };
e = { x: d, y: c };
} else {
if (u) {
if (u.y < l) return;
} else u = { x: d, y: c };
e = { x: d, y: l };
}
} else if (((r = (h - g) / (v - p)), (i = y - r * d), -1 > r || r > 1))
if (h > g) {
if (u) {
if (u.y >= c) return;
} else u = { x: (l - i) / r, y: l };
e = { x: (c - i) / r, y: c };
} else {
if (u) {
if (u.y < l) return;
} else u = { x: (c - i) / r, y: c };
e = { x: (l - i) / r, y: l };
}
else if (v > p) {
if (u) {
if (u.x >= a) return;
} else u = { x: o, y: r * o + i };
e = { x: a, y: r * a + i };
} else {
if (u) {
if (u.x < o) return;
} else u = { x: a, y: r * a + i };
e = { x: o, y: r * o + i };
}
return (n.a = u), (n.b = e), !0;
}
function Ge(n, t) {
(this.l = n), (this.r = t), (this.a = this.b = null);
}
function Ke(n, t, e, r) {
var i = new Ge(n, t);
return (
il.push(i),
e && nr(i, n, t, e),
r && nr(i, t, n, r),
ul[n.i].edges.push(new tr(i, n, t)),
ul[t.i].edges.push(new tr(i, t, n)),
i
);
}
function Qe(n, t, e) {
var r = new Ge(n, null);
return (r.a = t), (r.b = e), il.push(r), r;
}
function nr(n, t, e, r) {
n.a || n.b
? n.l === e
? (n.b = r)
: (n.a = r)
: ((n.a = r), (n.l = t), (n.r = e));
}
function tr(n, t, e) {
var r = n.a,
i = n.b;
(this.edge = n),
(this.site = t),
(this.angle = e
? Math.atan2(e.y - t.y, e.x - t.x)
: n.l === t
? Math.atan2(i.x - r.x, r.y - i.y)
: Math.atan2(r.x - i.x, i.y - r.y));
}
function er() {
this._ = null;
}
function rr(n) {
n.U = n.C = n.L = n.R = n.P = n.N = null;
}
function ir(n, t) {
var e = t,
r = t.R,
i = e.U;
i ? (i.L === e ? (i.L = r) : (i.R = r)) : (n._ = r),
(r.U = i),
(e.U = r),
(e.R = r.L),
e.R && (e.R.U = e),
(r.L = e);
}
function ur(n, t) {
var e = t,
r = t.L,
i = e.U;
i ? (i.L === e ? (i.L = r) : (i.R = r)) : (n._ = r),
(r.U = i),
(e.U = r),
(e.L = r.R),
e.L && (e.L.U = e),
(r.R = e);
}
function or(n) {
for (; n.L; ) n = n.L;
return n;
}
function ar(n, t) {
var e,
r,
i,
u = n.sort(lr).pop();
for (il = [], ul = new Array(n.length), ol = new er(), ll = new er(); ; )
if (((i = al), u && (!i || u.y < i.y || (u.y === i.y && u.x < i.x))))
(u.x === e && u.y === r) ||
((ul[u.i] = new Ye(u)), He(u), (e = u.x), (r = u.y)),
(u = n.pop());
else {
if (!i) break;
Fe(i.arc);
}
t && (We(t), Ze(t));
var o = { cells: ul, edges: il };
return (ol = ll = il = ul = null), o;
}
function lr(n, t) {
return t.y - n.y || t.x - n.x;
}
function cr(n, t, e) {
return (n.x - e.x) * (t.y - n.y) - (n.x - t.x) * (e.y - n.y);
}
function fr(n) {
return n.x;
}
function sr(n) {
return n.y;
}
function hr() {
return { leaf: !0, nodes: [], point: null, x: null, y: null };
}
function pr(n, t, e, r, i, u) {
if (!n(t, e, r, i, u)) {
var o = 0.5 * (e + i),
a = 0.5 * (r + u),
l = t.nodes;
l[0] && pr(n, l[0], e, r, o, a),
l[1] && pr(n, l[1], o, r, i, a),
l[2] && pr(n, l[2], e, a, o, u),
l[3] && pr(n, l[3], o, a, i, u);
}
}
function gr(n, t, e, r, i, u, o) {
var a,
l = 1 / 0;
return (
(function c(n, f, s, h, p) {
if (!(f > u || s > o || r > h || i > p)) {
if ((g = n.point)) {
var g,
v = t - n.x,
d = e - n.y,
y = v * v + d * d;
if (l > y) {
var m = Math.sqrt((l = y));
(r = t - m), (i = e - m), (u = t + m), (o = e + m), (a = g);
}
}
for (
var M = n.nodes,
x = 0.5 * (f + h),
b = 0.5 * (s + p),
_ = t >= x,
w = e >= b,
S = (w << 1) | _,
k = S + 4;
k > S;
++S
)
if ((n = M[3 & S]))
switch (3 & S) {
case 0:
c(n, f, s, x, b);
break;
case 1:
c(n, x, s, h, b);
break;
case 2:
c(n, f, b, x, p);
break;
case 3:
c(n, x, b, h, p);
}
}
})(n, r, i, u, o),
a
);
}
function vr(n, t) {
(n = ao.rgb(n)), (t = ao.rgb(t));
var e = n.r,
r = n.g,
i = n.b,
u = t.r - e,
o = t.g - r,
a = t.b - i;
return function (n) {
return (
"#" +
bn(Math.round(e + u * n)) +
bn(Math.round(r + o * n)) +
bn(Math.round(i + a * n))
);
};
}
function dr(n, t) {
var e,
r = {},
i = {};
for (e in n) e in t ? (r[e] = Mr(n[e], t[e])) : (i[e] = n[e]);
for (e in t) e in n || (i[e] = t[e]);
return function (n) {
for (e in r) i[e] = r[e](n);
return i;
};
}
function yr(n, t) {
return (
(n = +n),
(t = +t),
function (e) {
return n * (1 - e) + t * e;
}
);
}
function mr(n, t) {
var e,
r,
i,
u = (hl.lastIndex = pl.lastIndex = 0),
o = -1,
a = [],
l = [];
for (n += "", t += ""; (e = hl.exec(n)) && (r = pl.exec(t)); )
(i = r.index) > u &&
((i = t.slice(u, i)), a[o] ? (a[o] += i) : (a[++o] = i)),
(e = e[0]) === (r = r[0])
? a[o]
? (a[o] += r)
: (a[++o] = r)
: ((a[++o] = null), l.push({ i: o, x: yr(e, r) })),
(u = pl.lastIndex);
return (
u < t.length && ((i = t.slice(u)), a[o] ? (a[o] += i) : (a[++o] = i)),
a.length < 2
? l[0]
? ((t = l[0].x),
function (n) {
return t(n) + "";
})
: function () {
return t;
}
: ((t = l.length),
function (n) {
for (var e, r = 0; t > r; ++r) a[(e = l[r]).i] = e.x(n);
return a.join("");
})
);
}
function Mr(n, t) {
for (
var e, r = ao.interpolators.length;
--r >= 0 && !(e = ao.interpolators[r](n, t));
);
return e;
}
function xr(n, t) {
var e,
r = [],
i = [],
u = n.length,
o = t.length,
a = Math.min(n.length, t.length);
for (e = 0; a > e; ++e) r.push(Mr(n[e], t[e]));
for (; u > e; ++e) i[e] = n[e];
for (; o > e; ++e) i[e] = t[e];
return function (n) {
for (e = 0; a > e; ++e) i[e] = r[e](n);
return i;
};
}
function br(n) {
return function (t) {
return 0 >= t ? 0 : t >= 1 ? 1 : n(t);
};
}
function _r(n) {
return function (t) {
return 1 - n(1 - t);
};
}
function wr(n) {
return function (t) {
return 0.5 * (0.5 > t ? n(2 * t) : 2 - n(2 - 2 * t));
};
}
function Sr(n) {
return n * n;
}
function kr(n) {
return n * n * n;
}
function Nr(n) {
if (0 >= n) return 0;
if (n >= 1) return 1;
var t = n * n,
e = t * n;
return 4 * (0.5 > n ? e : 3 * (n - t) + e - 0.75);
}
function Er(n) {
return function (t) {
return Math.pow(t, n);
};
}
function Ar(n) {
return 1 - Math.cos(n * Io);
}
function Cr(n) {
return Math.pow(2, 10 * (n - 1));
}
function zr(n) {
return 1 - Math.sqrt(1 - n * n);
}
function Lr(n, t) {
var e;
return (
arguments.length < 2 && (t = 0.45),
arguments.length
? (e = (t / Ho) * Math.asin(1 / n))
: ((n = 1), (e = t / 4)),
function (r) {
return 1 + n * Math.pow(2, -10 * r) * Math.sin(((r - e) * Ho) / t);
}
);
}
function qr(n) {
return (
n || (n = 1.70158),
function (t) {
return t * t * ((n + 1) * t - n);
}
);
}
function Tr(n) {
return 1 / 2.75 > n
? 7.5625 * n * n
: 2 / 2.75 > n
? 7.5625 * (n -= 1.5 / 2.75) * n + 0.75
: 2.5 / 2.75 > n
? 7.5625 * (n -= 2.25 / 2.75) * n + 0.9375
: 7.5625 * (n -= 2.625 / 2.75) * n + 0.984375;
}
function Rr(n, t) {
(n = ao.hcl(n)), (t = ao.hcl(t));
var e = n.h,
r = n.c,
i = n.l,
u = t.h - e,
o = t.c - r,
a = t.l - i;
return (
isNaN(o) && ((o = 0), (r = isNaN(r) ? t.c : r)),
isNaN(u)
? ((u = 0), (e = isNaN(e) ? t.h : e))
: u > 180
? (u -= 360)
: -180 > u && (u += 360),
function (n) {
return sn(e + u * n, r + o * n, i + a * n) + "";
}
);
}
function Dr(n, t) {
(n = ao.hsl(n)), (t = ao.hsl(t));
var e = n.h,
r = n.s,
i = n.l,
u = t.h - e,
o = t.s - r,
a = t.l - i;
return (
isNaN(o) && ((o = 0), (r = isNaN(r) ? t.s : r)),
isNaN(u)
? ((u = 0), (e = isNaN(e) ? t.h : e))
: u > 180
? (u -= 360)
: -180 > u && (u += 360),
function (n) {
return cn(e + u * n, r + o * n, i + a * n) + "";
}
);
}
function Pr(n, t) {
(n = ao.lab(n)), (t = ao.lab(t));
var e = n.l,
r = n.a,
i = n.b,
u = t.l - e,
o = t.a - r,
a = t.b - i;
return function (n) {
return pn(e + u * n, r + o * n, i + a * n) + "";
};
}
function Ur(n, t) {
return (
(t -= n),
function (e) {
return Math.round(n + t * e);
}
);
}
function jr(n) {
var t = [n.a, n.b],
e = [n.c, n.d],
r = Hr(t),
i = Fr(t, e),
u = Hr(Or(e, t, -i)) || 0;
t[0] * e[1] < e[0] * t[1] &&
((t[0] *= -1), (t[1] *= -1), (r *= -1), (i *= -1)),
(this.rotate =
(r ? Math.atan2(t[1], t[0]) : Math.atan2(-e[0], e[1])) * Zo),
(this.translate = [n.e, n.f]),
(this.scale = [r, u]),
(this.skew = u ? Math.atan2(i, u) * Zo : 0);
}
function Fr(n, t) {
return n[0] * t[0] + n[1] * t[1];
}
function Hr(n) {
var t = Math.sqrt(Fr(n, n));
return t && ((n[0] /= t), (n[1] /= t)), t;
}
function Or(n, t, e) {
return (n[0] += e * t[0]), (n[1] += e * t[1]), n;
}
function Ir(n) {
return n.length ? n.pop() + "," : "";
}
function Yr(n, t, e, r) {
if (n[0] !== t[0] || n[1] !== t[1]) {
var i = e.push("translate(", null, ",", null, ")");
r.push({ i: i - 4, x: yr(n[0], t[0]) }, { i: i - 2, x: yr(n[1], t[1]) });
} else (t[0] || t[1]) && e.push("translate(" + t + ")");
}
function Zr(n, t, e, r) {
n !== t
? (n - t > 180 ? (t += 360) : t - n > 180 && (n += 360),
r.push({ i: e.push(Ir(e) + "rotate(", null, ")") - 2, x: yr(n, t) }))
: t && e.push(Ir(e) + "rotate(" + t + ")");
}
function Vr(n, t, e, r) {
n !== t
? r.push({ i: e.push(Ir(e) + "skewX(", null, ")") - 2, x: yr(n, t) })
: t && e.push(Ir(e) + "skewX(" + t + ")");
}
function Xr(n, t, e, r) {
if (n[0] !== t[0] || n[1] !== t[1]) {
var i = e.push(Ir(e) + "scale(", null, ",", null, ")");
r.push({ i: i - 4, x: yr(n[0], t[0]) }, { i: i - 2, x: yr(n[1], t[1]) });
} else (1 === t[0] && 1 === t[1]) || e.push(Ir(e) + "scale(" + t + ")");
}
function $r(n, t) {
var e = [],
r = [];
return (
(n = ao.transform(n)),
(t = ao.transform(t)),
Yr(n.translate, t.translate, e, r),
Zr(n.rotate, t.rotate, e, r),
Vr(n.skew, t.skew, e, r),
Xr(n.scale, t.scale, e, r),
(n = t = null),
function (n) {
for (var t, i = -1, u = r.length; ++i < u; ) e[(t = r[i]).i] = t.x(n);
return e.join("");
}
);
}
function Br(n, t) {
return (
(t = (t -= n = +n) || 1 / t),
function (e) {
return (e - n) / t;
}
);
}
function Wr(n, t) {
return (
(t = (t -= n = +n) || 1 / t),
function (e) {
return Math.max(0, Math.min(1, (e - n) / t));
}
);
}
function Jr(n) {
for (var t = n.source, e = n.target, r = Kr(t, e), i = [t]; t !== r; )
(t = t.parent), i.push(t);
for (var u = i.length; e !== r; ) i.splice(u, 0, e), (e = e.parent);
return i;
}
function Gr(n) {
for (var t = [], e = n.parent; null != e; )
t.push(n), (n = e), (e = e.parent);
return t.push(n), t;
}
function Kr(n, t) {
if (n === t) return n;
for (
var e = Gr(n), r = Gr(t), i = e.pop(), u = r.pop(), o = null;
i === u;
)
(o = i), (i = e.pop()), (u = r.pop());
return o;
}
function Qr(n) {
n.fixed |= 2;
}
function ni(n) {
n.fixed &= -7;
}
function ti(n) {
(n.fixed |= 4), (n.px = n.x), (n.py = n.y);
}
function ei(n) {
n.fixed &= -5;
}
function ri(n, t, e) {
var r = 0,
i = 0;
if (((n.charge = 0), !n.leaf))
for (var u, o = n.nodes, a = o.length, l = -1; ++l < a; )
(u = o[l]),
null != u &&
(ri(u, t, e),
(n.charge += u.charge),
(r += u.charge * u.cx),
(i += u.charge * u.cy));
if (n.point) {
n.leaf ||
((n.point.x += Math.random() - 0.5),
(n.point.y += Math.random() - 0.5));
var c = t * e[n.point.index];
(n.charge += n.pointCharge = c),
(r += c * n.point.x),
(i += c * n.point.y);
}
(n.cx = r / n.charge), (n.cy = i / n.charge);
}
function ii(n, t) {
return (
ao.rebind(n, t, "sort", "children", "value"),
(n.nodes = n),
(n.links = fi),
n
);
}
function ui(n, t) {
for (var e = [n]; null != (n = e.pop()); )
if ((t(n), (i = n.children) && (r = i.length)))
for (var r, i; --r >= 0; ) e.push(i[r]);
}
function oi(n, t) {
for (var e = [n], r = []; null != (n = e.pop()); )
if ((r.push(n), (u = n.children) && (i = u.length)))
for (var i, u, o = -1; ++o < i; ) e.push(u[o]);
for (; null != (n = r.pop()); ) t(n);
}
function ai(n) {
return n.children;
}
function li(n) {
return n.value;
}
function ci(n, t) {
return t.value - n.value;
}
function fi(n) {
return ao.merge(
n.map(function (n) {
return (n.children || []).map(function (t) {
return { source: n, target: t };
});
})
);
}
function si(n) {
return n.x;
}
function hi(n) {
return n.y;
}
function pi(n, t, e) {
(n.y0 = t), (n.y = e);
}
function gi(n) {
return ao.range(n.length);
}
function vi(n) {
for (var t = -1, e = n[0].length, r = []; ++t < e; ) r[t] = 0;
return r;
}
function di(n) {
for (var t, e = 1, r = 0, i = n[0][1], u = n.length; u > e; ++e)
(t = n[e][1]) > i && ((r = e), (i = t));
return r;
}
function yi(n) {
return n.reduce(mi, 0);
}
function mi(n, t) {
return n + t[1];
}
function Mi(n, t) {
return xi(n, Math.ceil(Math.log(t.length) / Math.LN2 + 1));
}
function xi(n, t) {
for (var e = -1, r = +n[0], i = (n[1] - r) / t, u = []; ++e <= t; )
u[e] = i * e + r;
return u;
}
function bi(n) {
return [ao.min(n), ao.max(n)];
}
function _i(n, t) {
return n.value - t.value;
}
function wi(n, t) {
var e = n._pack_next;
(n._pack_next = t),
(t._pack_prev = n),
(t._pack_next = e),
(e._pack_prev = t);
}
function Si(n, t) {
(n._pack_next = t), (t._pack_prev = n);
}
function ki(n, t) {
var e = t.x - n.x,
r = t.y - n.y,
i = n.r + t.r;
return 0.999 * i * i > e * e + r * r;
}
function Ni(n) {
function t(n) {
(f = Math.min(n.x - n.r, f)),
(s = Math.max(n.x + n.r, s)),
(h = Math.min(n.y - n.r, h)),
(p = Math.max(n.y + n.r, p));
}
if ((e = n.children) && (c = e.length)) {
var e,
r,
i,
u,
o,
a,
l,
c,
f = 1 / 0,
s = -(1 / 0),
h = 1 / 0,
p = -(1 / 0);
if (
(e.forEach(Ei),
(r = e[0]),
(r.x = -r.r),
(r.y = 0),
t(r),
c > 1 && ((i = e[1]), (i.x = i.r), (i.y = 0), t(i), c > 2))
)
for (
u = e[2],
zi(r, i, u),
t(u),
wi(r, u),
r._pack_prev = u,
wi(u, i),
i = r._pack_next,
o = 3;
c > o;
o++
) {
zi(r, i, (u = e[o]));
var g = 0,
v = 1,
d = 1;
for (a = i._pack_next; a !== i; a = a._pack_next, v++)
if (ki(a, u)) {
g = 1;
break;
}
if (1 == g)
for (
l = r._pack_prev;
l !== a._pack_prev && !ki(l, u);
l = l._pack_prev, d++
);
g
? (d > v || (v == d && i.r < r.r) ? Si(r, (i = a)) : Si((r = l), i),
o--)
: (wi(r, u), (i = u), t(u));
}
var y = (f + s) / 2,
m = (h + p) / 2,
M = 0;
for (o = 0; c > o; o++)
(u = e[o]),
(u.x -= y),
(u.y -= m),
(M = Math.max(M, u.r + Math.sqrt(u.x * u.x + u.y * u.y)));
(n.r = M), e.forEach(Ai);
}
}
function Ei(n) {
n._pack_next = n._pack_prev = n;
}
function Ai(n) {
delete n._pack_next, delete n._pack_prev;
}
function Ci(n, t, e, r) {
var i = n.children;
if (((n.x = t += r * n.x), (n.y = e += r * n.y), (n.r *= r), i))
for (var u = -1, o = i.length; ++u < o; ) Ci(i[u], t, e, r);
}
function zi(n, t, e) {
var r = n.r + e.r,
i = t.x - n.x,
u = t.y - n.y;
if (r && (i || u)) {
var o = t.r + e.r,
a = i * i + u * u;
(o *= o), (r *= r);
var l = 0.5 + (r - o) / (2 * a),
c =
Math.sqrt(Math.max(0, 2 * o * (r + a) - (r -= a) * r - o * o)) /
(2 * a);
(e.x = n.x + l * i + c * u), (e.y = n.y + l * u - c * i);
} else (e.x = n.x + r), (e.y = n.y);
}
function Li(n, t) {
return n.parent == t.parent ? 1 : 2;
}
function qi(n) {
var t = n.children;
return t.length ? t[0] : n.t;
}
function Ti(n) {
var t,
e = n.children;
return (t = e.length) ? e[t - 1] : n.t;
}
function Ri(n, t, e) {
var r = e / (t.i - n.i);
(t.c -= r), (t.s += e), (n.c += r), (t.z += e), (t.m += e);
}
function Di(n) {
for (var t, e = 0, r = 0, i = n.children, u = i.length; --u >= 0; )
(t = i[u]), (t.z += e), (t.m += e), (e += t.s + (r += t.c));
}
function Pi(n, t, e) {
return n.a.parent === t.parent ? n.a : e;
}
function Ui(n) {
return (
1 +
ao.max(n, function (n) {
return n.y;
})
);
}
function ji(n) {
return (
n.reduce(function (n, t) {
return n + t.x;
}, 0) / n.length
);
}
function Fi(n) {
var t = n.children;
return t && t.length ? Fi(t[0]) : n;
}
function Hi(n) {
var t,
e = n.children;
return e && (t = e.length) ? Hi(e[t - 1]) : n;
}
function Oi(n) {
return { x: n.x, y: n.y, dx: n.dx, dy: n.dy };
}
function Ii(n, t) {
var e = n.x + t[3],
r = n.y + t[0],
i = n.dx - t[1] - t[3],
u = n.dy - t[0] - t[2];
return (
0 > i && ((e += i / 2), (i = 0)),
0 > u && ((r += u / 2), (u = 0)),
{ x: e, y: r, dx: i, dy: u }
);
}
function Yi(n) {
var t = n[0],
e = n[n.length - 1];
return e > t ? [t, e] : [e, t];
}
function Zi(n) {
return n.rangeExtent ? n.rangeExtent() : Yi(n.range());
}
function Vi(n, t, e, r) {
var i = e(n[0], n[1]),
u = r(t[0], t[1]);
return function (n) {
return u(i(n));
};
}
function Xi(n, t) {
var e,
r = 0,
i = n.length - 1,
u = n[r],
o = n[i];
return (
u > o && ((e = r), (r = i), (i = e), (e = u), (u = o), (o = e)),
(n[r] = t.floor(u)),
(n[i] = t.ceil(o)),
n
);
}
function $i(n) {
return n
? {
floor: function (t) {
return Math.floor(t / n) * n;
},
ceil: function (t) {
return Math.ceil(t / n) * n;
},
}
: Sl;
}
function Bi(n, t, e, r) {
var i = [],
u = [],
o = 0,
a = Math.min(n.length, t.length) - 1;
for (
n[a] < n[0] && ((n = n.slice().reverse()), (t = t.slice().reverse()));
++o <= a;
)
i.push(e(n[o - 1], n[o])), u.push(r(t[o - 1], t[o]));
return function (t) {
var e = ao.bisect(n, t, 1, a) - 1;
return u[e](i[e](t));
};
}
function Wi(n, t, e, r) {
function i() {
var i = Math.min(n.length, t.length) > 2 ? Bi : Vi,
l = r ? Wr : Br;
return (o = i(n, t, l, e)), (a = i(t, n, l, Mr)), u;
}
function u(n) {
return o(n);
}
var o, a;
return (
(u.invert = function (n) {
return a(n);
}),
(u.domain = function (t) {
return arguments.length ? ((n = t.map(Number)), i()) : n;
}),
(u.range = function (n) {
return arguments.length ? ((t = n), i()) : t;
}),
(u.rangeRound = function (n) {
return u.range(n).interpolate(Ur);
}),
(u.clamp = function (n) {
return arguments.length ? ((r = n), i()) : r;
}),
(u.interpolate = function (n) {
return arguments.length ? ((e = n), i()) : e;
}),
(u.ticks = function (t) {
return Qi(n, t);
}),
(u.tickFormat = function (t, e) {
return nu(n, t, e);
}),
(u.nice = function (t) {
return Gi(n, t), i();
}),
(u.copy = function () {
return Wi(n, t, e, r);
}),
i()
);
}
function Ji(n, t) {
return ao.rebind(n, t, "range", "rangeRound", "interpolate", "clamp");
}
function Gi(n, t) {
return Xi(n, $i(Ki(n, t)[2])), Xi(n, $i(Ki(n, t)[2])), n;
}
function Ki(n, t) {
null == t && (t = 10);
var e = Yi(n),
r = e[1] - e[0],
i = Math.pow(10, Math.floor(Math.log(r / t) / Math.LN10)),
u = (t / r) * i;
return (
0.15 >= u ? (i *= 10) : 0.35 >= u ? (i *= 5) : 0.75 >= u && (i *= 2),
(e[0] = Math.ceil(e[0] / i) * i),
(e[1] = Math.floor(e[1] / i) * i + 0.5 * i),
(e[2] = i),
e
);
}
function Qi(n, t) {
return ao.range.apply(ao, Ki(n, t));
}
function nu(n, t, e) {
var r = Ki(n, t);
if (e) {
var i = ha.exec(e);
if ((i.shift(), "s" === i[8])) {
var u = ao.formatPrefix(Math.max(xo(r[0]), xo(r[1])));
return (
i[7] || (i[7] = "." + tu(u.scale(r[2]))),
(i[8] = "f"),
(e = ao.format(i.join(""))),
function (n) {
return e(u.scale(n)) + u.symbol;
}
);
}
i[7] || (i[7] = "." + eu(i[8], r)), (e = i.join(""));
} else e = ",." + tu(r[2]) + "f";
return ao.format(e);
}
function tu(n) {
return -Math.floor(Math.log(n) / Math.LN10 + 0.01);
}
function eu(n, t) {
var e = tu(t[2]);
return n in kl
? Math.abs(e - tu(Math.max(xo(t[0]), xo(t[1])))) + +("e" !== n)
: e - 2 * ("%" === n);
}
function ru(n, t, e, r) {
function i(n) {
return (
(e ? Math.log(0 > n ? 0 : n) : -Math.log(n > 0 ? 0 : -n)) / Math.log(t)
);
}
function u(n) {
return e ? Math.pow(t, n) : -Math.pow(t, -n);
}
function o(t) {
return n(i(t));
}
return (
(o.invert = function (t) {
return u(n.invert(t));
}),
(o.domain = function (t) {
return arguments.length
? ((e = t[0] >= 0), n.domain((r = t.map(Number)).map(i)), o)
: r;
}),
(o.base = function (e) {
return arguments.length ? ((t = +e), n.domain(r.map(i)), o) : t;
}),
(o.nice = function () {
var t = Xi(r.map(i), e ? Math : El);
return n.domain(t), (r = t.map(u)), o;
}),
(o.ticks = function () {
var n = Yi(r),
o = [],
a = n[0],
l = n[1],
c = Math.floor(i(a)),
f = Math.ceil(i(l)),
s = t % 1 ? 2 : t;
if (isFinite(f - c)) {
if (e) {
for (; f > c; c++) for (var h = 1; s > h; h++) o.push(u(c) * h);
o.push(u(c));
} else
for (o.push(u(c)); c++ < f; )
for (var h = s - 1; h > 0; h--) o.push(u(c) * h);
for (c = 0; o[c] < a; c++);
for (f = o.length; o[f - 1] > l; f--);
o = o.slice(c, f);
}
return o;
}),
(o.tickFormat = function (n, e) {
if (!arguments.length) return Nl;
arguments.length < 2
? (e = Nl)
: "function" != typeof e && (e = ao.format(e));
var r = Math.max(1, (t * n) / o.ticks().length);
return function (n) {
var o = n / u(Math.round(i(n)));
return t - 0.5 > o * t && (o *= t), r >= o ? e(n) : "";
};
}),
(o.copy = function () {
return ru(n.copy(), t, e, r);
}),
Ji(o, n)
);
}
function iu(n, t, e) {
function r(t) {
return n(i(t));
}
var i = uu(t),
u = uu(1 / t);
return (
(r.invert = function (t) {
return u(n.invert(t));
}),
(r.domain = function (t) {
return arguments.length ? (n.domain((e = t.map(Number)).map(i)), r) : e;
}),
(r.ticks = function (n) {
return Qi(e, n);
}),
(r.tickFormat = function (n, t) {
return nu(e, n, t);
}),
(r.nice = function (n) {
return r.domain(Gi(e, n));
}),
(r.exponent = function (o) {
return arguments.length
? ((i = uu((t = o))), (u = uu(1 / t)), n.domain(e.map(i)), r)
: t;
}),
(r.copy = function () {
return iu(n.copy(), t, e);
}),
Ji(r, n)
);
}
function uu(n) {
return function (t) {
return 0 > t ? -Math.pow(-t, n) : Math.pow(t, n);
};
}
function ou(n, t) {
function e(e) {
return u[
((i.get(e) || ("range" === t.t ? i.set(e, n.push(e)) : NaN)) - 1) %
u.length
];
}
function r(t, e) {
return ao.range(n.length).map(function (n) {
return t + e * n;
});
}
var i, u, o;
return (
(e.domain = function (r) {
if (!arguments.length) return n;
(n = []), (i = new c());
for (var u, o = -1, a = r.length; ++o < a; )
i.has((u = r[o])) || i.set(u, n.push(u));
return e[t.t].apply(e, t.a);
}),
(e.range = function (n) {
return arguments.length
? ((u = n), (o = 0), (t = { t: "range", a: arguments }), e)
: u;
}),
(e.rangePoints = function (i, a) {
arguments.length < 2 && (a = 0);
var l = i[0],
c = i[1],
f =
n.length < 2
? ((l = (l + c) / 2), 0)
: (c - l) / (n.length - 1 + a);
return (
(u = r(l + (f * a) / 2, f)),
(o = 0),
(t = { t: "rangePoints", a: arguments }),
e
);
}),
(e.rangeRoundPoints = function (i, a) {
arguments.length < 2 && (a = 0);
var l = i[0],
c = i[1],
f =
n.length < 2
? ((l = c = Math.round((l + c) / 2)), 0)
: ((c - l) / (n.length - 1 + a)) | 0;
return (
(u = r(
l + Math.round((f * a) / 2 + (c - l - (n.length - 1 + a) * f) / 2),
f
)),
(o = 0),
(t = { t: "rangeRoundPoints", a: arguments }),
e
);
}),
(e.rangeBands = function (i, a, l) {
arguments.length < 2 && (a = 0), arguments.length < 3 && (l = a);
var c = i[1] < i[0],
f = i[c - 0],
s = i[1 - c],
h = (s - f) / (n.length - a + 2 * l);
return (
(u = r(f + h * l, h)),
c && u.reverse(),
(o = h * (1 - a)),
(t = { t: "rangeBands", a: arguments }),
e
);
}),
(e.rangeRoundBands = function (i, a, l) {
arguments.length < 2 && (a = 0), arguments.length < 3 && (l = a);
var c = i[1] < i[0],
f = i[c - 0],
s = i[1 - c],
h = Math.floor((s - f) / (n.length - a + 2 * l));
return (
(u = r(f + Math.round((s - f - (n.length - a) * h) / 2), h)),
c && u.reverse(),
(o = Math.round(h * (1 - a))),
(t = { t: "rangeRoundBands", a: arguments }),
e
);
}),
(e.rangeBand = function () {
return o;
}),
(e.rangeExtent = function () {
return Yi(t.a[0]);
}),
(e.copy = function () {
return ou(n, t);
}),
e.domain(n)
);
}
function au(n, t) {
function u() {
var e = 0,
r = t.length;
for (a = []; ++e < r; ) a[e - 1] = ao.quantile(n, e / r);
return o;
}
function o(n) {
return isNaN((n = +n)) ? void 0 : t[ao.bisect(a, n)];
}
var a;
return (
(o.domain = function (t) {
return arguments.length ? ((n = t.map(r).filter(i).sort(e)), u()) : n;
}),
(o.range = function (n) {
return arguments.length ? ((t = n), u()) : t;
}),
(o.quantiles = function () {
return a;
}),
(o.invertExtent = function (e) {
return (
(e = t.indexOf(e)),
0 > e
? [NaN, NaN]
: [e > 0 ? a[e - 1] : n[0], e < a.length ? a[e] : n[n.length - 1]]
);
}),
(o.copy = function () {
return au(n, t);
}),
u()
);
}
function lu(n, t, e) {
function r(t) {
return e[Math.max(0, Math.min(o, Math.floor(u * (t - n))))];
}
function i() {
return (u = e.length / (t - n)), (o = e.length - 1), r;
}
var u, o;
return (
(r.domain = function (e) {
return arguments.length
? ((n = +e[0]), (t = +e[e.length - 1]), i())
: [n, t];
}),
(r.range = function (n) {
return arguments.length ? ((e = n), i()) : e;
}),
(r.invertExtent = function (t) {
return (
(t = e.indexOf(t)), (t = 0 > t ? NaN : t / u + n), [t, t + 1 / u]
);
}),
(r.copy = function () {
return lu(n, t, e);
}),
i()
);
}
function cu(n, t) {
function e(e) {
return e >= e ? t[ao.bisect(n, e)] : void 0;
}
return (
(e.domain = function (t) {
return arguments.length ? ((n = t), e) : n;
}),
(e.range = function (n) {
return arguments.length ? ((t = n), e) : t;
}),
(e.invertExtent = function (e) {
return (e = t.indexOf(e)), [n[e - 1], n[e]];
}),
(e.copy = function () {
return cu(n, t);
}),
e
);
}
function fu(n) {
function t(n) {
return +n;
}
return (
(t.invert = t),
(t.domain = t.range =
function (e) {
return arguments.length ? ((n = e.map(t)), t) : n;
}),
(t.ticks = function (t) {
return Qi(n, t);
}),
(t.tickFormat = function (t, e) {
return nu(n, t, e);
}),
(t.copy = function () {
return fu(n);
}),
t
);
}
function su() {
return 0;
}
function hu(n) {
return n.innerRadius;
}
function pu(n) {
return n.outerRadius;
}
function gu(n) {
return n.startAngle;
}
function vu(n) {
return n.endAngle;
}
function du(n) {
return n && n.padAngle;
}
function yu(n, t, e, r) {
return (n - e) * t - (t - r) * n > 0 ? 0 : 1;
}
function mu(n, t, e, r, i) {
var u = n[0] - t[0],
o = n[1] - t[1],
a = (i ? r : -r) / Math.sqrt(u * u + o * o),
l = a * o,
c = -a * u,
f = n[0] + l,
s = n[1] + c,
h = t[0] + l,
p = t[1] + c,
g = (f + h) / 2,
v = (s + p) / 2,
d = h - f,
y = p - s,
m = d * d + y * y,
M = e - r,
x = f * p - h * s,
b = (0 > y ? -1 : 1) * Math.sqrt(Math.max(0, M * M * m - x * x)),
_ = (x * y - d * b) / m,
w = (-x * d - y * b) / m,
S = (x * y + d * b) / m,
k = (-x * d + y * b) / m,
N = _ - g,
E = w - v,
A = S - g,
C = k - v;
return (
N * N + E * E > A * A + C * C && ((_ = S), (w = k)),
[
[_ - l, w - c],
[(_ * e) / M, (w * e) / M],
]
);
}
function Mu(n) {
function t(t) {
function o() {
c.push("M", u(n(f), a));
}
for (
var l, c = [], f = [], s = -1, h = t.length, p = En(e), g = En(r);
++s < h;
)
i.call(this, (l = t[s]), s)
? f.push([+p.call(this, l, s), +g.call(this, l, s)])
: f.length && (o(), (f = []));
return f.length && o(), c.length ? c.join("") : null;
}
var e = Ce,
r = ze,
i = zt,
u = xu,
o = u.key,
a = 0.7;
return (
(t.x = function (n) {
return arguments.length ? ((e = n), t) : e;
}),
(t.y = function (n) {
return arguments.length ? ((r = n), t) : r;
}),
(t.defined = function (n) {
return arguments.length ? ((i = n), t) : i;
}),
(t.interpolate = function (n) {
return arguments.length
? ((o = "function" == typeof n ? (u = n) : (u = Tl.get(n) || xu).key),
t)
: o;
}),
(t.tension = function (n) {
return arguments.length ? ((a = n), t) : a;
}),
t
);
}
function xu(n) {
return n.length > 1 ? n.join("L") : n + "Z";
}
function bu(n) {
return n.join("L") + "Z";
}
function _u(n) {
for (var t = 0, e = n.length, r = n[0], i = [r[0], ",", r[1]]; ++t < e; )
i.push("H", (r[0] + (r = n[t])[0]) / 2, "V", r[1]);
return e > 1 && i.push("H", r[0]), i.join("");
}
function wu(n) {
for (var t = 0, e = n.length, r = n[0], i = [r[0], ",", r[1]]; ++t < e; )
i.push("V", (r = n[t])[1], "H", r[0]);
return i.join("");
}
function Su(n) {
for (var t = 0, e = n.length, r = n[0], i = [r[0], ",", r[1]]; ++t < e; )
i.push("H", (r = n[t])[0], "V", r[1]);
return i.join("");
}
function ku(n, t) {
return n.length < 4 ? xu(n) : n[1] + Au(n.slice(1, -1), Cu(n, t));
}
function Nu(n, t) {
return n.length < 3
? bu(n)
: n[0] +
Au((n.push(n[0]), n), Cu([n[n.length - 2]].concat(n, [n[1]]), t));
}
function Eu(n, t) {
return n.length < 3 ? xu(n) : n[0] + Au(n, Cu(n, t));
}
function Au(n, t) {
if (t.length < 1 || (n.length != t.length && n.length != t.length + 2))
return xu(n);
var e = n.length != t.length,
r = "",
i = n[0],
u = n[1],
o = t[0],
a = o,
l = 1;
if (
(e &&
((r +=
"Q" +
(u[0] - (2 * o[0]) / 3) +
"," +
(u[1] - (2 * o[1]) / 3) +
"," +
u[0] +
"," +
u[1]),
(i = n[1]),
(l = 2)),
t.length > 1)
) {
(a = t[1]),
(u = n[l]),
l++,
(r +=
"C" +
(i[0] + o[0]) +
"," +
(i[1] + o[1]) +
"," +
(u[0] - a[0]) +
"," +
(u[1] - a[1]) +
"," +
u[0] +
"," +
u[1]);
for (var c = 2; c < t.length; c++, l++)
(u = n[l]),
(a = t[c]),
(r +=
"S" +
(u[0] - a[0]) +
"," +
(u[1] - a[1]) +
"," +
u[0] +
"," +
u[1]);
}
if (e) {
var f = n[l];
r +=
"Q" +
(u[0] + (2 * a[0]) / 3) +
"," +
(u[1] + (2 * a[1]) / 3) +
"," +
f[0] +
"," +
f[1];
}
return r;
}
function Cu(n, t) {
for (
var e, r = [], i = (1 - t) / 2, u = n[0], o = n[1], a = 1, l = n.length;
++a < l;
)
(e = u),
(u = o),
(o = n[a]),
r.push([i * (o[0] - e[0]), i * (o[1] - e[1])]);
return r;
}
function zu(n) {
if (n.length < 3) return xu(n);
var t = 1,
e = n.length,
r = n[0],
i = r[0],
u = r[1],
o = [i, i, i, (r = n[1])[0]],
a = [u, u, u, r[1]],
l = [i, ",", u, "L", Ru(Pl, o), ",", Ru(Pl, a)];
for (n.push(n[e - 1]); ++t <= e; )
(r = n[t]), o.shift(), o.push(r[0]), a.shift(), a.push(r[1]), Du(l, o, a);
return n.pop(), l.push("L", r), l.join("");
}
function Lu(n) {
if (n.length < 4) return xu(n);
for (var t, e = [], r = -1, i = n.length, u = [0], o = [0]; ++r < 3; )
(t = n[r]), u.push(t[0]), o.push(t[1]);
for (e.push(Ru(Pl, u) + "," + Ru(Pl, o)), --r; ++r < i; )
(t = n[r]), u.shift(), u.push(t[0]), o.shift(), o.push(t[1]), Du(e, u, o);
return e.join("");
}
function qu(n) {
for (var t, e, r = -1, i = n.length, u = i + 4, o = [], a = []; ++r < 4; )
(e = n[r % i]), o.push(e[0]), a.push(e[1]);
for (t = [Ru(Pl, o), ",", Ru(Pl, a)], --r; ++r < u; )
(e = n[r % i]),
o.shift(),
o.push(e[0]),
a.shift(),
a.push(e[1]),
Du(t, o, a);
return t.join("");
}
function Tu(n, t) {
var e = n.length - 1;
if (e)
for (
var r,
i,
u = n[0][0],
o = n[0][1],
a = n[e][0] - u,
l = n[e][1] - o,
c = -1;
++c <= e;
)
(r = n[c]),
(i = c / e),
(r[0] = t * r[0] + (1 - t) * (u + i * a)),
(r[1] = t * r[1] + (1 - t) * (o + i * l));
return zu(n);
}
function Ru(n, t) {
return n[0] * t[0] + n[1] * t[1] + n[2] * t[2] + n[3] * t[3];
}
function Du(n, t, e) {
n.push(
"C",
Ru(Rl, t),
",",
Ru(Rl, e),
",",
Ru(Dl, t),
",",
Ru(Dl, e),
",",
Ru(Pl, t),
",",
Ru(Pl, e)
);
}
function Pu(n, t) {
return (t[1] - n[1]) / (t[0] - n[0]);
}
function Uu(n) {
for (
var t = 0,
e = n.length - 1,
r = [],
i = n[0],
u = n[1],
o = (r[0] = Pu(i, u));
++t < e;
)
r[t] = (o + (o = Pu((i = u), (u = n[t + 1])))) / 2;
return (r[t] = o), r;
}
function ju(n) {
for (var t, e, r, i, u = [], o = Uu(n), a = -1, l = n.length - 1; ++a < l; )
(t = Pu(n[a], n[a + 1])),
xo(t) < Uo
? (o[a] = o[a + 1] = 0)
: ((e = o[a] / t),
(r = o[a + 1] / t),
(i = e * e + r * r),
i > 9 &&
((i = (3 * t) / Math.sqrt(i)),
(o[a] = i * e),
(o[a + 1] = i * r)));
for (a = -1; ++a <= l; )
(i =
(n[Math.min(l, a + 1)][0] - n[Math.max(0, a - 1)][0]) /
(6 * (1 + o[a] * o[a]))),
u.push([i || 0, o[a] * i || 0]);
return u;
}
function Fu(n) {
return n.length < 3 ? xu(n) : n[0] + Au(n, ju(n));
}
function Hu(n) {
for (var t, e, r, i = -1, u = n.length; ++i < u; )
(t = n[i]),
(e = t[0]),
(r = t[1] - Io),
(t[0] = e * Math.cos(r)),
(t[1] = e * Math.sin(r));
return n;
}
function Ou(n) {
function t(t) {
function l() {
v.push("M", a(n(y), s), f, c(n(d.reverse()), s), "Z");
}
for (
var h,
p,
g,
v = [],
d = [],
y = [],
m = -1,
M = t.length,
x = En(e),
b = En(i),
_ =
e === r
? function () {
return p;
}
: En(r),
w =
i === u
? function () {
return g;
}
: En(u);
++m < M;
)
o.call(this, (h = t[m]), m)
? (d.push([(p = +x.call(this, h, m)), (g = +b.call(this, h, m))]),
y.push([+_.call(this, h, m), +w.call(this, h, m)]))
: d.length && (l(), (d = []), (y = []));
return d.length && l(), v.length ? v.join("") : null;
}
var e = Ce,
r = Ce,
i = 0,
u = ze,
o = zt,
a = xu,
l = a.key,
c = a,
f = "L",
s = 0.7;
return (
(t.x = function (n) {
return arguments.length ? ((e = r = n), t) : r;
}),
(t.x0 = function (n) {
return arguments.length ? ((e = n), t) : e;
}),
(t.x1 = function (n) {
return arguments.length ? ((r = n), t) : r;
}),
(t.y = function (n) {
return arguments.length ? ((i = u = n), t) : u;
}),
(t.y0 = function (n) {
return arguments.length ? ((i = n), t) : i;
}),
(t.y1 = function (n) {
return arguments.length ? ((u = n), t) : u;
}),
(t.defined = function (n) {
return arguments.length ? ((o = n), t) : o;
}),
(t.interpolate = function (n) {
return arguments.length
? ((l = "function" == typeof n ? (a = n) : (a = Tl.get(n) || xu).key),
(c = a.reverse || a),
(f = a.closed ? "M" : "L"),
t)
: l;
}),
(t.tension = function (n) {
return arguments.length ? ((s = n), t) : s;
}),
t
);
}
function Iu(n) {
return n.radius;
}
function Yu(n) {
return [n.x, n.y];
}
function Zu(n) {
return function () {
var t = n.apply(this, arguments),
e = t[0],
r = t[1] - Io;
return [e * Math.cos(r), e * Math.sin(r)];
};
}
function Vu() {
return 64;
}
function Xu() {
return "circle";
}
function $u(n) {
var t = Math.sqrt(n / Fo);
return (
"M0," +
t +
"A" +
t +
"," +
t +
" 0 1,1 0," +
-t +
"A" +
t +
"," +
t +
" 0 1,1 0," +
t +
"Z"
);
}
function Bu(n) {
return function () {
var t, e, r;
(t = this[n]) &&
(r = t[(e = t.active)]) &&
((r.timer.c = null),
(r.timer.t = NaN),
--t.count ? delete t[e] : delete this[n],
(t.active += 0.5),
r.event && r.event.interrupt.call(this, this.__data__, r.index));
};
}
function Wu(n, t, e) {
return ko(n, Yl), (n.namespace = t), (n.id = e), n;
}
function Ju(n, t, e, r) {
var i = n.id,
u = n.namespace;
return Y(
n,
"function" == typeof e
? function (n, o, a) {
n[u][i].tween.set(t, r(e.call(n, n.__data__, o, a)));
}
: ((e = r(e)),
function (n) {
n[u][i].tween.set(t, e);
})
);
}
function Gu(n) {
return (
null == n && (n = ""),
function () {
this.textContent = n;
}
);
}
function Ku(n) {
return null == n ? "__transition__" : "__transition_" + n + "__";
}
function Qu(n, t, e, r, i) {
function u(n) {
var t = v.delay;
return (f.t = t + l), n >= t ? o(n - t) : void (f.c = o);
}
function o(e) {
var i = g.active,
u = g[i];
u &&
((u.timer.c = null),
(u.timer.t = NaN),
--g.count,
delete g[i],
u.event && u.event.interrupt.call(n, n.__data__, u.index));
for (var o in g)
if (r > +o) {
var c = g[o];
(c.timer.c = null), (c.timer.t = NaN), --g.count, delete g[o];
}
(f.c = a),
qn(
function () {
return f.c && a(e || 1) && ((f.c = null), (f.t = NaN)), 1;
},
0,
l
),
(g.active = r),
v.event && v.event.start.call(n, n.__data__, t),
(p = []),
v.tween.forEach(function (e, r) {
(r = r.call(n, n.__data__, t)) && p.push(r);
}),
(h = v.ease),
(s = v.duration);
}
function a(i) {
for (var u = i / s, o = h(u), a = p.length; a > 0; ) p[--a].call(n, o);
return u >= 1
? (v.event && v.event.end.call(n, n.__data__, t),
--g.count ? delete g[r] : delete n[e],
1)
: void 0;
}
var l,
f,
s,
h,
p,
g = n[e] || (n[e] = { active: 0, count: 0 }),
v = g[r];
v ||
((l = i.time),
(f = qn(u, 0, l)),
(v = g[r] =
{
tween: new c(),
time: l,
timer: f,
delay: i.delay,
duration: i.duration,
ease: i.ease,
index: t,
}),
(i = null),
++g.count);
}
function no(n, t, e) {
n.attr("transform", function (n) {
var r = t(n);
return "translate(" + (isFinite(r) ? r : e(n)) + ",0)";
});
}
function to(n, t, e) {
n.attr("transform", function (n) {
var r = t(n);
return "translate(0," + (isFinite(r) ? r : e(n)) + ")";
});
}
function eo(n) {
return n.toISOString();
}
function ro(n, t, e) {
function r(t) {
return n(t);
}
function i(n, e) {
var r = n[1] - n[0],
i = r / e,
u = ao.bisect(Kl, i);
return u == Kl.length
? [
t.year,
Ki(
n.map(function (n) {
return n / 31536e6;
}),
e
)[2],
]
: u
? t[i / Kl[u - 1] < Kl[u] / i ? u - 1 : u]
: [tc, Ki(n, e)[2]];
}
return (
(r.invert = function (t) {
return io(n.invert(t));
}),
(r.domain = function (t) {
return arguments.length ? (n.domain(t), r) : n.domain().map(io);
}),
(r.nice = function (n, t) {
function e(e) {
return !isNaN(e) && !n.range(e, io(+e + 1), t).length;
}
var u = r.domain(),
o = Yi(u),
a = null == n ? i(o, 10) : "number" == typeof n && i(o, n);
return (
a && ((n = a[0]), (t = a[1])),
r.domain(
Xi(
u,
t > 1
? {
floor: function (t) {
for (; e((t = n.floor(t))); ) t = io(t - 1);
return t;
},
ceil: function (t) {
for (; e((t = n.ceil(t))); ) t = io(+t + 1);
return t;
},
}
: n
)
)
);
}),
(r.ticks = function (n, t) {
var e = Yi(r.domain()),
u =
null == n
? i(e, 10)
: "number" == typeof n
? i(e, n)
: !n.range && [{ range: n }, t];
return (
u && ((n = u[0]), (t = u[1])),
n.range(e[0], io(+e[1] + 1), 1 > t ? 1 : t)
);
}),
(r.tickFormat = function () {
return e;
}),
(r.copy = function () {
return ro(n.copy(), t, e);
}),
Ji(r, n)
);
}
function io(n) {
return new Date(n);
}
function uo(n) {
return JSON.parse(n.responseText);
}
function oo(n) {
var t = fo.createRange();
return t.selectNode(fo.body), t.createContextualFragment(n.responseText);
}
var ao = { version: "3.5.17" },
lo = [].slice,
co = function (n) {
return lo.call(n);
},
fo = this.document;
if (fo)
try {
co(fo.documentElement.childNodes)[0].nodeType;
} catch (so) {
co = function (n) {
for (var t = n.length, e = new Array(t); t--; ) e[t] = n[t];
return e;
};
}
if (
(Date.now ||
(Date.now = function () {
return +new Date();
}),
fo)
)
try {
fo.createElement("DIV").style.setProperty("opacity", 0, "");
} catch (ho) {
var po = this.Element.prototype,
go = po.setAttribute,
vo = po.setAttributeNS,
yo = this.CSSStyleDeclaration.prototype,
mo = yo.setProperty;
(po.setAttribute = function (n, t) {
go.call(this, n, t + "");
}),
(po.setAttributeNS = function (n, t, e) {
vo.call(this, n, t, e + "");
}),
(yo.setProperty = function (n, t, e) {
mo.call(this, n, t + "", e);
});
}
(ao.ascending = e),
(ao.descending = function (n, t) {
return n > t ? -1 : t > n ? 1 : t >= n ? 0 : NaN;
}),
(ao.min = function (n, t) {
var e,
r,
i = -1,
u = n.length;
if (1 === arguments.length) {
for (; ++i < u; )
if (null != (r = n[i]) && r >= r) {
e = r;
break;
}
for (; ++i < u; ) null != (r = n[i]) && e > r && (e = r);
} else {
for (; ++i < u; )
if (null != (r = t.call(n, n[i], i)) && r >= r) {
e = r;
break;
}
for (; ++i < u; ) null != (r = t.call(n, n[i], i)) && e > r && (e = r);
}
return e;
}),
(ao.max = function (n, t) {
var e,
r,
i = -1,
u = n.length;
if (1 === arguments.length) {
for (; ++i < u; )
if (null != (r = n[i]) && r >= r) {
e = r;
break;
}
for (; ++i < u; ) null != (r = n[i]) && r > e && (e = r);
} else {
for (; ++i < u; )
if (null != (r = t.call(n, n[i], i)) && r >= r) {
e = r;
break;
}
for (; ++i < u; ) null != (r = t.call(n, n[i], i)) && r > e && (e = r);
}
return e;
}),
(ao.extent = function (n, t) {
var e,
r,
i,
u = -1,
o = n.length;
if (1 === arguments.length) {
for (; ++u < o; )
if (null != (r = n[u]) && r >= r) {
e = i = r;
break;
}
for (; ++u < o; )
null != (r = n[u]) && (e > r && (e = r), r > i && (i = r));
} else {
for (; ++u < o; )
if (null != (r = t.call(n, n[u], u)) && r >= r) {
e = i = r;
break;
}
for (; ++u < o; )
null != (r = t.call(n, n[u], u)) &&
(e > r && (e = r), r > i && (i = r));
}
return [e, i];
}),
(ao.sum = function (n, t) {
var e,
r = 0,
u = n.length,
o = -1;
if (1 === arguments.length) for (; ++o < u; ) i((e = +n[o])) && (r += e);
else for (; ++o < u; ) i((e = +t.call(n, n[o], o))) && (r += e);
return r;
}),
(ao.mean = function (n, t) {
var e,
u = 0,
o = n.length,
a = -1,
l = o;
if (1 === arguments.length)
for (; ++a < o; ) i((e = r(n[a]))) ? (u += e) : --l;
else for (; ++a < o; ) i((e = r(t.call(n, n[a], a)))) ? (u += e) : --l;
return l ? u / l : void 0;
}),
(ao.quantile = function (n, t) {
var e = (n.length - 1) * t + 1,
r = Math.floor(e),
i = +n[r - 1],
u = e - r;
return u ? i + u * (n[r] - i) : i;
}),
(ao.median = function (n, t) {
var u,
o = [],
a = n.length,
l = -1;
if (1 === arguments.length)
for (; ++l < a; ) i((u = r(n[l]))) && o.push(u);
else for (; ++l < a; ) i((u = r(t.call(n, n[l], l)))) && o.push(u);
return o.length ? ao.quantile(o.sort(e), 0.5) : void 0;
}),
(ao.variance = function (n, t) {
var e,
u,
o = n.length,
a = 0,
l = 0,
c = -1,
f = 0;
if (1 === arguments.length)
for (; ++c < o; )
i((e = r(n[c]))) && ((u = e - a), (a += u / ++f), (l += u * (e - a)));
else
for (; ++c < o; )
i((e = r(t.call(n, n[c], c)))) &&
((u = e - a), (a += u / ++f), (l += u * (e - a)));
return f > 1 ? l / (f - 1) : void 0;
}),
(ao.deviation = function () {
var n = ao.variance.apply(this, arguments);
return n ? Math.sqrt(n) : n;
});
var Mo = u(e);
(ao.bisectLeft = Mo.left),
(ao.bisect = ao.bisectRight = Mo.right),
(ao.bisector = function (n) {
return u(
1 === n.length
? function (t, r) {
return e(n(t), r);
}
: n
);
}),
(ao.shuffle = function (n, t, e) {
(u = arguments.length) < 3 && ((e = n.length), 2 > u && (t = 0));
for (var r, i, u = e - t; u; )
(i = (Math.random() * u--) | 0),
(r = n[u + t]),
(n[u + t] = n[i + t]),
(n[i + t] = r);
return n;
}),
(ao.permute = function (n, t) {
for (var e = t.length, r = new Array(e); e--; ) r[e] = n[t[e]];
return r;
}),
(ao.pairs = function (n) {
for (
var t, e = 0, r = n.length - 1, i = n[0], u = new Array(0 > r ? 0 : r);
r > e;
)
u[e] = [(t = i), (i = n[++e])];
return u;
}),
(ao.transpose = function (n) {
if (!(i = n.length)) return [];
for (var t = -1, e = ao.min(n, o), r = new Array(e); ++t < e; )
for (var i, u = -1, a = (r[t] = new Array(i)); ++u < i; )
a[u] = n[u][t];
return r;
}),
(ao.zip = function () {
return ao.transpose(arguments);
}),
(ao.keys = function (n) {
var t = [];
for (var e in n) t.push(e);
return t;
}),
(ao.values = function (n) {
var t = [];
for (var e in n) t.push(n[e]);
return t;
}),
(ao.entries = function (n) {
var t = [];
for (var e in n) t.push({ key: e, value: n[e] });
return t;
}),
(ao.merge = function (n) {
for (var t, e, r, i = n.length, u = -1, o = 0; ++u < i; )
o += n[u].length;
for (e = new Array(o); --i >= 0; )
for (r = n[i], t = r.length; --t >= 0; ) e[--o] = r[t];
return e;
});
var xo = Math.abs;
(ao.range = function (n, t, e) {
if (
(arguments.length < 3 &&
((e = 1), arguments.length < 2 && ((t = n), (n = 0))),
(t - n) / e === 1 / 0)
)
throw new Error("infinite range");
var r,
i = [],
u = a(xo(e)),
o = -1;
if (((n *= u), (t *= u), (e *= u), 0 > e))
for (; (r = n + e * ++o) > t; ) i.push(r / u);
else for (; (r = n + e * ++o) < t; ) i.push(r / u);
return i;
}),
(ao.map = function (n, t) {
var e = new c();
if (n instanceof c)
n.forEach(function (n, t) {
e.set(n, t);
});
else if (Array.isArray(n)) {
var r,
i = -1,
u = n.length;
if (1 === arguments.length) for (; ++i < u; ) e.set(i, n[i]);
else for (; ++i < u; ) e.set(t.call(n, (r = n[i]), i), r);
} else for (var o in n) e.set(o, n[o]);
return e;
});
var bo = "__proto__",
_o = "\x00";
l(c, {
has: h,
get: function (n) {
return this._[f(n)];
},
set: function (n, t) {
return (this._[f(n)] = t);
},
remove: p,
keys: g,
values: function () {
var n = [];
for (var t in this._) n.push(this._[t]);
return n;
},
entries: function () {
var n = [];
for (var t in this._) n.push({ key: s(t), value: this._[t] });
return n;
},
size: v,
empty: d,
forEach: function (n) {
for (var t in this._) n.call(this, s(t), this._[t]);
},
}),
(ao.nest = function () {
function n(t, o, a) {
if (a >= u.length) return r ? r.call(i, o) : e ? o.sort(e) : o;
for (
var l, f, s, h, p = -1, g = o.length, v = u[a++], d = new c();
++p < g;
)
(h = d.get((l = v((f = o[p]))))) ? h.push(f) : d.set(l, [f]);
return (
t
? ((f = t()),
(s = function (e, r) {
f.set(e, n(t, r, a));
}))
: ((f = {}),
(s = function (e, r) {
f[e] = n(t, r, a);
})),
d.forEach(s),
f
);
}
function t(n, e) {
if (e >= u.length) return n;
var r = [],
i = o[e++];
return (
n.forEach(function (n, i) {
r.push({ key: n, values: t(i, e) });
}),
i
? r.sort(function (n, t) {
return i(n.key, t.key);
})
: r
);
}
var e,
r,
i = {},
u = [],
o = [];
return (
(i.map = function (t, e) {
return n(e, t, 0);
}),
(i.entries = function (e) {
return t(n(ao.map, e, 0), 0);
}),
(i.key = function (n) {
return u.push(n), i;
}),
(i.sortKeys = function (n) {
return (o[u.length - 1] = n), i;
}),
(i.sortValues = function (n) {
return (e = n), i;
}),
(i.rollup = function (n) {
return (r = n), i;
}),
i
);
}),
(ao.set = function (n) {
var t = new y();
if (n) for (var e = 0, r = n.length; r > e; ++e) t.add(n[e]);
return t;
}),
l(y, {
has: h,
add: function (n) {
return (this._[f((n += ""))] = !0), n;
},
remove: p,
values: g,
size: v,
empty: d,
forEach: function (n) {
for (var t in this._) n.call(this, s(t));
},
}),
(ao.behavior = {}),
(ao.rebind = function (n, t) {
for (var e, r = 1, i = arguments.length; ++r < i; )
n[(e = arguments[r])] = M(n, t, t[e]);
return n;
});
var wo = ["webkit", "ms", "moz", "Moz", "o", "O"];
(ao.dispatch = function () {
for (var n = new _(), t = -1, e = arguments.length; ++t < e; )
n[arguments[t]] = w(n);
return n;
}),
(_.prototype.on = function (n, t) {
var e = n.indexOf("."),
r = "";
if ((e >= 0 && ((r = n.slice(e + 1)), (n = n.slice(0, e))), n))
return arguments.length < 2 ? this[n].on(r) : this[n].on(r, t);
if (2 === arguments.length) {
if (null == t)
for (n in this) this.hasOwnProperty(n) && this[n].on(r, null);
return this;
}
}),
(ao.event = null),
(ao.requote = function (n) {
return n.replace(So, "\\$&");
});
var So = /[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g,
ko = {}.__proto__
? function (n, t) {
n.__proto__ = t;
}
: function (n, t) {
for (var e in t) n[e] = t[e];
},
No = function (n, t) {
return t.querySelector(n);
},
Eo = function (n, t) {
return t.querySelectorAll(n);
},
Ao = function (n, t) {
var e = n.matches || n[x(n, "matchesSelector")];
return (Ao = function (n, t) {
return e.call(n, t);
})(n, t);
};
"function" == typeof Sizzle &&
((No = function (n, t) {
return Sizzle(n, t)[0] || null;
}),
(Eo = Sizzle),
(Ao = Sizzle.matchesSelector)),
(ao.selection = function () {
return ao.select(fo.documentElement);
});
var Co = (ao.selection.prototype = []);
(Co.select = function (n) {
var t,
e,
r,
i,
u = [];
n = A(n);
for (var o = -1, a = this.length; ++o < a; ) {
u.push((t = [])), (t.parentNode = (r = this[o]).parentNode);
for (var l = -1, c = r.length; ++l < c; )
(i = r[l])
? (t.push((e = n.call(i, i.__data__, l, o))),
e && "__data__" in i && (e.__data__ = i.__data__))
: t.push(null);
}
return E(u);
}),
(Co.selectAll = function (n) {
var t,
e,
r = [];
n = C(n);
for (var i = -1, u = this.length; ++i < u; )
for (var o = this[i], a = -1, l = o.length; ++a < l; )
(e = o[a]) &&
(r.push((t = co(n.call(e, e.__data__, a, i)))), (t.parentNode = e));
return E(r);
});
var zo = "http://www.w3.org/1999/xhtml",
Lo = {
svg: "http://www.w3.org/2000/svg",
xhtml: zo,
xlink: "http://www.w3.org/1999/xlink",
xml: "http://www.w3.org/XML/1998/namespace",
xmlns: "http://www.w3.org/2000/xmlns/",
};
(ao.ns = {
prefix: Lo,
qualify: function (n) {
var t = n.indexOf(":"),
e = n;
return (
t >= 0 && "xmlns" !== (e = n.slice(0, t)) && (n = n.slice(t + 1)),
Lo.hasOwnProperty(e) ? { space: Lo[e], local: n } : n
);
},
}),
(Co.attr = function (n, t) {
if (arguments.length < 2) {
if ("string" == typeof n) {
var e = this.node();
return (
(n = ao.ns.qualify(n)),
n.local ? e.getAttributeNS(n.space, n.local) : e.getAttribute(n)
);
}
for (t in n) this.each(z(t, n[t]));
return this;
}
return this.each(z(n, t));
}),
(Co.classed = function (n, t) {
if (arguments.length < 2) {
if ("string" == typeof n) {
var e = this.node(),
r = (n = T(n)).length,
i = -1;
if ((t = e.classList)) {
for (; ++i < r; ) if (!t.contains(n[i])) return !1;
} else
for (t = e.getAttribute("class"); ++i < r; )
if (!q(n[i]).test(t)) return !1;
return !0;
}
for (t in n) this.each(R(t, n[t]));
return this;
}
return this.each(R(n, t));
}),
(Co.style = function (n, e, r) {
var i = arguments.length;
if (3 > i) {
if ("string" != typeof n) {
2 > i && (e = "");
for (r in n) this.each(P(r, n[r], e));
return this;
}
if (2 > i) {
var u = this.node();
return t(u).getComputedStyle(u, null).getPropertyValue(n);
}
r = "";
}
return this.each(P(n, e, r));
}),
(Co.property = function (n, t) {
if (arguments.length < 2) {
if ("string" == typeof n) return this.node()[n];
for (t in n) this.each(U(t, n[t]));
return this;
}
return this.each(U(n, t));
}),
(Co.text = function (n) {
return arguments.length
? this.each(
"function" == typeof n
? function () {
var t = n.apply(this, arguments);
this.textContent = null == t ? "" : t;
}
: null == n
? function () {
this.textContent = "";
}
: function () {
this.textContent = n;
}
)
: this.node().textContent;
}),
(Co.html = function (n) {
return arguments.length
? this.each(
"function" == typeof n
? function () {
var t = n.apply(this, arguments);
this.innerHTML = null == t ? "" : t;
}
: null == n
? function () {
this.innerHTML = "";
}
: function () {
this.innerHTML = n;
}
)
: this.node().innerHTML;
}),
(Co.append = function (n) {
return (
(n = j(n)),
this.select(function () {
return this.appendChild(n.apply(this, arguments));
})
);
}),
(Co.insert = function (n, t) {
return (
(n = j(n)),
(t = A(t)),
this.select(function () {
return this.insertBefore(
n.apply(this, arguments),
t.apply(this, arguments) || null
);
})
);
}),
(Co.remove = function () {
return this.each(F);
}),
(Co.data = function (n, t) {
function e(n, e) {
var r,
i,
u,
o = n.length,
s = e.length,
h = Math.min(o, s),
p = new Array(s),
g = new Array(s),
v = new Array(o);
if (t) {
var d,
y = new c(),
m = new Array(o);
for (r = -1; ++r < o; )
(i = n[r]) &&
(y.has((d = t.call(i, i.__data__, r))) ? (v[r] = i) : y.set(d, i),
(m[r] = d));
for (r = -1; ++r < s; )
(i = y.get((d = t.call(e, (u = e[r]), r))))
? i !== !0 && ((p[r] = i), (i.__data__ = u))
: (g[r] = H(u)),
y.set(d, !0);
for (r = -1; ++r < o; ) r in m && y.get(m[r]) !== !0 && (v[r] = n[r]);
} else {
for (r = -1; ++r < h; )
(i = n[r]),
(u = e[r]),
i ? ((i.__data__ = u), (p[r] = i)) : (g[r] = H(u));
for (; s > r; ++r) g[r] = H(e[r]);
for (; o > r; ++r) v[r] = n[r];
}
(g.update = p),
(g.parentNode = p.parentNode = v.parentNode = n.parentNode),
a.push(g),
l.push(p),
f.push(v);
}
var r,
i,
u = -1,
o = this.length;
if (!arguments.length) {
for (n = new Array((o = (r = this[0]).length)); ++u < o; )
(i = r[u]) && (n[u] = i.__data__);
return n;
}
var a = Z([]),
l = E([]),
f = E([]);
if ("function" == typeof n)
for (; ++u < o; ) e((r = this[u]), n.call(r, r.parentNode.__data__, u));
else for (; ++u < o; ) e((r = this[u]), n);
return (
(l.enter = function () {
return a;
}),
(l.exit = function () {
return f;
}),
l
);
}),
(Co.datum = function (n) {
return arguments.length
? this.property("__data__", n)
: this.property("__data__");
}),
(Co.filter = function (n) {
var t,
e,
r,
i = [];
"function" != typeof n && (n = O(n));
for (var u = 0, o = this.length; o > u; u++) {
i.push((t = [])), (t.parentNode = (e = this[u]).parentNode);
for (var a = 0, l = e.length; l > a; a++)
(r = e[a]) && n.call(r, r.__data__, a, u) && t.push(r);
}
return E(i);
}),
(Co.order = function () {
for (var n = -1, t = this.length; ++n < t; )
for (var e, r = this[n], i = r.length - 1, u = r[i]; --i >= 0; )
(e = r[i]) &&
(u && u !== e.nextSibling && u.parentNode.insertBefore(e, u),
(u = e));
return this;
}),
(Co.sort = function (n) {
n = I.apply(this, arguments);
for (var t = -1, e = this.length; ++t < e; ) this[t].sort(n);
return this.order();
}),
(Co.each = function (n) {
return Y(this, function (t, e, r) {
n.call(t, t.__data__, e, r);
});
}),
(Co.call = function (n) {
var t = co(arguments);
return n.apply((t[0] = this), t), this;
}),
(Co.empty = function () {
return !this.node();
}),
(Co.node = function () {
for (var n = 0, t = this.length; t > n; n++)
for (var e = this[n], r = 0, i = e.length; i > r; r++) {
var u = e[r];
if (u) return u;
}
return null;
}),
(Co.size = function () {
var n = 0;
return (
Y(this, function () {
++n;
}),
n
);
});
var qo = [];
(ao.selection.enter = Z),
(ao.selection.enter.prototype = qo),
(qo.append = Co.append),
(qo.empty = Co.empty),
(qo.node = Co.node),
(qo.call = Co.call),
(qo.size = Co.size),
(qo.select = function (n) {
for (var t, e, r, i, u, o = [], a = -1, l = this.length; ++a < l; ) {
(r = (i = this[a]).update),
o.push((t = [])),
(t.parentNode = i.parentNode);
for (var c = -1, f = i.length; ++c < f; )
(u = i[c])
? (t.push((r[c] = e = n.call(i.parentNode, u.__data__, c, a))),
(e.__data__ = u.__data__))
: t.push(null);
}
return E(o);
}),
(qo.insert = function (n, t) {
return arguments.length < 2 && (t = V(this)), Co.insert.call(this, n, t);
}),
(ao.select = function (t) {
var e;
return (
"string" == typeof t
? ((e = [No(t, fo)]), (e.parentNode = fo.documentElement))
: ((e = [t]), (e.parentNode = n(t))),
E([e])
);
}),
(ao.selectAll = function (n) {
var t;
return (
"string" == typeof n
? ((t = co(Eo(n, fo))), (t.parentNode = fo.documentElement))
: ((t = co(n)), (t.parentNode = null)),
E([t])
);
}),
(Co.on = function (n, t, e) {
var r = arguments.length;
if (3 > r) {
if ("string" != typeof n) {
2 > r && (t = !1);
for (e in n) this.each(X(e, n[e], t));
return this;
}
if (2 > r) return (r = this.node()["__on" + n]) && r._;
e = !1;
}
return this.each(X(n, t, e));
});
var To = ao.map({ mouseenter: "mouseover", mouseleave: "mouseout" });
fo &&
To.forEach(function (n) {
"on" + n in fo && To.remove(n);
});
var Ro,
Do = 0;
ao.mouse = function (n) {
return J(n, k());
};
var Po = this.navigator && /WebKit/.test(this.navigator.userAgent) ? -1 : 0;
(ao.touch = function (n, t, e) {
if ((arguments.length < 3 && ((e = t), (t = k().changedTouches)), t))
for (var r, i = 0, u = t.length; u > i; ++i)
if ((r = t[i]).identifier === e) return J(n, r);
}),
(ao.behavior.drag = function () {
function n() {
this.on("mousedown.drag", u).on("touchstart.drag", o);
}
function e(n, t, e, u, o) {
return function () {
function a() {
var n,
e,
r = t(h, v);
r &&
((n = r[0] - M[0]),
(e = r[1] - M[1]),
(g |= n | e),
(M = r),
p({
type: "drag",
x: r[0] + c[0],
y: r[1] + c[1],
dx: n,
dy: e,
}));
}
function l() {
t(h, v) &&
(y.on(u + d, null).on(o + d, null), m(g), p({ type: "dragend" }));
}
var c,
f = this,
s = ao.event.target.correspondingElement || ao.event.target,
h = f.parentNode,
p = r.of(f, arguments),
g = 0,
v = n(),
d = ".drag" + (null == v ? "" : "-" + v),
y = ao
.select(e(s))
.on(u + d, a)
.on(o + d, l),
m = W(s),
M = t(h, v);
i
? ((c = i.apply(f, arguments)), (c = [c.x - M[0], c.y - M[1]]))
: (c = [0, 0]),
p({ type: "dragstart" });
};
}
var r = N(n, "drag", "dragstart", "dragend"),
i = null,
u = e(b, ao.mouse, t, "mousemove", "mouseup"),
o = e(G, ao.touch, m, "touchmove", "touchend");
return (
(n.origin = function (t) {
return arguments.length ? ((i = t), n) : i;
}),
ao.rebind(n, r, "on")
);
}),
(ao.touches = function (n, t) {
return (
arguments.length < 2 && (t = k().touches),
t
? co(t).map(function (t) {
var e = J(n, t);
return (e.identifier = t.identifier), e;
})
: []
);
});
var Uo = 1e-6,
jo = Uo * Uo,
Fo = Math.PI,
Ho = 2 * Fo,
Oo = Ho - Uo,
Io = Fo / 2,
Yo = Fo / 180,
Zo = 180 / Fo,
Vo = Math.SQRT2,
Xo = 2,
$o = 4;
(ao.interpolateZoom = function (n, t) {
var e,
r,
i = n[0],
u = n[1],
o = n[2],
a = t[0],
l = t[1],
c = t[2],
f = a - i,
s = l - u,
h = f * f + s * s;
if (jo > h)
(r = Math.log(c / o) / Vo),
(e = function (n) {
return [i + n * f, u + n * s, o * Math.exp(Vo * n * r)];
});
else {
var p = Math.sqrt(h),
g = (c * c - o * o + $o * h) / (2 * o * Xo * p),
v = (c * c - o * o - $o * h) / (2 * c * Xo * p),
d = Math.log(Math.sqrt(g * g + 1) - g),
y = Math.log(Math.sqrt(v * v + 1) - v);
(r = (y - d) / Vo),
(e = function (n) {
var t = n * r,
e = rn(d),
a = (o / (Xo * p)) * (e * un(Vo * t + d) - en(d));
return [i + a * f, u + a * s, (o * e) / rn(Vo * t + d)];
});
}
return (e.duration = 1e3 * r), e;
}),
(ao.behavior.zoom = function () {
function n(n) {
n.on(L, s)
.on(Wo + ".zoom", p)
.on("dblclick.zoom", g)
.on(R, h);
}
function e(n) {
return [(n[0] - k.x) / k.k, (n[1] - k.y) / k.k];
}
function r(n) {
return [n[0] * k.k + k.x, n[1] * k.k + k.y];
}
function i(n) {
k.k = Math.max(A[0], Math.min(A[1], n));
}
function u(n, t) {
(t = r(t)), (k.x += n[0] - t[0]), (k.y += n[1] - t[1]);
}
function o(t, e, r, o) {
(t.__chart__ = { x: k.x, y: k.y, k: k.k }),
i(Math.pow(2, o)),
u((d = e), r),
(t = ao.select(t)),
C > 0 && (t = t.transition().duration(C)),
t.call(n.event);
}
function a() {
b &&
b.domain(
x
.range()
.map(function (n) {
return (n - k.x) / k.k;
})
.map(x.invert)
),
w &&
w.domain(
_.range()
.map(function (n) {
return (n - k.y) / k.k;
})
.map(_.invert)
);
}
function l(n) {
z++ || n({ type: "zoomstart" });
}
function c(n) {
a(), n({ type: "zoom", scale: k.k, translate: [k.x, k.y] });
}
function f(n) {
--z || (n({ type: "zoomend" }), (d = null));
}
function s() {
function n() {
(a = 1), u(ao.mouse(i), h), c(o);
}
function r() {
s.on(q, null).on(T, null), p(a), f(o);
}
var i = this,
o = D.of(i, arguments),
a = 0,
s = ao.select(t(i)).on(q, n).on(T, r),
h = e(ao.mouse(i)),
p = W(i);
Il.call(i), l(o);
}
function h() {
function n() {
var n = ao.touches(g);
return (
(p = k.k),
n.forEach(function (n) {
n.identifier in d && (d[n.identifier] = e(n));
}),
n
);
}
function t() {
var t = ao.event.target;
ao.select(t).on(x, r).on(b, a), _.push(t);
for (var e = ao.event.changedTouches, i = 0, u = e.length; u > i; ++i)
d[e[i].identifier] = null;
var l = n(),
c = Date.now();
if (1 === l.length) {
if (500 > c - M) {
var f = l[0];
o(
g,
f,
d[f.identifier],
Math.floor(Math.log(k.k) / Math.LN2) + 1
),
S();
}
M = c;
} else if (l.length > 1) {
var f = l[0],
s = l[1],
h = f[0] - s[0],
p = f[1] - s[1];
y = h * h + p * p;
}
}
function r() {
var n,
t,
e,
r,
o = ao.touches(g);
Il.call(g);
for (var a = 0, l = o.length; l > a; ++a, r = null)
if (((e = o[a]), (r = d[e.identifier]))) {
if (t) break;
(n = e), (t = r);
}
if (r) {
var f = (f = e[0] - n[0]) * f + (f = e[1] - n[1]) * f,
s = y && Math.sqrt(f / y);
(n = [(n[0] + e[0]) / 2, (n[1] + e[1]) / 2]),
(t = [(t[0] + r[0]) / 2, (t[1] + r[1]) / 2]),
i(s * p);
}
(M = null), u(n, t), c(v);
}
function a() {
if (ao.event.touches.length) {
for (
var t = ao.event.changedTouches, e = 0, r = t.length;
r > e;
++e
)
delete d[t[e].identifier];
for (var i in d) return void n();
}
ao.selectAll(_).on(m, null), w.on(L, s).on(R, h), N(), f(v);
}
var p,
g = this,
v = D.of(g, arguments),
d = {},
y = 0,
m = ".zoom-" + ao.event.changedTouches[0].identifier,
x = "touchmove" + m,
b = "touchend" + m,
_ = [],
w = ao.select(g),
N = W(g);
t(), l(v), w.on(L, null).on(R, t);
}
function p() {
var n = D.of(this, arguments);
m
? clearTimeout(m)
: (Il.call(this), (v = e((d = y || ao.mouse(this)))), l(n)),
(m = setTimeout(function () {
(m = null), f(n);
}, 50)),
S(),
i(Math.pow(2, 0.002 * Bo()) * k.k),
u(d, v),
c(n);
}
function g() {
var n = ao.mouse(this),
t = Math.log(k.k) / Math.LN2;
o(
this,
n,
e(n),
ao.event.shiftKey ? Math.ceil(t) - 1 : Math.floor(t) + 1
);
}
var v,
d,
y,
m,
M,
x,
b,
_,
w,
k = { x: 0, y: 0, k: 1 },
E = [960, 500],
A = Jo,
C = 250,
z = 0,
L = "mousedown.zoom",
q = "mousemove.zoom",
T = "mouseup.zoom",
R = "touchstart.zoom",
D = N(n, "zoomstart", "zoom", "zoomend");
return (
Wo ||
(Wo =
"onwheel" in fo
? ((Bo = function () {
return -ao.event.deltaY * (ao.event.deltaMode ? 120 : 1);
}),
"wheel")
: "onmousewheel" in fo
? ((Bo = function () {
return ao.event.wheelDelta;
}),
"mousewheel")
: ((Bo = function () {
return -ao.event.detail;
}),
"MozMousePixelScroll")),
(n.event = function (n) {
n.each(function () {
var n = D.of(this, arguments),
t = k;
Hl
? ao
.select(this)
.transition()
.each("start.zoom", function () {
(k = this.__chart__ || { x: 0, y: 0, k: 1 }), l(n);
})
.tween("zoom:zoom", function () {
var e = E[0],
r = E[1],
i = d ? d[0] : e / 2,
u = d ? d[1] : r / 2,
o = ao.interpolateZoom(
[(i - k.x) / k.k, (u - k.y) / k.k, e / k.k],
[(i - t.x) / t.k, (u - t.y) / t.k, e / t.k]
);
return function (t) {
var r = o(t),
a = e / r[2];
(this.__chart__ = k =
{ x: i - r[0] * a, y: u - r[1] * a, k: a }),
c(n);
};
})
.each("interrupt.zoom", function () {
f(n);
})
.each("end.zoom", function () {
f(n);
})
: ((this.__chart__ = k), l(n), c(n), f(n));
});
}),
(n.translate = function (t) {
return arguments.length
? ((k = { x: +t[0], y: +t[1], k: k.k }), a(), n)
: [k.x, k.y];
}),
(n.scale = function (t) {
return arguments.length
? ((k = { x: k.x, y: k.y, k: null }), i(+t), a(), n)
: k.k;
}),
(n.scaleExtent = function (t) {
return arguments.length
? ((A = null == t ? Jo : [+t[0], +t[1]]), n)
: A;
}),
(n.center = function (t) {
return arguments.length ? ((y = t && [+t[0], +t[1]]), n) : y;
}),
(n.size = function (t) {
return arguments.length ? ((E = t && [+t[0], +t[1]]), n) : E;
}),
(n.duration = function (t) {
return arguments.length ? ((C = +t), n) : C;
}),
(n.x = function (t) {
return arguments.length
? ((b = t), (x = t.copy()), (k = { x: 0, y: 0, k: 1 }), n)
: b;
}),
(n.y = function (t) {
return arguments.length
? ((w = t), (_ = t.copy()), (k = { x: 0, y: 0, k: 1 }), n)
: w;
}),
ao.rebind(n, D, "on")
);
});
var Bo,
Wo,
Jo = [0, 1 / 0];
(ao.color = an),
(an.prototype.toString = function () {
return this.rgb() + "";
}),
(ao.hsl = ln);
var Go = (ln.prototype = new an());
(Go.brighter = function (n) {
return (
(n = Math.pow(0.7, arguments.length ? n : 1)),
new ln(this.h, this.s, this.l / n)
);
}),
(Go.darker = function (n) {
return (
(n = Math.pow(0.7, arguments.length ? n : 1)),
new ln(this.h, this.s, n * this.l)
);
}),
(Go.rgb = function () {
return cn(this.h, this.s, this.l);
}),
(ao.hcl = fn);
var Ko = (fn.prototype = new an());
(Ko.brighter = function (n) {
return new fn(
this.h,
this.c,
Math.min(100, this.l + Qo * (arguments.length ? n : 1))
);
}),
(Ko.darker = function (n) {
return new fn(
this.h,
this.c,
Math.max(0, this.l - Qo * (arguments.length ? n : 1))
);
}),
(Ko.rgb = function () {
return sn(this.h, this.c, this.l).rgb();
}),
(ao.lab = hn);
var Qo = 18,
na = 0.95047,
ta = 1,
ea = 1.08883,
ra = (hn.prototype = new an());
(ra.brighter = function (n) {
return new hn(
Math.min(100, this.l + Qo * (arguments.length ? n : 1)),
this.a,
this.b
);
}),
(ra.darker = function (n) {
return new hn(
Math.max(0, this.l - Qo * (arguments.length ? n : 1)),
this.a,
this.b
);
}),
(ra.rgb = function () {
return pn(this.l, this.a, this.b);
}),
(ao.rgb = mn);
var ia = (mn.prototype = new an());
(ia.brighter = function (n) {
n = Math.pow(0.7, arguments.length ? n : 1);
var t = this.r,
e = this.g,
r = this.b,
i = 30;
return t || e || r
? (t && i > t && (t = i),
e && i > e && (e = i),
r && i > r && (r = i),
new mn(
Math.min(255, t / n),
Math.min(255, e / n),
Math.min(255, r / n)
))
: new mn(i, i, i);
}),
(ia.darker = function (n) {
return (
(n = Math.pow(0.7, arguments.length ? n : 1)),
new mn(n * this.r, n * this.g, n * this.b)
);
}),
(ia.hsl = function () {
return wn(this.r, this.g, this.b);
}),
(ia.toString = function () {
return "#" + bn(this.r) + bn(this.g) + bn(this.b);
});
var ua = ao.map({
aliceblue: 15792383,
antiquewhite: 16444375,
aqua: 65535,
aquamarine: 8388564,
azure: 15794175,
beige: 16119260,
bisque: 16770244,
black: 0,
blanchedalmond: 16772045,
blue: 255,
blueviolet: 9055202,
brown: 10824234,
burlywood: 14596231,
cadetblue: 6266528,
chartreuse: 8388352,
chocolate: 13789470,
coral: 16744272,
cornflowerblue: 6591981,
cornsilk: 16775388,
crimson: 14423100,
cyan: 65535,
darkblue: 139,
darkcyan: 35723,
darkgoldenrod: 12092939,
darkgray: 11119017,
darkgreen: 25600,
darkgrey: 11119017,
darkkhaki: 12433259,
darkmagenta: 9109643,
darkolivegreen: 5597999,
darkorange: 16747520,
darkorchid: 10040012,
darkred: 9109504,
darksalmon: 15308410,
darkseagreen: 9419919,
darkslateblue: 4734347,
darkslategray: 3100495,
darkslategrey: 3100495,
darkturquoise: 52945,
darkviolet: 9699539,
deeppink: 16716947,
deepskyblue: 49151,
dimgray: 6908265,
dimgrey: 6908265,
dodgerblue: 2003199,
firebrick: 11674146,
floralwhite: 16775920,
forestgreen: 2263842,
fuchsia: 16711935,
gainsboro: 14474460,
ghostwhite: 16316671,
gold: 16766720,
goldenrod: 14329120,
gray: 8421504,
green: 32768,
greenyellow: 11403055,
grey: 8421504,
honeydew: 15794160,
hotpink: 16738740,
indianred: 13458524,
indigo: 4915330,
ivory: 16777200,
khaki: 15787660,
lavender: 15132410,
lavenderblush: 16773365,
lawngreen: 8190976,
lemonchiffon: 16775885,
lightblue: 11393254,
lightcoral: 15761536,
lightcyan: 14745599,
lightgoldenrodyellow: 16448210,
lightgray: 13882323,
lightgreen: 9498256,
lightgrey: 13882323,
lightpink: 16758465,
lightsalmon: 16752762,
lightseagreen: 2142890,
lightskyblue: 8900346,
lightslategray: 7833753,
lightslategrey: 7833753,
lightsteelblue: 11584734,
lightyellow: 16777184,
lime: 65280,
limegreen: 3329330,
linen: 16445670,
magenta: 16711935,
maroon: 8388608,
mediumaquamarine: 6737322,
mediumblue: 205,
mediumorchid: 12211667,
mediumpurple: 9662683,
mediumseagreen: 3978097,
mediumslateblue: 8087790,
mediumspringgreen: 64154,
mediumturquoise: 4772300,
mediumvioletred: 13047173,
midnightblue: 1644912,
mintcream: 16121850,
mistyrose: 16770273,
moccasin: 16770229,
navajowhite: 16768685,
navy: 128,
oldlace: 16643558,
olive: 8421376,
olivedrab: 7048739,
orange: 16753920,
orangered: 16729344,
orchid: 14315734,
palegoldenrod: 15657130,
palegreen: 10025880,
paleturquoise: 11529966,
palevioletred: 14381203,
papayawhip: 16773077,
peachpuff: 16767673,
peru: 13468991,
pink: 16761035,
plum: 14524637,
powderblue: 11591910,
purple: 8388736,
rebeccapurple: 6697881,
red: 16711680,
rosybrown: 12357519,
royalblue: 4286945,
saddlebrown: 9127187,
salmon: 16416882,
sandybrown: 16032864,
seagreen: 3050327,
seashell: 16774638,
sienna: 10506797,
silver: 12632256,
skyblue: 8900331,
slateblue: 6970061,
slategray: 7372944,
slategrey: 7372944,
snow: 16775930,
springgreen: 65407,
steelblue: 4620980,
tan: 13808780,
teal: 32896,
thistle: 14204888,
tomato: 16737095,
turquoise: 4251856,
violet: 15631086,
wheat: 16113331,
white: 16777215,
whitesmoke: 16119285,
yellow: 16776960,
yellowgreen: 10145074,
});
ua.forEach(function (n, t) {
ua.set(n, Mn(t));
}),
(ao.functor = En),
(ao.xhr = An(m)),
(ao.dsv = function (n, t) {
function e(n, e, u) {
arguments.length < 3 && ((u = e), (e = null));
var o = Cn(n, t, null == e ? r : i(e), u);
return (
(o.row = function (n) {
return arguments.length
? o.response(null == (e = n) ? r : i(n))
: e;
}),
o
);
}
function r(n) {
return e.parse(n.responseText);
}
function i(n) {
return function (t) {
return e.parse(t.responseText, n);
};
}
function u(t) {
return t.map(o).join(n);
}
function o(n) {
return a.test(n) ? '"' + n.replace(/\"/g, '""') + '"' : n;
}
var a = new RegExp('["' + n + "\n]"),
l = n.charCodeAt(0);
return (
(e.parse = function (n, t) {
var r;
return e.parseRows(n, function (n, e) {
if (r) return r(n, e - 1);
var i = new Function(
"d",
"return {" +
n
.map(function (n, t) {
return JSON.stringify(n) + ": d[" + t + "]";
})
.join(",") +
"}"
);
r = t
? function (n, e) {
return t(i(n), e);
}
: i;
});
}),
(e.parseRows = function (n, t) {
function e() {
if (f >= c) return o;
if (i) return (i = !1), u;
var t = f;
if (34 === n.charCodeAt(t)) {
for (var e = t; e++ < c; )
if (34 === n.charCodeAt(e)) {
if (34 !== n.charCodeAt(e + 1)) break;
++e;
}
f = e + 2;
var r = n.charCodeAt(e + 1);
return (
13 === r
? ((i = !0), 10 === n.charCodeAt(e + 2) && ++f)
: 10 === r && (i = !0),
n.slice(t + 1, e).replace(/""/g, '"')
);
}
for (; c > f; ) {
var r = n.charCodeAt(f++),
a = 1;
if (10 === r) i = !0;
else if (13 === r) (i = !0), 10 === n.charCodeAt(f) && (++f, ++a);
else if (r !== l) continue;
return n.slice(t, f - a);
}
return n.slice(t);
}
for (
var r, i, u = {}, o = {}, a = [], c = n.length, f = 0, s = 0;
(r = e()) !== o;
) {
for (var h = []; r !== u && r !== o; ) h.push(r), (r = e());
(t && null == (h = t(h, s++))) || a.push(h);
}
return a;
}),
(e.format = function (t) {
if (Array.isArray(t[0])) return e.formatRows(t);
var r = new y(),
i = [];
return (
t.forEach(function (n) {
for (var t in n) r.has(t) || i.push(r.add(t));
}),
[i.map(o).join(n)]
.concat(
t.map(function (t) {
return i
.map(function (n) {
return o(t[n]);
})
.join(n);
})
)
.join("\n")
);
}),
(e.formatRows = function (n) {
return n.map(u).join("\n");
}),
e
);
}),
(ao.csv = ao.dsv(",", "text/csv")),
(ao.tsv = ao.dsv(" ", "text/tab-separated-values"));
var oa,
aa,
la,
ca,
fa =
this[x(this, "requestAnimationFrame")] ||
function (n) {
setTimeout(n, 17);
};
(ao.timer = function () {
qn.apply(this, arguments);
}),
(ao.timer.flush = function () {
Rn(), Dn();
}),
(ao.round = function (n, t) {
return t ? Math.round(n * (t = Math.pow(10, t))) / t : Math.round(n);
});
var sa = [
"y",
"z",
"a",
"f",
"p",
"n",
"\xb5",
"m",
"",
"k",
"M",
"G",
"T",
"P",
"E",
"Z",
"Y",
].map(Un);
ao.formatPrefix = function (n, t) {
var e = 0;
return (
(n = +n) &&
(0 > n && (n *= -1),
t && (n = ao.round(n, Pn(n, t))),
(e = 1 + Math.floor(1e-12 + Math.log(n) / Math.LN10)),
(e = Math.max(-24, Math.min(24, 3 * Math.floor((e - 1) / 3))))),
sa[8 + e / 3]
);
};
var ha =
/(?:([^{])?([<>=^]))?([+\- ])?([$#])?(0)?(\d+)?(,)?(\.-?\d+)?([a-z%])?/i,
pa = ao.map({
b: function (n) {
return n.toString(2);
},
c: function (n) {
return String.fromCharCode(n);
},
o: function (n) {
return n.toString(8);
},
x: function (n) {
return n.toString(16);
},
X: function (n) {
return n.toString(16).toUpperCase();
},
g: function (n, t) {
return n.toPrecision(t);
},
e: function (n, t) {
return n.toExponential(t);
},
f: function (n, t) {
return n.toFixed(t);
},
r: function (n, t) {
return (n = ao.round(n, Pn(n, t))).toFixed(
Math.max(0, Math.min(20, Pn(n * (1 + 1e-15), t)))
);
},
}),
ga = (ao.time = {}),
va = Date;
Hn.prototype = {
getDate: function () {
return this._.getUTCDate();
},
getDay: function () {
return this._.getUTCDay();
},
getFullYear: function () {
return this._.getUTCFullYear();
},
getHours: function () {
return this._.getUTCHours();
},
getMilliseconds: function () {
return this._.getUTCMilliseconds();
},
getMinutes: function () {
return this._.getUTCMinutes();
},
getMonth: function () {
return this._.getUTCMonth();
},
getSeconds: function () {
return this._.getUTCSeconds();
},
getTime: function () {
return this._.getTime();
},
getTimezoneOffset: function () {
return 0;
},
valueOf: function () {
return this._.valueOf();
},
setDate: function () {
da.setUTCDate.apply(this._, arguments);
},
setDay: function () {
da.setUTCDay.apply(this._, arguments);
},
setFullYear: function () {
da.setUTCFullYear.apply(this._, arguments);
},
setHours: function () {
da.setUTCHours.apply(this._, arguments);
},
setMilliseconds: function () {
da.setUTCMilliseconds.apply(this._, arguments);
},
setMinutes: function () {
da.setUTCMinutes.apply(this._, arguments);
},
setMonth: function () {
da.setUTCMonth.apply(this._, arguments);
},
setSeconds: function () {
da.setUTCSeconds.apply(this._, arguments);
},
setTime: function () {
da.setTime.apply(this._, arguments);
},
};
var da = Date.prototype;
(ga.year = On(
function (n) {
return (n = ga.day(n)), n.setMonth(0, 1), n;
},
function (n, t) {
n.setFullYear(n.getFullYear() + t);
},
function (n) {
return n.getFullYear();
}
)),
(ga.years = ga.year.range),
(ga.years.utc = ga.year.utc.range),
(ga.day = On(
function (n) {
var t = new va(2e3, 0);
return t.setFullYear(n.getFullYear(), n.getMonth(), n.getDate()), t;
},
function (n, t) {
n.setDate(n.getDate() + t);
},
function (n) {
return n.getDate() - 1;
}
)),
(ga.days = ga.day.range),
(ga.days.utc = ga.day.utc.range),
(ga.dayOfYear = function (n) {
var t = ga.year(n);
return Math.floor(
(n - t - 6e4 * (n.getTimezoneOffset() - t.getTimezoneOffset())) / 864e5
);
}),
[
"sunday",
"monday",
"tuesday",
"wednesday",
"thursday",
"friday",
"saturday",
].forEach(function (n, t) {
t = 7 - t;
var e = (ga[n] = On(
function (n) {
return (
(n = ga.day(n)).setDate(n.getDate() - ((n.getDay() + t) % 7)), n
);
},
function (n, t) {
n.setDate(n.getDate() + 7 * Math.floor(t));
},
function (n) {
var e = ga.year(n).getDay();
return Math.floor((ga.dayOfYear(n) + ((e + t) % 7)) / 7) - (e !== t);
}
));
(ga[n + "s"] = e.range),
(ga[n + "s"].utc = e.utc.range),
(ga[n + "OfYear"] = function (n) {
var e = ga.year(n).getDay();
return Math.floor((ga.dayOfYear(n) + ((e + t) % 7)) / 7);
});
}),
(ga.week = ga.sunday),
(ga.weeks = ga.sunday.range),
(ga.weeks.utc = ga.sunday.utc.range),
(ga.weekOfYear = ga.sundayOfYear);
var ya = { "-": "", _: " ", 0: "0" },
ma = /^\s*\d+/,
Ma = /^%/;
ao.locale = function (n) {
return { numberFormat: jn(n), timeFormat: Yn(n) };
};
var xa = ao.locale({
decimal: ".",
thousands: ",",
grouping: [3],
currency: ["$", ""],
dateTime: "%a %b %e %X %Y",
date: "%m/%d/%Y",
time: "%H:%M:%S",
periods: ["AM", "PM"],
days: [
"Sunday",
"Monday",
"Tuesday",
"Wednesday",
"Thursday",
"Friday",
"Saturday",
],
shortDays: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
months: [
"January",
"February",
"March",
"April",
"May",
"June",
"July",
"August",
"September",
"October",
"November",
"December",
],
shortMonths: [
"Jan",
"Feb",
"Mar",
"Apr",
"May",
"Jun",
"Jul",
"Aug",
"Sep",
"Oct",
"Nov",
"Dec",
],
});
(ao.format = xa.numberFormat),
(ao.geo = {}),
(ft.prototype = {
s: 0,
t: 0,
add: function (n) {
st(n, this.t, ba),
st(ba.s, this.s, this),
this.s ? (this.t += ba.t) : (this.s = ba.t);
},
reset: function () {
this.s = this.t = 0;
},
valueOf: function () {
return this.s;
},
});
var ba = new ft();
ao.geo.stream = function (n, t) {
n && _a.hasOwnProperty(n.type) ? _a[n.type](n, t) : ht(n, t);
};
var _a = {
Feature: function (n, t) {
ht(n.geometry, t);
},
FeatureCollection: function (n, t) {
for (var e = n.features, r = -1, i = e.length; ++r < i; )
ht(e[r].geometry, t);
},
},
wa = {
Sphere: function (n, t) {
t.sphere();
},
Point: function (n, t) {
(n = n.coordinates), t.point(n[0], n[1], n[2]);
},
MultiPoint: function (n, t) {
for (var e = n.coordinates, r = -1, i = e.length; ++r < i; )
(n = e[r]), t.point(n[0], n[1], n[2]);
},
LineString: function (n, t) {
pt(n.coordinates, t, 0);
},
MultiLineString: function (n, t) {
for (var e = n.coordinates, r = -1, i = e.length; ++r < i; )
pt(e[r], t, 0);
},
Polygon: function (n, t) {
gt(n.coordinates, t);
},
MultiPolygon: function (n, t) {
for (var e = n.coordinates, r = -1, i = e.length; ++r < i; )
gt(e[r], t);
},
GeometryCollection: function (n, t) {
for (var e = n.geometries, r = -1, i = e.length; ++r < i; ) ht(e[r], t);
},
};
ao.geo.area = function (n) {
return (Sa = 0), ao.geo.stream(n, Na), Sa;
};
var Sa,
ka = new ft(),
Na = {
sphere: function () {
Sa += 4 * Fo;
},
point: b,
lineStart: b,
lineEnd: b,
polygonStart: function () {
ka.reset(), (Na.lineStart = vt);
},
polygonEnd: function () {
var n = 2 * ka;
(Sa += 0 > n ? 4 * Fo + n : n),
(Na.lineStart = Na.lineEnd = Na.point = b);
},
};
(ao.geo.bounds = (function () {
function n(n, t) {
M.push((x = [(f = n), (h = n)])), s > t && (s = t), t > p && (p = t);
}
function t(t, e) {
var r = dt([t * Yo, e * Yo]);
if (y) {
var i = mt(y, r),
u = [i[1], -i[0], 0],
o = mt(u, i);
bt(o), (o = _t(o));
var l = t - g,
c = l > 0 ? 1 : -1,
v = o[0] * Zo * c,
d = xo(l) > 180;
if (d ^ (v > c * g && c * t > v)) {
var m = o[1] * Zo;
m > p && (p = m);
} else if (
((v = ((v + 360) % 360) - 180), d ^ (v > c * g && c * t > v))
) {
var m = -o[1] * Zo;
s > m && (s = m);
} else s > e && (s = e), e > p && (p = e);
d
? g > t
? a(f, t) > a(f, h) && (h = t)
: a(t, h) > a(f, h) && (f = t)
: h >= f
? (f > t && (f = t), t > h && (h = t))
: t > g
? a(f, t) > a(f, h) && (h = t)
: a(t, h) > a(f, h) && (f = t);
} else n(t, e);
(y = r), (g = t);
}
function e() {
b.point = t;
}
function r() {
(x[0] = f), (x[1] = h), (b.point = n), (y = null);
}
function i(n, e) {
if (y) {
var r = n - g;
m += xo(r) > 180 ? r + (r > 0 ? 360 : -360) : r;
} else (v = n), (d = e);
Na.point(n, e), t(n, e);
}
function u() {
Na.lineStart();
}
function o() {
i(v, d),
Na.lineEnd(),
xo(m) > Uo && (f = -(h = 180)),
(x[0] = f),
(x[1] = h),
(y = null);
}
function a(n, t) {
return (t -= n) < 0 ? t + 360 : t;
}
function l(n, t) {
return n[0] - t[0];
}
function c(n, t) {
return t[0] <= t[1] ? t[0] <= n && n <= t[1] : n < t[0] || t[1] < n;
}
var f,
s,
h,
p,
g,
v,
d,
y,
m,
M,
x,
b = {
point: n,
lineStart: e,
lineEnd: r,
polygonStart: function () {
(b.point = i),
(b.lineStart = u),
(b.lineEnd = o),
(m = 0),
Na.polygonStart();
},
polygonEnd: function () {
Na.polygonEnd(),
(b.point = n),
(b.lineStart = e),
(b.lineEnd = r),
0 > ka
? ((f = -(h = 180)), (s = -(p = 90)))
: m > Uo
? (p = 90)
: -Uo > m && (s = -90),
(x[0] = f),
(x[1] = h);
},
};
return function (n) {
(p = h = -(f = s = 1 / 0)), (M = []), ao.geo.stream(n, b);
var t = M.length;
if (t) {
M.sort(l);
for (var e, r = 1, i = M[0], u = [i]; t > r; ++r)
(e = M[r]),
c(e[0], i) || c(e[1], i)
? (a(i[0], e[1]) > a(i[0], i[1]) && (i[1] = e[1]),
a(e[0], i[1]) > a(i[0], i[1]) && (i[0] = e[0]))
: u.push((i = e));
for (
var o, e, g = -(1 / 0), t = u.length - 1, r = 0, i = u[t];
t >= r;
i = e, ++r
)
(e = u[r]),
(o = a(i[1], e[0])) > g && ((g = o), (f = e[0]), (h = i[1]));
}
return (
(M = x = null),
f === 1 / 0 || s === 1 / 0
? [
[NaN, NaN],
[NaN, NaN],
]
: [
[f, s],
[h, p],
]
);
};
})()),
(ao.geo.centroid = function (n) {
(Ea = Aa = Ca = za = La = qa = Ta = Ra = Da = Pa = Ua = 0),
ao.geo.stream(n, ja);
var t = Da,
e = Pa,
r = Ua,
i = t * t + e * e + r * r;
return jo > i &&
((t = qa),
(e = Ta),
(r = Ra),
Uo > Aa && ((t = Ca), (e = za), (r = La)),
(i = t * t + e * e + r * r),
jo > i)
? [NaN, NaN]
: [Math.atan2(e, t) * Zo, tn(r / Math.sqrt(i)) * Zo];
});
var Ea,
Aa,
Ca,
za,
La,
qa,
Ta,
Ra,
Da,
Pa,
Ua,
ja = {
sphere: b,
point: St,
lineStart: Nt,
lineEnd: Et,
polygonStart: function () {
ja.lineStart = At;
},
polygonEnd: function () {
ja.lineStart = Nt;
},
},
Fa = Rt(zt, jt, Ht, [-Fo, -Fo / 2]),
Ha = 1e9;
(ao.geo.clipExtent = function () {
var n,
t,
e,
r,
i,
u,
o = {
stream: function (n) {
return i && (i.valid = !1), (i = u(n)), (i.valid = !0), i;
},
extent: function (a) {
return arguments.length
? ((u = Zt(
(n = +a[0][0]),
(t = +a[0][1]),
(e = +a[1][0]),
(r = +a[1][1])
)),
i && ((i.valid = !1), (i = null)),
o)
: [
[n, t],
[e, r],
];
},
};
return o.extent([
[0, 0],
[960, 500],
]);
}),
((ao.geo.conicEqualArea = function () {
return Vt(Xt);
}).raw = Xt),
(ao.geo.albers = function () {
return ao.geo
.conicEqualArea()
.rotate([96, 0])
.center([-0.6, 38.7])
.parallels([29.5, 45.5])
.scale(1070);
}),
(ao.geo.albersUsa = function () {
function n(n) {
var u = n[0],
o = n[1];
return (t = null), e(u, o), t || (r(u, o), t) || i(u, o), t;
}
var t,
e,
r,
i,
u = ao.geo.albers(),
o = ao.geo
.conicEqualArea()
.rotate([154, 0])
.center([-2, 58.5])
.parallels([55, 65]),
a = ao.geo
.conicEqualArea()
.rotate([157, 0])
.center([-3, 19.9])
.parallels([8, 18]),
l = {
point: function (n, e) {
t = [n, e];
},
};
return (
(n.invert = function (n) {
var t = u.scale(),
e = u.translate(),
r = (n[0] - e[0]) / t,
i = (n[1] - e[1]) / t;
return (
i >= 0.12 && 0.234 > i && r >= -0.425 && -0.214 > r
? o
: i >= 0.166 && 0.234 > i && r >= -0.214 && -0.115 > r
? a
: u
).invert(n);
}),
(n.stream = function (n) {
var t = u.stream(n),
e = o.stream(n),
r = a.stream(n);
return {
point: function (n, i) {
t.point(n, i), e.point(n, i), r.point(n, i);
},
sphere: function () {
t.sphere(), e.sphere(), r.sphere();
},
lineStart: function () {
t.lineStart(), e.lineStart(), r.lineStart();
},
lineEnd: function () {
t.lineEnd(), e.lineEnd(), r.lineEnd();
},
polygonStart: function () {
t.polygonStart(), e.polygonStart(), r.polygonStart();
},
polygonEnd: function () {
t.polygonEnd(), e.polygonEnd(), r.polygonEnd();
},
};
}),
(n.precision = function (t) {
return arguments.length
? (u.precision(t), o.precision(t), a.precision(t), n)
: u.precision();
}),
(n.scale = function (t) {
return arguments.length
? (u.scale(t),
o.scale(0.35 * t),
a.scale(t),
n.translate(u.translate()))
: u.scale();
}),
(n.translate = function (t) {
if (!arguments.length) return u.translate();
var c = u.scale(),
f = +t[0],
s = +t[1];
return (
(e = u
.translate(t)
.clipExtent([
[f - 0.455 * c, s - 0.238 * c],
[f + 0.455 * c, s + 0.238 * c],
])
.stream(l).point),
(r = o
.translate([f - 0.307 * c, s + 0.201 * c])
.clipExtent([
[f - 0.425 * c + Uo, s + 0.12 * c + Uo],
[f - 0.214 * c - Uo, s + 0.234 * c - Uo],
])
.stream(l).point),
(i = a
.translate([f - 0.205 * c, s + 0.212 * c])
.clipExtent([
[f - 0.214 * c + Uo, s + 0.166 * c + Uo],
[f - 0.115 * c - Uo, s + 0.234 * c - Uo],
])
.stream(l).point),
n
);
}),
n.scale(1070)
);
});
var Oa,
Ia,
Ya,
Za,
Va,
Xa,
$a = {
point: b,
lineStart: b,
lineEnd: b,
polygonStart: function () {
(Ia = 0), ($a.lineStart = $t);
},
polygonEnd: function () {
($a.lineStart = $a.lineEnd = $a.point = b), (Oa += xo(Ia / 2));
},
},
Ba = {
point: Bt,
lineStart: b,
lineEnd: b,
polygonStart: b,
polygonEnd: b,
},
Wa = {
point: Gt,
lineStart: Kt,
lineEnd: Qt,
polygonStart: function () {
Wa.lineStart = ne;
},
polygonEnd: function () {
(Wa.point = Gt), (Wa.lineStart = Kt), (Wa.lineEnd = Qt);
},
};
(ao.geo.path = function () {
function n(n) {
return (
n &&
("function" == typeof a && u.pointRadius(+a.apply(this, arguments)),
(o && o.valid) || (o = i(u)),
ao.geo.stream(n, o)),
u.result()
);
}
function t() {
return (o = null), n;
}
var e,
r,
i,
u,
o,
a = 4.5;
return (
(n.area = function (n) {
return (Oa = 0), ao.geo.stream(n, i($a)), Oa;
}),
(n.centroid = function (n) {
return (
(Ca = za = La = qa = Ta = Ra = Da = Pa = Ua = 0),
ao.geo.stream(n, i(Wa)),
Ua
? [Da / Ua, Pa / Ua]
: Ra
? [qa / Ra, Ta / Ra]
: La
? [Ca / La, za / La]
: [NaN, NaN]
);
}),
(n.bounds = function (n) {
return (
(Va = Xa = -(Ya = Za = 1 / 0)),
ao.geo.stream(n, i(Ba)),
[
[Ya, Za],
[Va, Xa],
]
);
}),
(n.projection = function (n) {
return arguments.length
? ((i = (e = n) ? n.stream || re(n) : m), t())
: e;
}),
(n.context = function (n) {
return arguments.length
? ((u = null == (r = n) ? new Wt() : new te(n)),
"function" != typeof a && u.pointRadius(a),
t())
: r;
}),
(n.pointRadius = function (t) {
return arguments.length
? ((a = "function" == typeof t ? t : (u.pointRadius(+t), +t)), n)
: a;
}),
n.projection(ao.geo.albersUsa()).context(null)
);
}),
(ao.geo.transform = function (n) {
return {
stream: function (t) {
var e = new ie(t);
for (var r in n) e[r] = n[r];
return e;
},
};
}),
(ie.prototype = {
point: function (n, t) {
this.stream.point(n, t);
},
sphere: function () {
this.stream.sphere();
},
lineStart: function () {
this.stream.lineStart();
},
lineEnd: function () {
this.stream.lineEnd();
},
polygonStart: function () {
this.stream.polygonStart();
},
polygonEnd: function () {
this.stream.polygonEnd();
},
}),
(ao.geo.projection = oe),
(ao.geo.projectionMutator = ae),
((ao.geo.equirectangular = function () {
return oe(ce);
}).raw = ce.invert =
ce),
(ao.geo.rotation = function (n) {
function t(t) {
return (t = n(t[0] * Yo, t[1] * Yo)), (t[0] *= Zo), (t[1] *= Zo), t;
}
return (
(n = se((n[0] % 360) * Yo, n[1] * Yo, n.length > 2 ? n[2] * Yo : 0)),
(t.invert = function (t) {
return (
(t = n.invert(t[0] * Yo, t[1] * Yo)), (t[0] *= Zo), (t[1] *= Zo), t
);
}),
t
);
}),
(fe.invert = ce),
(ao.geo.circle = function () {
function n() {
var n = "function" == typeof r ? r.apply(this, arguments) : r,
t = se(-n[0] * Yo, -n[1] * Yo, 0).invert,
i = [];
return (
e(null, null, 1, {
point: function (n, e) {
i.push((n = t(n, e))), (n[0] *= Zo), (n[1] *= Zo);
},
}),
{ type: "Polygon", coordinates: [i] }
);
}
var t,
e,
r = [0, 0],
i = 6;
return (
(n.origin = function (t) {
return arguments.length ? ((r = t), n) : r;
}),
(n.angle = function (r) {
return arguments.length ? ((e = ve((t = +r) * Yo, i * Yo)), n) : t;
}),
(n.precision = function (r) {
return arguments.length ? ((e = ve(t * Yo, (i = +r) * Yo)), n) : i;
}),
n.angle(90)
);
}),
(ao.geo.distance = function (n, t) {
var e,
r = (t[0] - n[0]) * Yo,
i = n[1] * Yo,
u = t[1] * Yo,
o = Math.sin(r),
a = Math.cos(r),
l = Math.sin(i),
c = Math.cos(i),
f = Math.sin(u),
s = Math.cos(u);
return Math.atan2(
Math.sqrt((e = s * o) * e + (e = c * f - l * s * a) * e),
l * f + c * s * a
);
}),
(ao.geo.graticule = function () {
function n() {
return { type: "MultiLineString", coordinates: t() };
}
function t() {
return ao
.range(Math.ceil(u / d) * d, i, d)
.map(h)
.concat(ao.range(Math.ceil(c / y) * y, l, y).map(p))
.concat(
ao
.range(Math.ceil(r / g) * g, e, g)
.filter(function (n) {
return xo(n % d) > Uo;
})
.map(f)
)
.concat(
ao
.range(Math.ceil(a / v) * v, o, v)
.filter(function (n) {
return xo(n % y) > Uo;
})
.map(s)
);
}
var e,
r,
i,
u,
o,
a,
l,
c,
f,
s,
h,
p,
g = 10,
v = g,
d = 90,
y = 360,
m = 2.5;
return (
(n.lines = function () {
return t().map(function (n) {
return { type: "LineString", coordinates: n };
});
}),
(n.outline = function () {
return {
type: "Polygon",
coordinates: [
h(u).concat(
p(l).slice(1),
h(i).reverse().slice(1),
p(c).reverse().slice(1)
),
],
};
}),
(n.extent = function (t) {
return arguments.length
? n.majorExtent(t).minorExtent(t)
: n.minorExtent();
}),
(n.majorExtent = function (t) {
return arguments.length
? ((u = +t[0][0]),
(i = +t[1][0]),
(c = +t[0][1]),
(l = +t[1][1]),
u > i && ((t = u), (u = i), (i = t)),
c > l && ((t = c), (c = l), (l = t)),
n.precision(m))
: [
[u, c],
[i, l],
];
}),
(n.minorExtent = function (t) {
return arguments.length
? ((r = +t[0][0]),
(e = +t[1][0]),
(a = +t[0][1]),
(o = +t[1][1]),
r > e && ((t = r), (r = e), (e = t)),
a > o && ((t = a), (a = o), (o = t)),
n.precision(m))
: [
[r, a],
[e, o],
];
}),
(n.step = function (t) {
return arguments.length ? n.majorStep(t).minorStep(t) : n.minorStep();
}),
(n.majorStep = function (t) {
return arguments.length ? ((d = +t[0]), (y = +t[1]), n) : [d, y];
}),
(n.minorStep = function (t) {
return arguments.length ? ((g = +t[0]), (v = +t[1]), n) : [g, v];
}),
(n.precision = function (t) {
return arguments.length
? ((m = +t),
(f = ye(a, o, 90)),
(s = me(r, e, m)),
(h = ye(c, l, 90)),
(p = me(u, i, m)),
n)
: m;
}),
n
.majorExtent([
[-180, -90 + Uo],
[180, 90 - Uo],
])
.minorExtent([
[-180, -80 - Uo],
[180, 80 + Uo],
])
);
}),
(ao.geo.greatArc = function () {
function n() {
return {
type: "LineString",
coordinates: [
t || r.apply(this, arguments),
e || i.apply(this, arguments),
],
};
}
var t,
e,
r = Me,
i = xe;
return (
(n.distance = function () {
return ao.geo.distance(
t || r.apply(this, arguments),
e || i.apply(this, arguments)
);
}),
(n.source = function (e) {
return arguments.length
? ((r = e), (t = "function" == typeof e ? null : e), n)
: r;
}),
(n.target = function (t) {
return arguments.length
? ((i = t), (e = "function" == typeof t ? null : t), n)
: i;
}),
(n.precision = function () {
return arguments.length ? n : 0;
}),
n
);
}),
(ao.geo.interpolate = function (n, t) {
return be(n[0] * Yo, n[1] * Yo, t[0] * Yo, t[1] * Yo);
}),
(ao.geo.length = function (n) {
return (Ja = 0), ao.geo.stream(n, Ga), Ja;
});
var Ja,
Ga = {
sphere: b,
point: b,
lineStart: _e,
lineEnd: b,
polygonStart: b,
polygonEnd: b,
},
Ka = we(
function (n) {
return Math.sqrt(2 / (1 + n));
},
function (n) {
return 2 * Math.asin(n / 2);
}
);
(ao.geo.azimuthalEqualArea = function () {
return oe(Ka);
}).raw = Ka;
var Qa = we(function (n) {
var t = Math.acos(n);
return t && t / Math.sin(t);
}, m);
((ao.geo.azimuthalEquidistant = function () {
return oe(Qa);
}).raw = Qa),
((ao.geo.conicConformal = function () {
return Vt(Se);
}).raw = Se),
((ao.geo.conicEquidistant = function () {
return Vt(ke);
}).raw = ke);
var nl = we(function (n) {
return 1 / n;
}, Math.atan);
((ao.geo.gnomonic = function () {
return oe(nl);
}).raw = nl),
(Ne.invert = function (n, t) {
return [n, 2 * Math.atan(Math.exp(t)) - Io];
}),
((ao.geo.mercator = function () {
return Ee(Ne);
}).raw = Ne);
var tl = we(function () {
return 1;
}, Math.asin);
(ao.geo.orthographic = function () {
return oe(tl);
}).raw = tl;
var el = we(
function (n) {
return 1 / (1 + n);
},
function (n) {
return 2 * Math.atan(n);
}
);
((ao.geo.stereographic = function () {
return oe(el);
}).raw = el),
(Ae.invert = function (n, t) {
return [-t, 2 * Math.atan(Math.exp(n)) - Io];
}),
((ao.geo.transverseMercator = function () {
var n = Ee(Ae),
t = n.center,
e = n.rotate;
return (
(n.center = function (n) {
return n ? t([-n[1], n[0]]) : ((n = t()), [n[1], -n[0]]);
}),
(n.rotate = function (n) {
return n
? e([n[0], n[1], n.length > 2 ? n[2] + 90 : 90])
: ((n = e()), [n[0], n[1], n[2] - 90]);
}),
e([0, 0, 90])
);
}).raw = Ae),
(ao.geom = {}),
(ao.geom.hull = function (n) {
function t(n) {
if (n.length < 3) return [];
var t,
i = En(e),
u = En(r),
o = n.length,
a = [],
l = [];
for (t = 0; o > t; t++)
a.push([+i.call(this, n[t], t), +u.call(this, n[t], t), t]);
for (a.sort(qe), t = 0; o > t; t++) l.push([a[t][0], -a[t][1]]);
var c = Le(a),
f = Le(l),
s = f[0] === c[0],
h = f[f.length - 1] === c[c.length - 1],
p = [];
for (t = c.length - 1; t >= 0; --t) p.push(n[a[c[t]][2]]);
for (t = +s; t < f.length - h; ++t) p.push(n[a[f[t]][2]]);
return p;
}
var e = Ce,
r = ze;
return arguments.length
? t(n)
: ((t.x = function (n) {
return arguments.length ? ((e = n), t) : e;
}),
(t.y = function (n) {
return arguments.length ? ((r = n), t) : r;
}),
t);
}),
(ao.geom.polygon = function (n) {
return ko(n, rl), n;
});
var rl = (ao.geom.polygon.prototype = []);
(rl.area = function () {
for (var n, t = -1, e = this.length, r = this[e - 1], i = 0; ++t < e; )
(n = r), (r = this[t]), (i += n[1] * r[0] - n[0] * r[1]);
return 0.5 * i;
}),
(rl.centroid = function (n) {
var t,
e,
r = -1,
i = this.length,
u = 0,
o = 0,
a = this[i - 1];
for (arguments.length || (n = -1 / (6 * this.area())); ++r < i; )
(t = a),
(a = this[r]),
(e = t[0] * a[1] - a[0] * t[1]),
(u += (t[0] + a[0]) * e),
(o += (t[1] + a[1]) * e);
return [u * n, o * n];
}),
(rl.clip = function (n) {
for (
var t,
e,
r,
i,
u,
o,
a = De(n),
l = -1,
c = this.length - De(this),
f = this[c - 1];
++l < c;
) {
for (
t = n.slice(),
n.length = 0,
i = this[l],
u = t[(r = t.length - a) - 1],
e = -1;
++e < r;
)
(o = t[e]),
Te(o, f, i)
? (Te(u, f, i) || n.push(Re(u, o, f, i)), n.push(o))
: Te(u, f, i) && n.push(Re(u, o, f, i)),
(u = o);
a && n.push(n[0]), (f = i);
}
return n;
});
var il,
ul,
ol,
al,
ll,
cl = [],
fl = [];
(Ye.prototype.prepare = function () {
for (var n, t = this.edges, e = t.length; e--; )
(n = t[e].edge), (n.b && n.a) || t.splice(e, 1);
return t.sort(Ve), t.length;
}),
(tr.prototype = {
start: function () {
return this.edge.l === this.site ? this.edge.a : this.edge.b;
},
end: function () {
return this.edge.l === this.site ? this.edge.b : this.edge.a;
},
}),
(er.prototype = {
insert: function (n, t) {
var e, r, i;
if (n) {
if (((t.P = n), (t.N = n.N), n.N && (n.N.P = t), (n.N = t), n.R)) {
for (n = n.R; n.L; ) n = n.L;
n.L = t;
} else n.R = t;
e = n;
} else
this._
? ((n = or(this._)),
(t.P = null),
(t.N = n),
(n.P = n.L = t),
(e = n))
: ((t.P = t.N = null), (this._ = t), (e = null));
for (t.L = t.R = null, t.U = e, t.C = !0, n = t; e && e.C; )
(r = e.U),
e === r.L
? ((i = r.R),
i && i.C
? ((e.C = i.C = !1), (r.C = !0), (n = r))
: (n === e.R && (ir(this, e), (n = e), (e = n.U)),
(e.C = !1),
(r.C = !0),
ur(this, r)))
: ((i = r.L),
i && i.C
? ((e.C = i.C = !1), (r.C = !0), (n = r))
: (n === e.L && (ur(this, e), (n = e), (e = n.U)),
(e.C = !1),
(r.C = !0),
ir(this, r))),
(e = n.U);
this._.C = !1;
},
remove: function (n) {
n.N && (n.N.P = n.P), n.P && (n.P.N = n.N), (n.N = n.P = null);
var t,
e,
r,
i = n.U,
u = n.L,
o = n.R;
if (
((e = u ? (o ? or(o) : u) : o),
i ? (i.L === n ? (i.L = e) : (i.R = e)) : (this._ = e),
u && o
? ((r = e.C),
(e.C = n.C),
(e.L = u),
(u.U = e),
e !== o
? ((i = e.U),
(e.U = n.U),
(n = e.R),
(i.L = n),
(e.R = o),
(o.U = e))
: ((e.U = i), (i = e), (n = e.R)))
: ((r = n.C), (n = e)),
n && (n.U = i),
!r)
) {
if (n && n.C) return void (n.C = !1);
do {
if (n === this._) break;
if (n === i.L) {
if (
((t = i.R),
t.C && ((t.C = !1), (i.C = !0), ir(this, i), (t = i.R)),
(t.L && t.L.C) || (t.R && t.R.C))
) {
(t.R && t.R.C) ||
((t.L.C = !1), (t.C = !0), ur(this, t), (t = i.R)),
(t.C = i.C),
(i.C = t.R.C = !1),
ir(this, i),
(n = this._);
break;
}
} else if (
((t = i.L),
t.C && ((t.C = !1), (i.C = !0), ur(this, i), (t = i.L)),
(t.L && t.L.C) || (t.R && t.R.C))
) {
(t.L && t.L.C) ||
((t.R.C = !1), (t.C = !0), ir(this, t), (t = i.L)),
(t.C = i.C),
(i.C = t.L.C = !1),
ur(this, i),
(n = this._);
break;
}
(t.C = !0), (n = i), (i = i.U);
} while (!n.C);
n && (n.C = !1);
}
},
}),
(ao.geom.voronoi = function (n) {
function t(n) {
var t = new Array(n.length),
r = a[0][0],
i = a[0][1],
u = a[1][0],
o = a[1][1];
return (
ar(e(n), a).cells.forEach(function (e, a) {
var l = e.edges,
c = e.site,
f = (t[a] = l.length
? l.map(function (n) {
var t = n.start();
return [t.x, t.y];
})
: c.x >= r && c.x <= u && c.y >= i && c.y <= o
? [
[r, o],
[u, o],
[u, i],
[r, i],
]
: []);
f.point = n[a];
}),
t
);
}
function e(n) {
return n.map(function (n, t) {
return {
x: Math.round(u(n, t) / Uo) * Uo,
y: Math.round(o(n, t) / Uo) * Uo,
i: t,
};
});
}
var r = Ce,
i = ze,
u = r,
o = i,
a = sl;
return n
? t(n)
: ((t.links = function (n) {
return ar(e(n))
.edges.filter(function (n) {
return n.l && n.r;
})
.map(function (t) {
return { source: n[t.l.i], target: n[t.r.i] };
});
}),
(t.triangles = function (n) {
var t = [];
return (
ar(e(n)).cells.forEach(function (e, r) {
for (
var i,
u,
o = e.site,
a = e.edges.sort(Ve),
l = -1,
c = a.length,
f = a[c - 1].edge,
s = f.l === o ? f.r : f.l;
++l < c;
)
(i = f),
(u = s),
(f = a[l].edge),
(s = f.l === o ? f.r : f.l),
r < u.i &&
r < s.i &&
cr(o, u, s) < 0 &&
t.push([n[r], n[u.i], n[s.i]]);
}),
t
);
}),
(t.x = function (n) {
return arguments.length ? ((u = En((r = n))), t) : r;
}),
(t.y = function (n) {
return arguments.length ? ((o = En((i = n))), t) : i;
}),
(t.clipExtent = function (n) {
return arguments.length
? ((a = null == n ? sl : n), t)
: a === sl
? null
: a;
}),
(t.size = function (n) {
return arguments.length
? t.clipExtent(n && [[0, 0], n])
: a === sl
? null
: a && a[1];
}),
t);
});
var sl = [
[-1e6, -1e6],
[1e6, 1e6],
];
(ao.geom.delaunay = function (n) {
return ao.geom.voronoi().triangles(n);
}),
(ao.geom.quadtree = function (n, t, e, r, i) {
function u(n) {
function u(n, t, e, r, i, u, o, a) {
if (!isNaN(e) && !isNaN(r))
if (n.leaf) {
var l = n.x,
f = n.y;
if (null != l)
if (xo(l - e) + xo(f - r) < 0.01) c(n, t, e, r, i, u, o, a);
else {
var s = n.point;
(n.x = n.y = n.point = null),
c(n, s, l, f, i, u, o, a),
c(n, t, e, r, i, u, o, a);
}
else (n.x = e), (n.y = r), (n.point = t);
} else c(n, t, e, r, i, u, o, a);
}
function c(n, t, e, r, i, o, a, l) {
var c = 0.5 * (i + a),
f = 0.5 * (o + l),
s = e >= c,
h = r >= f,
p = (h << 1) | s;
(n.leaf = !1),
(n = n.nodes[p] || (n.nodes[p] = hr())),
s ? (i = c) : (a = c),
h ? (o = f) : (l = f),
u(n, t, e, r, i, o, a, l);
}
var f,
s,
h,
p,
g,
v,
d,
y,
m,
M = En(a),
x = En(l);
if (null != t) (v = t), (d = e), (y = r), (m = i);
else if (
((y = m = -(v = d = 1 / 0)), (s = []), (h = []), (g = n.length), o)
)
for (p = 0; g > p; ++p)
(f = n[p]),
f.x < v && (v = f.x),
f.y < d && (d = f.y),
f.x > y && (y = f.x),
f.y > m && (m = f.y),
s.push(f.x),
h.push(f.y);
else
for (p = 0; g > p; ++p) {
var b = +M((f = n[p]), p),
_ = +x(f, p);
v > b && (v = b),
d > _ && (d = _),
b > y && (y = b),
_ > m && (m = _),
s.push(b),
h.push(_);
}
var w = y - v,
S = m - d;
w > S ? (m = d + w) : (y = v + S);
var k = hr();
if (
((k.add = function (n) {
u(k, n, +M(n, ++p), +x(n, p), v, d, y, m);
}),
(k.visit = function (n) {
pr(n, k, v, d, y, m);
}),
(k.find = function (n) {
return gr(k, n[0], n[1], v, d, y, m);
}),
(p = -1),
null == t)
) {
for (; ++p < g; ) u(k, n[p], s[p], h[p], v, d, y, m);
--p;
} else n.forEach(k.add);
return (s = h = n = f = null), k;
}
var o,
a = Ce,
l = ze;
return (o = arguments.length)
? ((a = fr), (l = sr), 3 === o && ((i = e), (r = t), (e = t = 0)), u(n))
: ((u.x = function (n) {
return arguments.length ? ((a = n), u) : a;
}),
(u.y = function (n) {
return arguments.length ? ((l = n), u) : l;
}),
(u.extent = function (n) {
return arguments.length
? (null == n
? (t = e = r = i = null)
: ((t = +n[0][0]),
(e = +n[0][1]),
(r = +n[1][0]),
(i = +n[1][1])),
u)
: null == t
? null
: [
[t, e],
[r, i],
];
}),
(u.size = function (n) {
return arguments.length
? (null == n
? (t = e = r = i = null)
: ((t = e = 0), (r = +n[0]), (i = +n[1])),
u)
: null == t
? null
: [r - t, i - e];
}),
u);
}),
(ao.interpolateRgb = vr),
(ao.interpolateObject = dr),
(ao.interpolateNumber = yr),
(ao.interpolateString = mr);
var hl = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,
pl = new RegExp(hl.source, "g");
(ao.interpolate = Mr),
(ao.interpolators = [
function (n, t) {
var e = typeof t;
return (
"string" === e
? ua.has(t.toLowerCase()) || /^(#|rgb\(|hsl\()/i.test(t)
? vr
: mr
: t instanceof an
? vr
: Array.isArray(t)
? xr
: "object" === e && isNaN(t)
? dr
: yr
)(n, t);
},
]),
(ao.interpolateArray = xr);
var gl = function () {
return m;
},
vl = ao.map({
linear: gl,
poly: Er,
quad: function () {
return Sr;
},
cubic: function () {
return kr;
},
sin: function () {
return Ar;
},
exp: function () {
return Cr;
},
circle: function () {
return zr;
},
elastic: Lr,
back: qr,
bounce: function () {
return Tr;
},
}),
dl = ao.map({
in: m,
out: _r,
"in-out": wr,
"out-in": function (n) {
return wr(_r(n));
},
});
(ao.ease = function (n) {
var t = n.indexOf("-"),
e = t >= 0 ? n.slice(0, t) : n,
r = t >= 0 ? n.slice(t + 1) : "in";
return (
(e = vl.get(e) || gl),
(r = dl.get(r) || m),
br(r(e.apply(null, lo.call(arguments, 1))))
);
}),
(ao.interpolateHcl = Rr),
(ao.interpolateHsl = Dr),
(ao.interpolateLab = Pr),
(ao.interpolateRound = Ur),
(ao.transform = function (n) {
var t = fo.createElementNS(ao.ns.prefix.svg, "g");
return (ao.transform = function (n) {
if (null != n) {
t.setAttribute("transform", n);
var e = t.transform.baseVal.consolidate();
}
return new jr(e ? e.matrix : yl);
})(n);
}),
(jr.prototype.toString = function () {
return (
"translate(" +
this.translate +
")rotate(" +
this.rotate +
")skewX(" +
this.skew +
")scale(" +
this.scale +
")"
);
});
var yl = { a: 1, b: 0, c: 0, d: 1, e: 0, f: 0 };
(ao.interpolateTransform = $r),
(ao.layout = {}),
(ao.layout.bundle = function () {
return function (n) {
for (var t = [], e = -1, r = n.length; ++e < r; ) t.push(Jr(n[e]));
return t;
};
}),
(ao.layout.chord = function () {
function n() {
var n,
c,
s,
h,
p,
g = {},
v = [],
d = ao.range(u),
y = [];
for (e = [], r = [], n = 0, h = -1; ++h < u; ) {
for (c = 0, p = -1; ++p < u; ) c += i[h][p];
v.push(c), y.push(ao.range(u)), (n += c);
}
for (
o &&
d.sort(function (n, t) {
return o(v[n], v[t]);
}),
a &&
y.forEach(function (n, t) {
n.sort(function (n, e) {
return a(i[t][n], i[t][e]);
});
}),
n = (Ho - f * u) / n,
c = 0,
h = -1;
++h < u;
) {
for (s = c, p = -1; ++p < u; ) {
var m = d[h],
M = y[m][p],
x = i[m][M],
b = c,
_ = (c += x * n);
g[m + "-" + M] = {
index: m,
subindex: M,
startAngle: b,
endAngle: _,
value: x,
};
}
(r[m] = { index: m, startAngle: s, endAngle: c, value: v[m] }),
(c += f);
}
for (h = -1; ++h < u; )
for (p = h - 1; ++p < u; ) {
var w = g[h + "-" + p],
S = g[p + "-" + h];
(w.value || S.value) &&
e.push(
w.value < S.value
? { source: S, target: w }
: { source: w, target: S }
);
}
l && t();
}
function t() {
e.sort(function (n, t) {
return l(
(n.source.value + n.target.value) / 2,
(t.source.value + t.target.value) / 2
);
});
}
var e,
r,
i,
u,
o,
a,
l,
c = {},
f = 0;
return (
(c.matrix = function (n) {
return arguments.length
? ((u = (i = n) && i.length), (e = r = null), c)
: i;
}),
(c.padding = function (n) {
return arguments.length ? ((f = n), (e = r = null), c) : f;
}),
(c.sortGroups = function (n) {
return arguments.length ? ((o = n), (e = r = null), c) : o;
}),
(c.sortSubgroups = function (n) {
return arguments.length ? ((a = n), (e = null), c) : a;
}),
(c.sortChords = function (n) {
return arguments.length ? ((l = n), e && t(), c) : l;
}),
(c.chords = function () {
return e || n(), e;
}),
(c.groups = function () {
return r || n(), r;
}),
c
);
}),
(ao.layout.force = function () {
function n(n) {
return function (t, e, r, i) {
if (t.point !== n) {
var u = t.cx - n.x,
o = t.cy - n.y,
a = i - e,
l = u * u + o * o;
if (l > (a * a) / y) {
if (v > l) {
var c = t.charge / l;
(n.px -= u * c), (n.py -= o * c);
}
return !0;
}
if (t.point && l && v > l) {
var c = t.pointCharge / l;
(n.px -= u * c), (n.py -= o * c);
}
}
return !t.charge;
};
}
function t(n) {
(n.px = ao.event.x), (n.py = ao.event.y), l.resume();
}
var e,
r,
i,
u,
o,
a,
l = {},
c = ao.dispatch("start", "tick", "end"),
f = [1, 1],
s = 0.9,
h = ml,
p = Ml,
g = -30,
v = xl,
d = 0.1,
y = 0.64,
M = [],
x = [];
return (
(l.tick = function () {
if ((i *= 0.99) < 0.005)
return (e = null), c.end({ type: "end", alpha: (i = 0) }), !0;
var t,
r,
l,
h,
p,
v,
y,
m,
b,
_ = M.length,
w = x.length;
for (r = 0; w > r; ++r)
(l = x[r]),
(h = l.source),
(p = l.target),
(m = p.x - h.x),
(b = p.y - h.y),
(v = m * m + b * b) &&
((v = (i * o[r] * ((v = Math.sqrt(v)) - u[r])) / v),
(m *= v),
(b *= v),
(p.x -=
m *
(y =
h.weight + p.weight
? h.weight / (h.weight + p.weight)
: 0.5)),
(p.y -= b * y),
(h.x += m * (y = 1 - y)),
(h.y += b * y));
if ((y = i * d) && ((m = f[0] / 2), (b = f[1] / 2), (r = -1), y))
for (; ++r < _; )
(l = M[r]), (l.x += (m - l.x) * y), (l.y += (b - l.y) * y);
if (g)
for (ri((t = ao.geom.quadtree(M)), i, a), r = -1; ++r < _; )
(l = M[r]).fixed || t.visit(n(l));
for (r = -1; ++r < _; )
(l = M[r]),
l.fixed
? ((l.x = l.px), (l.y = l.py))
: ((l.x -= (l.px - (l.px = l.x)) * s),
(l.y -= (l.py - (l.py = l.y)) * s));
c.tick({ type: "tick", alpha: i });
}),
(l.nodes = function (n) {
return arguments.length ? ((M = n), l) : M;
}),
(l.links = function (n) {
return arguments.length ? ((x = n), l) : x;
}),
(l.size = function (n) {
return arguments.length ? ((f = n), l) : f;
}),
(l.linkDistance = function (n) {
return arguments.length
? ((h = "function" == typeof n ? n : +n), l)
: h;
}),
(l.distance = l.linkDistance),
(l.linkStrength = function (n) {
return arguments.length
? ((p = "function" == typeof n ? n : +n), l)
: p;
}),
(l.friction = function (n) {
return arguments.length ? ((s = +n), l) : s;
}),
(l.charge = function (n) {
return arguments.length
? ((g = "function" == typeof n ? n : +n), l)
: g;
}),
(l.chargeDistance = function (n) {
return arguments.length ? ((v = n * n), l) : Math.sqrt(v);
}),
(l.gravity = function (n) {
return arguments.length ? ((d = +n), l) : d;
}),
(l.theta = function (n) {
return arguments.length ? ((y = n * n), l) : Math.sqrt(y);
}),
(l.alpha = function (n) {
return arguments.length
? ((n = +n),
i
? n > 0
? (i = n)
: ((e.c = null),
(e.t = NaN),
(e = null),
c.end({ type: "end", alpha: (i = 0) }))
: n > 0 &&
(c.start({ type: "start", alpha: (i = n) }),
(e = qn(l.tick))),
l)
: i;
}),
(l.start = function () {
function n(n, r) {
if (!e) {
for (e = new Array(i), l = 0; i > l; ++l) e[l] = [];
for (l = 0; c > l; ++l) {
var u = x[l];
e[u.source.index].push(u.target),
e[u.target.index].push(u.source);
}
}
for (var o, a = e[t], l = -1, f = a.length; ++l < f; )
if (!isNaN((o = a[l][n]))) return o;
return Math.random() * r;
}
var t,
e,
r,
i = M.length,
c = x.length,
s = f[0],
v = f[1];
for (t = 0; i > t; ++t) ((r = M[t]).index = t), (r.weight = 0);
for (t = 0; c > t; ++t)
(r = x[t]),
"number" == typeof r.source && (r.source = M[r.source]),
"number" == typeof r.target && (r.target = M[r.target]),
++r.source.weight,
++r.target.weight;
for (t = 0; i > t; ++t)
(r = M[t]),
isNaN(r.x) && (r.x = n("x", s)),
isNaN(r.y) && (r.y = n("y", v)),
isNaN(r.px) && (r.px = r.x),
isNaN(r.py) && (r.py = r.y);
if (((u = []), "function" == typeof h))
for (t = 0; c > t; ++t) u[t] = +h.call(this, x[t], t);
else for (t = 0; c > t; ++t) u[t] = h;
if (((o = []), "function" == typeof p))
for (t = 0; c > t; ++t) o[t] = +p.call(this, x[t], t);
else for (t = 0; c > t; ++t) o[t] = p;
if (((a = []), "function" == typeof g))
for (t = 0; i > t; ++t) a[t] = +g.call(this, M[t], t);
else for (t = 0; i > t; ++t) a[t] = g;
return l.resume();
}),
(l.resume = function () {
return l.alpha(0.1);
}),
(l.stop = function () {
return l.alpha(0);
}),
(l.drag = function () {
return (
r ||
(r = ao.behavior
.drag()
.origin(m)
.on("dragstart.force", Qr)
.on("drag.force", t)
.on("dragend.force", ni)),
arguments.length
? void this.on("mouseover.force", ti)
.on("mouseout.force", ei)
.call(r)
: r
);
}),
ao.rebind(l, c, "on")
);
});
var ml = 20,
Ml = 1,
xl = 1 / 0;
(ao.layout.hierarchy = function () {
function n(i) {
var u,
o = [i],
a = [];
for (i.depth = 0; null != (u = o.pop()); )
if ((a.push(u), (c = e.call(n, u, u.depth)) && (l = c.length))) {
for (var l, c, f; --l >= 0; )
o.push((f = c[l])), (f.parent = u), (f.depth = u.depth + 1);
r && (u.value = 0), (u.children = c);
} else r && (u.value = +r.call(n, u, u.depth) || 0), delete u.children;
return (
oi(i, function (n) {
var e, i;
t && (e = n.children) && e.sort(t),
r && (i = n.parent) && (i.value += n.value);
}),
a
);
}
var t = ci,
e = ai,
r = li;
return (
(n.sort = function (e) {
return arguments.length ? ((t = e), n) : t;
}),
(n.children = function (t) {
return arguments.length ? ((e = t), n) : e;
}),
(n.value = function (t) {
return arguments.length ? ((r = t), n) : r;
}),
(n.revalue = function (t) {
return (
r &&
(ui(t, function (n) {
n.children && (n.value = 0);
}),
oi(t, function (t) {
var e;
t.children || (t.value = +r.call(n, t, t.depth) || 0),
(e = t.parent) && (e.value += t.value);
})),
t
);
}),
n
);
}),
(ao.layout.partition = function () {
function n(t, e, r, i) {
var u = t.children;
if (
((t.x = e),
(t.y = t.depth * i),
(t.dx = r),
(t.dy = i),
u && (o = u.length))
) {
var o,
a,
l,
c = -1;
for (r = t.value ? r / t.value : 0; ++c < o; )
n((a = u[c]), e, (l = a.value * r), i), (e += l);
}
}
function t(n) {
var e = n.children,
r = 0;
if (e && (i = e.length))
for (var i, u = -1; ++u < i; ) r = Math.max(r, t(e[u]));
return 1 + r;
}
function e(e, u) {
var o = r.call(this, e, u);
return n(o[0], 0, i[0], i[1] / t(o[0])), o;
}
var r = ao.layout.hierarchy(),
i = [1, 1];
return (
(e.size = function (n) {
return arguments.length ? ((i = n), e) : i;
}),
ii(e, r)
);
}),
(ao.layout.pie = function () {
function n(o) {
var a,
l = o.length,
c = o.map(function (e, r) {
return +t.call(n, e, r);
}),
f = +("function" == typeof r ? r.apply(this, arguments) : r),
s = ("function" == typeof i ? i.apply(this, arguments) : i) - f,
h = Math.min(
Math.abs(s) / l,
+("function" == typeof u ? u.apply(this, arguments) : u)
),
p = h * (0 > s ? -1 : 1),
g = ao.sum(c),
v = g ? (s - l * p) / g : 0,
d = ao.range(l),
y = [];
return (
null != e &&
d.sort(
e === bl
? function (n, t) {
return c[t] - c[n];
}
: function (n, t) {
return e(o[n], o[t]);
}
),
d.forEach(function (n) {
y[n] = {
data: o[n],
value: (a = c[n]),
startAngle: f,
endAngle: (f += a * v + p),
padAngle: h,
};
}),
y
);
}
var t = Number,
e = bl,
r = 0,
i = Ho,
u = 0;
return (
(n.value = function (e) {
return arguments.length ? ((t = e), n) : t;
}),
(n.sort = function (t) {
return arguments.length ? ((e = t), n) : e;
}),
(n.startAngle = function (t) {
return arguments.length ? ((r = t), n) : r;
}),
(n.endAngle = function (t) {
return arguments.length ? ((i = t), n) : i;
}),
(n.padAngle = function (t) {
return arguments.length ? ((u = t), n) : u;
}),
n
);
});
var bl = {};
ao.layout.stack = function () {
function n(a, l) {
if (!(h = a.length)) return a;
var c = a.map(function (e, r) {
return t.call(n, e, r);
}),
f = c.map(function (t) {
return t.map(function (t, e) {
return [u.call(n, t, e), o.call(n, t, e)];
});
}),
s = e.call(n, f, l);
(c = ao.permute(c, s)), (f = ao.permute(f, s));
var h,
p,
g,
v,
d = r.call(n, f, l),
y = c[0].length;
for (g = 0; y > g; ++g)
for (i.call(n, c[0][g], (v = d[g]), f[0][g][1]), p = 1; h > p; ++p)
i.call(n, c[p][g], (v += f[p - 1][g][1]), f[p][g][1]);
return a;
}
var t = m,
e = gi,
r = vi,
i = pi,
u = si,
o = hi;
return (
(n.values = function (e) {
return arguments.length ? ((t = e), n) : t;
}),
(n.order = function (t) {
return arguments.length
? ((e = "function" == typeof t ? t : _l.get(t) || gi), n)
: e;
}),
(n.offset = function (t) {
return arguments.length
? ((r = "function" == typeof t ? t : wl.get(t) || vi), n)
: r;
}),
(n.x = function (t) {
return arguments.length ? ((u = t), n) : u;
}),
(n.y = function (t) {
return arguments.length ? ((o = t), n) : o;
}),
(n.out = function (t) {
return arguments.length ? ((i = t), n) : i;
}),
n
);
};
var _l = ao.map({
"inside-out": function (n) {
var t,
e,
r = n.length,
i = n.map(di),
u = n.map(yi),
o = ao.range(r).sort(function (n, t) {
return i[n] - i[t];
}),
a = 0,
l = 0,
c = [],
f = [];
for (t = 0; r > t; ++t)
(e = o[t]),
l > a ? ((a += u[e]), c.push(e)) : ((l += u[e]), f.push(e));
return f.reverse().concat(c);
},
reverse: function (n) {
return ao.range(n.length).reverse();
},
default: gi,
}),
wl = ao.map({
silhouette: function (n) {
var t,
e,
r,
i = n.length,
u = n[0].length,
o = [],
a = 0,
l = [];
for (e = 0; u > e; ++e) {
for (t = 0, r = 0; i > t; t++) r += n[t][e][1];
r > a && (a = r), o.push(r);
}
for (e = 0; u > e; ++e) l[e] = (a - o[e]) / 2;
return l;
},
wiggle: function (n) {
var t,
e,
r,
i,
u,
o,
a,
l,
c,
f = n.length,
s = n[0],
h = s.length,
p = [];
for (p[0] = l = c = 0, e = 1; h > e; ++e) {
for (t = 0, i = 0; f > t; ++t) i += n[t][e][1];
for (t = 0, u = 0, a = s[e][0] - s[e - 1][0]; f > t; ++t) {
for (r = 0, o = (n[t][e][1] - n[t][e - 1][1]) / (2 * a); t > r; ++r)
o += (n[r][e][1] - n[r][e - 1][1]) / a;
u += o * n[t][e][1];
}
(p[e] = l -= i ? (u / i) * a : 0), c > l && (c = l);
}
for (e = 0; h > e; ++e) p[e] -= c;
return p;
},
expand: function (n) {
var t,
e,
r,
i = n.length,
u = n[0].length,
o = 1 / i,
a = [];
for (e = 0; u > e; ++e) {
for (t = 0, r = 0; i > t; t++) r += n[t][e][1];
if (r) for (t = 0; i > t; t++) n[t][e][1] /= r;
else for (t = 0; i > t; t++) n[t][e][1] = o;
}
for (e = 0; u > e; ++e) a[e] = 0;
return a;
},
zero: vi,
});
(ao.layout.histogram = function () {
function n(n, u) {
for (
var o,
a,
l = [],
c = n.map(e, this),
f = r.call(this, c, u),
s = i.call(this, f, c, u),
u = -1,
h = c.length,
p = s.length - 1,
g = t ? 1 : 1 / h;
++u < p;
)
(o = l[u] = []), (o.dx = s[u + 1] - (o.x = s[u])), (o.y = 0);
if (p > 0)
for (u = -1; ++u < h; )
(a = c[u]),
a >= f[0] &&
a <= f[1] &&
((o = l[ao.bisect(s, a, 1, p) - 1]), (o.y += g), o.push(n[u]));
return l;
}
var t = !0,
e = Number,
r = bi,
i = Mi;
return (
(n.value = function (t) {
return arguments.length ? ((e = t), n) : e;
}),
(n.range = function (t) {
return arguments.length ? ((r = En(t)), n) : r;
}),
(n.bins = function (t) {
return arguments.length
? ((i =
"number" == typeof t
? function (n) {
return xi(n, t);
}
: En(t)),
n)
: i;
}),
(n.frequency = function (e) {
return arguments.length ? ((t = !!e), n) : t;
}),
n
);
}),
(ao.layout.pack = function () {
function n(n, u) {
var o = e.call(this, n, u),
a = o[0],
l = i[0],
c = i[1],
f =
null == t
? Math.sqrt
: "function" == typeof t
? t
: function () {
return t;
};
if (
((a.x = a.y = 0),
oi(a, function (n) {
n.r = +f(n.value);
}),
oi(a, Ni),
r)
) {
var s = (r * (t ? 1 : Math.max((2 * a.r) / l, (2 * a.r) / c))) / 2;
oi(a, function (n) {
n.r += s;
}),
oi(a, Ni),
oi(a, function (n) {
n.r -= s;
});
}
return (
Ci(
a,
l / 2,
c / 2,
t ? 1 : 1 / Math.max((2 * a.r) / l, (2 * a.r) / c)
),
o
);
}
var t,
e = ao.layout.hierarchy().sort(_i),
r = 0,
i = [1, 1];
return (
(n.size = function (t) {
return arguments.length ? ((i = t), n) : i;
}),
(n.radius = function (e) {
return arguments.length
? ((t = null == e || "function" == typeof e ? e : +e), n)
: t;
}),
(n.padding = function (t) {
return arguments.length ? ((r = +t), n) : r;
}),
ii(n, e)
);
}),
(ao.layout.tree = function () {
function n(n, i) {
var f = o.call(this, n, i),
s = f[0],
h = t(s);
if ((oi(h, e), (h.parent.m = -h.z), ui(h, r), c)) ui(s, u);
else {
var p = s,
g = s,
v = s;
ui(s, function (n) {
n.x < p.x && (p = n),
n.x > g.x && (g = n),
n.depth > v.depth && (v = n);
});
var d = a(p, g) / 2 - p.x,
y = l[0] / (g.x + a(g, p) / 2 + d),
m = l[1] / (v.depth || 1);
ui(s, function (n) {
(n.x = (n.x + d) * y), (n.y = n.depth * m);
});
}
return f;
}
function t(n) {
for (
var t, e = { A: null, children: [n] }, r = [e];
null != (t = r.pop());
)
for (var i, u = t.children, o = 0, a = u.length; a > o; ++o)
r.push(
((u[o] = i =
{
_: u[o],
parent: t,
children: ((i = u[o].children) && i.slice()) || [],
A: null,
a: null,
z: 0,
m: 0,
c: 0,
s: 0,
t: null,
i: o,
}).a = i)
);
return e.children[0];
}
function e(n) {
var t = n.children,
e = n.parent.children,
r = n.i ? e[n.i - 1] : null;
if (t.length) {
Di(n);
var u = (t[0].z + t[t.length - 1].z) / 2;
r ? ((n.z = r.z + a(n._, r._)), (n.m = n.z - u)) : (n.z = u);
} else r && (n.z = r.z + a(n._, r._));
n.parent.A = i(n, r, n.parent.A || e[0]);
}
function r(n) {
(n._.x = n.z + n.parent.m), (n.m += n.parent.m);
}
function i(n, t, e) {
if (t) {
for (
var r,
i = n,
u = n,
o = t,
l = i.parent.children[0],
c = i.m,
f = u.m,
s = o.m,
h = l.m;
(o = Ti(o)), (i = qi(i)), o && i;
)
(l = qi(l)),
(u = Ti(u)),
(u.a = n),
(r = o.z + s - i.z - c + a(o._, i._)),
r > 0 && (Ri(Pi(o, n, e), n, r), (c += r), (f += r)),
(s += o.m),
(c += i.m),
(h += l.m),
(f += u.m);
o && !Ti(u) && ((u.t = o), (u.m += s - f)),
i && !qi(l) && ((l.t = i), (l.m += c - h), (e = n));
}
return e;
}
function u(n) {
(n.x *= l[0]), (n.y = n.depth * l[1]);
}
var o = ao.layout.hierarchy().sort(null).value(null),
a = Li,
l = [1, 1],
c = null;
return (
(n.separation = function (t) {
return arguments.length ? ((a = t), n) : a;
}),
(n.size = function (t) {
return arguments.length
? ((c = null == (l = t) ? u : null), n)
: c
? null
: l;
}),
(n.nodeSize = function (t) {
return arguments.length
? ((c = null == (l = t) ? null : u), n)
: c
? l
: null;
}),
ii(n, o)
);
}),
(ao.layout.cluster = function () {
function n(n, u) {
var o,
a = t.call(this, n, u),
l = a[0],
c = 0;
oi(l, function (n) {
var t = n.children;
t && t.length
? ((n.x = ji(t)), (n.y = Ui(t)))
: ((n.x = o ? (c += e(n, o)) : 0), (n.y = 0), (o = n));
});
var f = Fi(l),
s = Hi(l),
h = f.x - e(f, s) / 2,
p = s.x + e(s, f) / 2;
return (
oi(
l,
i
? function (n) {
(n.x = (n.x - l.x) * r[0]), (n.y = (l.y - n.y) * r[1]);
}
: function (n) {
(n.x = ((n.x - h) / (p - h)) * r[0]),
(n.y = (1 - (l.y ? n.y / l.y : 1)) * r[1]);
}
),
a
);
}
var t = ao.layout.hierarchy().sort(null).value(null),
e = Li,
r = [1, 1],
i = !1;
return (
(n.separation = function (t) {
return arguments.length ? ((e = t), n) : e;
}),
(n.size = function (t) {
return arguments.length ? ((i = null == (r = t)), n) : i ? null : r;
}),
(n.nodeSize = function (t) {
return arguments.length ? ((i = null != (r = t)), n) : i ? r : null;
}),
ii(n, t)
);
}),
(ao.layout.treemap = function () {
function n(n, t) {
for (var e, r, i = -1, u = n.length; ++i < u; )
(r = (e = n[i]).value * (0 > t ? 0 : t)),
(e.area = isNaN(r) || 0 >= r ? 0 : r);
}
function t(e) {
var u = e.children;
if (u && u.length) {
var o,
a,
l,
c = s(e),
f = [],
h = u.slice(),
g = 1 / 0,
v =
"slice" === p
? c.dx
: "dice" === p
? c.dy
: "slice-dice" === p
? 1 & e.depth
? c.dy
: c.dx
: Math.min(c.dx, c.dy);
for (n(h, (c.dx * c.dy) / e.value), f.area = 0; (l = h.length) > 0; )
f.push((o = h[l - 1])),
(f.area += o.area),
"squarify" !== p || (a = r(f, v)) <= g
? (h.pop(), (g = a))
: ((f.area -= f.pop().area),
i(f, v, c, !1),
(v = Math.min(c.dx, c.dy)),
(f.length = f.area = 0),
(g = 1 / 0));
f.length && (i(f, v, c, !0), (f.length = f.area = 0)), u.forEach(t);
}
}
function e(t) {
var r = t.children;
if (r && r.length) {
var u,
o = s(t),
a = r.slice(),
l = [];
for (n(a, (o.dx * o.dy) / t.value), l.area = 0; (u = a.pop()); )
l.push(u),
(l.area += u.area),
null != u.z &&
(i(l, u.z ? o.dx : o.dy, o, !a.length),
(l.length = l.area = 0));
r.forEach(e);
}
}
function r(n, t) {
for (
var e, r = n.area, i = 0, u = 1 / 0, o = -1, a = n.length;
++o < a;
)
(e = n[o].area) && (u > e && (u = e), e > i && (i = e));
return (
(r *= r),
(t *= t),
r ? Math.max((t * i * g) / r, r / (t * u * g)) : 1 / 0
);
}
function i(n, t, e, r) {
var i,
u = -1,
o = n.length,
a = e.x,
c = e.y,
f = t ? l(n.area / t) : 0;
if (t == e.dx) {
for ((r || f > e.dy) && (f = e.dy); ++u < o; )
(i = n[u]),
(i.x = a),
(i.y = c),
(i.dy = f),
(a += i.dx = Math.min(e.x + e.dx - a, f ? l(i.area / f) : 0));
(i.z = !0), (i.dx += e.x + e.dx - a), (e.y += f), (e.dy -= f);
} else {
for ((r || f > e.dx) && (f = e.dx); ++u < o; )
(i = n[u]),
(i.x = a),
(i.y = c),
(i.dx = f),
(c += i.dy = Math.min(e.y + e.dy - c, f ? l(i.area / f) : 0));
(i.z = !1), (i.dy += e.y + e.dy - c), (e.x += f), (e.dx -= f);
}
}
function u(r) {
var i = o || a(r),
u = i[0];
return (
(u.x = u.y = 0),
u.value ? ((u.dx = c[0]), (u.dy = c[1])) : (u.dx = u.dy = 0),
o && a.revalue(u),
n([u], (u.dx * u.dy) / u.value),
(o ? e : t)(u),
h && (o = i),
i
);
}
var o,
a = ao.layout.hierarchy(),
l = Math.round,
c = [1, 1],
f = null,
s = Oi,
h = !1,
p = "squarify",
g = 0.5 * (1 + Math.sqrt(5));
return (
(u.size = function (n) {
return arguments.length ? ((c = n), u) : c;
}),
(u.padding = function (n) {
function t(t) {
var e = n.call(u, t, t.depth);
return null == e
? Oi(t)
: Ii(t, "number" == typeof e ? [e, e, e, e] : e);
}
function e(t) {
return Ii(t, n);
}
if (!arguments.length) return f;
var r;
return (
(s =
null == (f = n)
? Oi
: "function" == (r = typeof n)
? t
: "number" === r
? ((n = [n, n, n, n]), e)
: e),
u
);
}),
(u.round = function (n) {
return arguments.length
? ((l = n ? Math.round : Number), u)
: l != Number;
}),
(u.sticky = function (n) {
return arguments.length ? ((h = n), (o = null), u) : h;
}),
(u.ratio = function (n) {
return arguments.length ? ((g = n), u) : g;
}),
(u.mode = function (n) {
return arguments.length ? ((p = n + ""), u) : p;
}),
ii(u, a)
);
}),
(ao.random = {
normal: function (n, t) {
var e = arguments.length;
return (
2 > e && (t = 1),
1 > e && (n = 0),
function () {
var e, r, i;
do
(e = 2 * Math.random() - 1),
(r = 2 * Math.random() - 1),
(i = e * e + r * r);
while (!i || i > 1);
return n + t * e * Math.sqrt((-2 * Math.log(i)) / i);
}
);
},
logNormal: function () {
var n = ao.random.normal.apply(ao, arguments);
return function () {
return Math.exp(n());
};
},
bates: function (n) {
var t = ao.random.irwinHall(n);
return function () {
return t() / n;
};
},
irwinHall: function (n) {
return function () {
for (var t = 0, e = 0; n > e; e++) t += Math.random();
return t;
};
},
}),
(ao.scale = {});
var Sl = { floor: m, ceil: m };
ao.scale.linear = function () {
return Wi([0, 1], [0, 1], Mr, !1);
};
var kl = { s: 1, g: 1, p: 1, r: 1, e: 1 };
ao.scale.log = function () {
return ru(ao.scale.linear().domain([0, 1]), 10, !0, [1, 10]);
};
var Nl = ao.format(".0e"),
El = {
floor: function (n) {
return -Math.ceil(-n);
},
ceil: function (n) {
return -Math.floor(-n);
},
};
(ao.scale.pow = function () {
return iu(ao.scale.linear(), 1, [0, 1]);
}),
(ao.scale.sqrt = function () {
return ao.scale.pow().exponent(0.5);
}),
(ao.scale.ordinal = function () {
return ou([], { t: "range", a: [[]] });
}),
(ao.scale.category10 = function () {
return ao.scale.ordinal().range(Al);
}),
(ao.scale.category20 = function () {
return ao.scale.ordinal().range(Cl);
}),
(ao.scale.category20b = function () {
return ao.scale.ordinal().range(zl);
}),
(ao.scale.category20c = function () {
return ao.scale.ordinal().range(Ll);
});
var Al = [
2062260, 16744206, 2924588, 14034728, 9725885, 9197131, 14907330, 8355711,
12369186, 1556175,
].map(xn),
Cl = [
2062260, 11454440, 16744206, 16759672, 2924588, 10018698, 14034728,
16750742, 9725885, 12955861, 9197131, 12885140, 14907330, 16234194,
8355711, 13092807, 12369186, 14408589, 1556175, 10410725,
].map(xn),
zl = [
3750777, 5395619, 7040719, 10264286, 6519097, 9216594, 11915115, 13556636,
9202993, 12426809, 15186514, 15190932, 8666169, 11356490, 14049643,
15177372, 8077683, 10834324, 13528509, 14589654,
].map(xn),
Ll = [
3244733, 7057110, 10406625, 13032431, 15095053, 16616764, 16625259,
16634018, 3253076, 7652470, 10607003, 13101504, 7695281, 10394312,
12369372, 14342891, 6513507, 9868950, 12434877, 14277081,
].map(xn);
(ao.scale.quantile = function () {
return au([], []);
}),
(ao.scale.quantize = function () {
return lu(0, 1, [0, 1]);
}),
(ao.scale.threshold = function () {
return cu([0.5], [0, 1]);
}),
(ao.scale.identity = function () {
return fu([0, 1]);
}),
(ao.svg = {}),
(ao.svg.arc = function () {
function n() {
var n = Math.max(0, +e.apply(this, arguments)),
c = Math.max(0, +r.apply(this, arguments)),
f = o.apply(this, arguments) - Io,
s = a.apply(this, arguments) - Io,
h = Math.abs(s - f),
p = f > s ? 0 : 1;
if ((n > c && ((g = c), (c = n), (n = g)), h >= Oo))
return t(c, p) + (n ? t(n, 1 - p) : "") + "Z";
var g,
v,
d,
y,
m,
M,
x,
b,
_,
w,
S,
k,
N = 0,
E = 0,
A = [];
if (
((y = (+l.apply(this, arguments) || 0) / 2) &&
((d =
u === ql ? Math.sqrt(n * n + c * c) : +u.apply(this, arguments)),
p || (E *= -1),
c && (E = tn((d / c) * Math.sin(y))),
n && (N = tn((d / n) * Math.sin(y)))),
c)
) {
(m = c * Math.cos(f + E)),
(M = c * Math.sin(f + E)),
(x = c * Math.cos(s - E)),
(b = c * Math.sin(s - E));
var C = Math.abs(s - f - 2 * E) <= Fo ? 0 : 1;
if (E && (yu(m, M, x, b) === p) ^ C) {
var z = (f + s) / 2;
(m = c * Math.cos(z)), (M = c * Math.sin(z)), (x = b = null);
}
} else m = M = 0;
if (n) {
(_ = n * Math.cos(s - N)),
(w = n * Math.sin(s - N)),
(S = n * Math.cos(f + N)),
(k = n * Math.sin(f + N));
var L = Math.abs(f - s + 2 * N) <= Fo ? 0 : 1;
if (N && (yu(_, w, S, k) === 1 - p) ^ L) {
var q = (f + s) / 2;
(_ = n * Math.cos(q)), (w = n * Math.sin(q)), (S = k = null);
}
} else _ = w = 0;
if (
h > Uo &&
(g = Math.min(Math.abs(c - n) / 2, +i.apply(this, arguments))) > 0.001
) {
v = (c > n) ^ p ? 0 : 1;
var T = g,
R = g;
if (Fo > h) {
var D =
null == S
? [_, w]
: null == x
? [m, M]
: Re([m, M], [S, k], [x, b], [_, w]),
P = m - D[0],
U = M - D[1],
j = x - D[0],
F = b - D[1],
H =
1 /
Math.sin(
Math.acos(
(P * j + U * F) /
(Math.sqrt(P * P + U * U) * Math.sqrt(j * j + F * F))
) / 2
),
O = Math.sqrt(D[0] * D[0] + D[1] * D[1]);
(R = Math.min(g, (n - O) / (H - 1))),
(T = Math.min(g, (c - O) / (H + 1)));
}
if (null != x) {
var I = mu(null == S ? [_, w] : [S, k], [m, M], c, T, p),
Y = mu([x, b], [_, w], c, T, p);
g === T
? A.push(
"M",
I[0],
"A",
T,
",",
T,
" 0 0,",
v,
" ",
I[1],
"A",
c,
",",
c,
" 0 ",
(1 - p) ^ yu(I[1][0], I[1][1], Y[1][0], Y[1][1]),
",",
p,
" ",
Y[1],
"A",
T,
",",
T,
" 0 0,",
v,
" ",
Y[0]
)
: A.push("M", I[0], "A", T, ",", T, " 0 1,", v, " ", Y[0]);
} else A.push("M", m, ",", M);
if (null != S) {
var Z = mu([m, M], [S, k], n, -R, p),
V = mu([_, w], null == x ? [m, M] : [x, b], n, -R, p);
g === R
? A.push(
"L",
V[0],
"A",
R,
",",
R,
" 0 0,",
v,
" ",
V[1],
"A",
n,
",",
n,
" 0 ",
p ^ yu(V[1][0], V[1][1], Z[1][0], Z[1][1]),
",",
1 - p,
" ",
Z[1],
"A",
R,
",",
R,
" 0 0,",
v,
" ",
Z[0]
)
: A.push("L", V[0], "A", R, ",", R, " 0 0,", v, " ", Z[0]);
} else A.push("L", _, ",", w);
} else
A.push("M", m, ",", M),
null != x &&
A.push("A", c, ",", c, " 0 ", C, ",", p, " ", x, ",", b),
A.push("L", _, ",", w),
null != S &&
A.push("A", n, ",", n, " 0 ", L, ",", 1 - p, " ", S, ",", k);
return A.push("Z"), A.join("");
}
function t(n, t) {
return (
"M0," +
n +
"A" +
n +
"," +
n +
" 0 1," +
t +
" 0," +
-n +
"A" +
n +
"," +
n +
" 0 1," +
t +
" 0," +
n
);
}
var e = hu,
r = pu,
i = su,
u = ql,
o = gu,
a = vu,
l = du;
return (
(n.innerRadius = function (t) {
return arguments.length ? ((e = En(t)), n) : e;
}),
(n.outerRadius = function (t) {
return arguments.length ? ((r = En(t)), n) : r;
}),
(n.cornerRadius = function (t) {
return arguments.length ? ((i = En(t)), n) : i;
}),
(n.padRadius = function (t) {
return arguments.length ? ((u = t == ql ? ql : En(t)), n) : u;
}),
(n.startAngle = function (t) {
return arguments.length ? ((o = En(t)), n) : o;
}),
(n.endAngle = function (t) {
return arguments.length ? ((a = En(t)), n) : a;
}),
(n.padAngle = function (t) {
return arguments.length ? ((l = En(t)), n) : l;
}),
(n.centroid = function () {
var n = (+e.apply(this, arguments) + +r.apply(this, arguments)) / 2,
t =
(+o.apply(this, arguments) + +a.apply(this, arguments)) / 2 - Io;
return [Math.cos(t) * n, Math.sin(t) * n];
}),
n
);
});
var ql = "auto";
ao.svg.line = function () {
return Mu(m);
};
var Tl = ao.map({
linear: xu,
"linear-closed": bu,
step: _u,
"step-before": wu,
"step-after": Su,
basis: zu,
"basis-open": Lu,
"basis-closed": qu,
bundle: Tu,
cardinal: Eu,
"cardinal-open": ku,
"cardinal-closed": Nu,
monotone: Fu,
});
Tl.forEach(function (n, t) {
(t.key = n), (t.closed = /-closed$/.test(n));
});
var Rl = [0, 2 / 3, 1 / 3, 0],
Dl = [0, 1 / 3, 2 / 3, 0],
Pl = [0, 1 / 6, 2 / 3, 1 / 6];
(ao.svg.line.radial = function () {
var n = Mu(Hu);
return (n.radius = n.x), delete n.x, (n.angle = n.y), delete n.y, n;
}),
(wu.reverse = Su),
(Su.reverse = wu),
(ao.svg.area = function () {
return Ou(m);
}),
(ao.svg.area.radial = function () {
var n = Ou(Hu);
return (
(n.radius = n.x),
delete n.x,
(n.innerRadius = n.x0),
delete n.x0,
(n.outerRadius = n.x1),
delete n.x1,
(n.angle = n.y),
delete n.y,
(n.startAngle = n.y0),
delete n.y0,
(n.endAngle = n.y1),
delete n.y1,
n
);
}),
(ao.svg.chord = function () {
function n(n, a) {
var l = t(this, u, n, a),
c = t(this, o, n, a);
return (
"M" +
l.p0 +
r(l.r, l.p1, l.a1 - l.a0) +
(e(l, c)
? i(l.r, l.p1, l.r, l.p0)
: i(l.r, l.p1, c.r, c.p0) +
r(c.r, c.p1, c.a1 - c.a0) +
i(c.r, c.p1, l.r, l.p0)) +
"Z"
);
}
function t(n, t, e, r) {
var i = t.call(n, e, r),
u = a.call(n, i, r),
o = l.call(n, i, r) - Io,
f = c.call(n, i, r) - Io;
return {
r: u,
a0: o,
a1: f,
p0: [u * Math.cos(o), u * Math.sin(o)],
p1: [u * Math.cos(f), u * Math.sin(f)],
};
}
function e(n, t) {
return n.a0 == t.a0 && n.a1 == t.a1;
}
function r(n, t, e) {
return "A" + n + "," + n + " 0 " + +(e > Fo) + ",1 " + t;
}
function i(n, t, e, r) {
return "Q 0,0 " + r;
}
var u = Me,
o = xe,
a = Iu,
l = gu,
c = vu;
return (
(n.radius = function (t) {
return arguments.length ? ((a = En(t)), n) : a;
}),
(n.source = function (t) {
return arguments.length ? ((u = En(t)), n) : u;
}),
(n.target = function (t) {
return arguments.length ? ((o = En(t)), n) : o;
}),
(n.startAngle = function (t) {
return arguments.length ? ((l = En(t)), n) : l;
}),
(n.endAngle = function (t) {
return arguments.length ? ((c = En(t)), n) : c;
}),
n
);
}),
(ao.svg.diagonal = function () {
function n(n, i) {
var u = t.call(this, n, i),
o = e.call(this, n, i),
a = (u.y + o.y) / 2,
l = [u, { x: u.x, y: a }, { x: o.x, y: a }, o];
return (
(l = l.map(r)), "M" + l[0] + "C" + l[1] + " " + l[2] + " " + l[3]
);
}
var t = Me,
e = xe,
r = Yu;
return (
(n.source = function (e) {
return arguments.length ? ((t = En(e)), n) : t;
}),
(n.target = function (t) {
return arguments.length ? ((e = En(t)), n) : e;
}),
(n.projection = function (t) {
return arguments.length ? ((r = t), n) : r;
}),
n
);
}),
(ao.svg.diagonal.radial = function () {
var n = ao.svg.diagonal(),
t = Yu,
e = n.projection;
return (
(n.projection = function (n) {
return arguments.length ? e(Zu((t = n))) : t;
}),
n
);
}),
(ao.svg.symbol = function () {
function n(n, r) {
return (Ul.get(t.call(this, n, r)) || $u)(e.call(this, n, r));
}
var t = Xu,
e = Vu;
return (
(n.type = function (e) {
return arguments.length ? ((t = En(e)), n) : t;
}),
(n.size = function (t) {
return arguments.length ? ((e = En(t)), n) : e;
}),
n
);
});
var Ul = ao.map({
circle: $u,
cross: function (n) {
var t = Math.sqrt(n / 5) / 2;
return (
"M" +
-3 * t +
"," +
-t +
"H" +
-t +
"V" +
-3 * t +
"H" +
t +
"V" +
-t +
"H" +
3 * t +
"V" +
t +
"H" +
t +
"V" +
3 * t +
"H" +
-t +
"V" +
t +
"H" +
-3 * t +
"Z"
);
},
diamond: function (n) {
var t = Math.sqrt(n / (2 * Fl)),
e = t * Fl;
return "M0," + -t + "L" + e + ",0 0," + t + " " + -e + ",0Z";
},
square: function (n) {
var t = Math.sqrt(n) / 2;
return (
"M" +
-t +
"," +
-t +
"L" +
t +
"," +
-t +
" " +
t +
"," +
t +
" " +
-t +
"," +
t +
"Z"
);
},
"triangle-down": function (n) {
var t = Math.sqrt(n / jl),
e = (t * jl) / 2;
return "M0," + e + "L" + t + "," + -e + " " + -t + "," + -e + "Z";
},
"triangle-up": function (n) {
var t = Math.sqrt(n / jl),
e = (t * jl) / 2;
return "M0," + -e + "L" + t + "," + e + " " + -t + "," + e + "Z";
},
});
ao.svg.symbolTypes = Ul.keys();
var jl = Math.sqrt(3),
Fl = Math.tan(30 * Yo);
(Co.transition = function (n) {
for (
var t,
e,
r = Hl || ++Zl,
i = Ku(n),
u = [],
o = Ol || { time: Date.now(), ease: Nr, delay: 0, duration: 250 },
a = -1,
l = this.length;
++a < l;
) {
u.push((t = []));
for (var c = this[a], f = -1, s = c.length; ++f < s; )
(e = c[f]) && Qu(e, f, i, r, o), t.push(e);
}
return Wu(u, i, r);
}),
(Co.interrupt = function (n) {
return this.each(null == n ? Il : Bu(Ku(n)));
});
var Hl,
Ol,
Il = Bu(Ku()),
Yl = [],
Zl = 0;
(Yl.call = Co.call),
(Yl.empty = Co.empty),
(Yl.node = Co.node),
(Yl.size = Co.size),
(ao.transition = function (n, t) {
return n && n.transition
? Hl
? n.transition(t)
: n
: ao.selection().transition(n);
}),
(ao.transition.prototype = Yl),
(Yl.select = function (n) {
var t,
e,
r,
i = this.id,
u = this.namespace,
o = [];
n = A(n);
for (var a = -1, l = this.length; ++a < l; ) {
o.push((t = []));
for (var c = this[a], f = -1, s = c.length; ++f < s; )
(r = c[f]) && (e = n.call(r, r.__data__, f, a))
? ("__data__" in r && (e.__data__ = r.__data__),
Qu(e, f, u, i, r[u][i]),
t.push(e))
: t.push(null);
}
return Wu(o, u, i);
}),
(Yl.selectAll = function (n) {
var t,
e,
r,
i,
u,
o = this.id,
a = this.namespace,
l = [];
n = C(n);
for (var c = -1, f = this.length; ++c < f; )
for (var s = this[c], h = -1, p = s.length; ++h < p; )
if ((r = s[h])) {
(u = r[a][o]), (e = n.call(r, r.__data__, h, c)), l.push((t = []));
for (var g = -1, v = e.length; ++g < v; )
(i = e[g]) && Qu(i, g, a, o, u), t.push(i);
}
return Wu(l, a, o);
}),
(Yl.filter = function (n) {
var t,
e,
r,
i = [];
"function" != typeof n && (n = O(n));
for (var u = 0, o = this.length; o > u; u++) {
i.push((t = []));
for (var e = this[u], a = 0, l = e.length; l > a; a++)
(r = e[a]) && n.call(r, r.__data__, a, u) && t.push(r);
}
return Wu(i, this.namespace, this.id);
}),
(Yl.tween = function (n, t) {
var e = this.id,
r = this.namespace;
return arguments.length < 2
? this.node()[r][e].tween.get(n)
: Y(
this,
null == t
? function (t) {
t[r][e].tween.remove(n);
}
: function (i) {
i[r][e].tween.set(n, t);
}
);
}),
(Yl.attr = function (n, t) {
function e() {
this.removeAttribute(a);
}
function r() {
this.removeAttributeNS(a.space, a.local);
}
function i(n) {
return null == n
? e
: ((n += ""),
function () {
var t,
e = this.getAttribute(a);
return (
e !== n &&
((t = o(e, n)),
function (n) {
this.setAttribute(a, t(n));
})
);
});
}
function u(n) {
return null == n
? r
: ((n += ""),
function () {
var t,
e = this.getAttributeNS(a.space, a.local);
return (
e !== n &&
((t = o(e, n)),
function (n) {
this.setAttributeNS(a.space, a.local, t(n));
})
);
});
}
if (arguments.length < 2) {
for (t in n) this.attr(t, n[t]);
return this;
}
var o = "transform" == n ? $r : Mr,
a = ao.ns.qualify(n);
return Ju(this, "attr." + n, t, a.local ? u : i);
}),
(Yl.attrTween = function (n, t) {
function e(n, e) {
var r = t.call(this, n, e, this.getAttribute(i));
return (
r &&
function (n) {
this.setAttribute(i, r(n));
}
);
}
function r(n, e) {
var r = t.call(this, n, e, this.getAttributeNS(i.space, i.local));
return (
r &&
function (n) {
this.setAttributeNS(i.space, i.local, r(n));
}
);
}
var i = ao.ns.qualify(n);
return this.tween("attr." + n, i.local ? r : e);
}),
(Yl.style = function (n, e, r) {
function i() {
this.style.removeProperty(n);
}
function u(e) {
return null == e
? i
: ((e += ""),
function () {
var i,
u = t(this).getComputedStyle(this, null).getPropertyValue(n);
return (
u !== e &&
((i = Mr(u, e)),
function (t) {
this.style.setProperty(n, i(t), r);
})
);
});
}
var o = arguments.length;
if (3 > o) {
if ("string" != typeof n) {
2 > o && (e = "");
for (r in n) this.style(r, n[r], e);
return this;
}
r = "";
}
return Ju(this, "style." + n, e, u);
}),
(Yl.styleTween = function (n, e, r) {
function i(i, u) {
var o = e.call(
this,
i,
u,
t(this).getComputedStyle(this, null).getPropertyValue(n)
);
return (
o &&
function (t) {
this.style.setProperty(n, o(t), r);
}
);
}
return arguments.length < 3 && (r = ""), this.tween("style." + n, i);
}),
(Yl.text = function (n) {
return Ju(this, "text", n, Gu);
}),
(Yl.remove = function () {
var n = this.namespace;
return this.each("end.transition", function () {
var t;
this[n].count < 2 && (t = this.parentNode) && t.removeChild(this);
});
}),
(Yl.ease = function (n) {
var t = this.id,
e = this.namespace;
return arguments.length < 1
? this.node()[e][t].ease
: ("function" != typeof n && (n = ao.ease.apply(ao, arguments)),
Y(this, function (r) {
r[e][t].ease = n;
}));
}),
(Yl.delay = function (n) {
var t = this.id,
e = this.namespace;
return arguments.length < 1
? this.node()[e][t].delay
: Y(
this,
"function" == typeof n
? function (r, i, u) {
r[e][t].delay = +n.call(r, r.__data__, i, u);
}
: ((n = +n),
function (r) {
r[e][t].delay = n;
})
);
}),
(Yl.duration = function (n) {
var t = this.id,
e = this.namespace;
return arguments.length < 1
? this.node()[e][t].duration
: Y(
this,
"function" == typeof n
? function (r, i, u) {
r[e][t].duration = Math.max(1, n.call(r, r.__data__, i, u));
}
: ((n = Math.max(1, n)),
function (r) {
r[e][t].duration = n;
})
);
}),
(Yl.each = function (n, t) {
var e = this.id,
r = this.namespace;
if (arguments.length < 2) {
var i = Ol,
u = Hl;
try {
(Hl = e),
Y(this, function (t, i, u) {
(Ol = t[r][e]), n.call(t, t.__data__, i, u);
});
} finally {
(Ol = i), (Hl = u);
}
} else
Y(this, function (i) {
var u = i[r][e];
(u.event || (u.event = ao.dispatch("start", "end", "interrupt"))).on(
n,
t
);
});
return this;
}),
(Yl.transition = function () {
for (
var n,
t,
e,
r,
i = this.id,
u = ++Zl,
o = this.namespace,
a = [],
l = 0,
c = this.length;
c > l;
l++
) {
a.push((n = []));
for (var t = this[l], f = 0, s = t.length; s > f; f++)
(e = t[f]) &&
((r = e[o][i]),
Qu(e, f, o, u, {
time: r.time,
ease: r.ease,
delay: r.delay + r.duration,
duration: r.duration,
})),
n.push(e);
}
return Wu(a, o, u);
}),
(ao.svg.axis = function () {
function n(n) {
n.each(function () {
var n,
c = ao.select(this),
f = this.__chart__ || e,
s = (this.__chart__ = e.copy()),
h = null == l ? (s.ticks ? s.ticks.apply(s, a) : s.domain()) : l,
p = null == t ? (s.tickFormat ? s.tickFormat.apply(s, a) : m) : t,
g = c.selectAll(".tick").data(h, s),
v = g
.enter()
.insert("g", ".domain")
.attr("class", "tick")
.style("opacity", Uo),
d = ao.transition(g.exit()).style("opacity", Uo).remove(),
y = ao.transition(g.order()).style("opacity", 1),
M = Math.max(i, 0) + o,
x = Zi(s),
b = c.selectAll(".domain").data([0]),
_ =
(b.enter().append("path").attr("class", "domain"),
ao.transition(b));
v.append("line"), v.append("text");
var w,
S,
k,
N,
E = v.select("line"),
A = y.select("line"),
C = g.select("text").text(p),
z = v.select("text"),
L = y.select("text"),
q = "top" === r || "left" === r ? -1 : 1;
if (
("bottom" === r || "top" === r
? ((n = no),
(w = "x"),
(k = "y"),
(S = "x2"),
(N = "y2"),
C.attr("dy", 0 > q ? "0em" : ".71em").style(
"text-anchor",
"middle"
),
_.attr(
"d",
"M" + x[0] + "," + q * u + "V0H" + x[1] + "V" + q * u
))
: ((n = to),
(w = "y"),
(k = "x"),
(S = "y2"),
(N = "x2"),
C.attr("dy", ".32em").style(
"text-anchor",
0 > q ? "end" : "start"
),
_.attr(
"d",
"M" + q * u + "," + x[0] + "H0V" + x[1] + "H" + q * u
)),
E.attr(N, q * i),
z.attr(k, q * M),
A.attr(S, 0).attr(N, q * i),
L.attr(w, 0).attr(k, q * M),
s.rangeBand)
) {
var T = s,
R = T.rangeBand() / 2;
f = s = function (n) {
return T(n) + R;
};
} else f.rangeBand ? (f = s) : d.call(n, s, f);
v.call(n, f, s), y.call(n, s, s);
});
}
var t,
e = ao.scale.linear(),
r = Vl,
i = 6,
u = 6,
o = 3,
a = [10],
l = null;
return (
(n.scale = function (t) {
return arguments.length ? ((e = t), n) : e;
}),
(n.orient = function (t) {
return arguments.length ? ((r = t in Xl ? t + "" : Vl), n) : r;
}),
(n.ticks = function () {
return arguments.length ? ((a = co(arguments)), n) : a;
}),
(n.tickValues = function (t) {
return arguments.length ? ((l = t), n) : l;
}),
(n.tickFormat = function (e) {
return arguments.length ? ((t = e), n) : t;
}),
(n.tickSize = function (t) {
var e = arguments.length;
return e ? ((i = +t), (u = +arguments[e - 1]), n) : i;
}),
(n.innerTickSize = function (t) {
return arguments.length ? ((i = +t), n) : i;
}),
(n.outerTickSize = function (t) {
return arguments.length ? ((u = +t), n) : u;
}),
(n.tickPadding = function (t) {
return arguments.length ? ((o = +t), n) : o;
}),
(n.tickSubdivide = function () {
return arguments.length && n;
}),
n
);
});
var Vl = "bottom",
Xl = { top: 1, right: 1, bottom: 1, left: 1 };
ao.svg.brush = function () {
function n(t) {
t.each(function () {
var t = ao
.select(this)
.style("pointer-events", "all")
.style("-webkit-tap-highlight-color", "rgba(0,0,0,0)")
.on("mousedown.brush", u)
.on("touchstart.brush", u),
o = t.selectAll(".background").data([0]);
o
.enter()
.append("rect")
.attr("class", "background")
.style("visibility", "hidden")
.style("cursor", "crosshair"),
t
.selectAll(".extent")
.data([0])
.enter()
.append("rect")
.attr("class", "extent")
.style("cursor", "move");
var a = t.selectAll(".resize").data(v, m);
a.exit().remove(),
a
.enter()
.append("g")
.attr("class", function (n) {
return "resize " + n;
})
.style("cursor", function (n) {
return $l[n];
})
.append("rect")
.attr("x", function (n) {
return /[ew]$/.test(n) ? -3 : null;
})
.attr("y", function (n) {
return /^[ns]/.test(n) ? -3 : null;
})
.attr("width", 6)
.attr("height", 6)
.style("visibility", "hidden"),
a.style("display", n.empty() ? "none" : null);
var l,
s = ao.transition(t),
h = ao.transition(o);
c && ((l = Zi(c)), h.attr("x", l[0]).attr("width", l[1] - l[0]), r(s)),
f &&
((l = Zi(f)), h.attr("y", l[0]).attr("height", l[1] - l[0]), i(s)),
e(s);
});
}
function e(n) {
n.selectAll(".resize").attr("transform", function (n) {
return "translate(" + s[+/e$/.test(n)] + "," + h[+/^s/.test(n)] + ")";
});
}
function r(n) {
n.select(".extent").attr("x", s[0]),
n.selectAll(".extent,.n>rect,.s>rect").attr("width", s[1] - s[0]);
}
function i(n) {
n.select(".extent").attr("y", h[0]),
n.selectAll(".extent,.e>rect,.w>rect").attr("height", h[1] - h[0]);
}
function u() {
function u() {
32 == ao.event.keyCode &&
(C || ((M = null), (L[0] -= s[1]), (L[1] -= h[1]), (C = 2)), S());
}
function v() {
32 == ao.event.keyCode &&
2 == C &&
((L[0] += s[1]), (L[1] += h[1]), (C = 0), S());
}
function d() {
var n = ao.mouse(b),
t = !1;
x && ((n[0] += x[0]), (n[1] += x[1])),
C ||
(ao.event.altKey
? (M || (M = [(s[0] + s[1]) / 2, (h[0] + h[1]) / 2]),
(L[0] = s[+(n[0] < M[0])]),
(L[1] = h[+(n[1] < M[1])]))
: (M = null)),
E && y(n, c, 0) && (r(k), (t = !0)),
A && y(n, f, 1) && (i(k), (t = !0)),
t && (e(k), w({ type: "brush", mode: C ? "move" : "resize" }));
}
function y(n, t, e) {
var r,
i,
u = Zi(t),
l = u[0],
c = u[1],
f = L[e],
v = e ? h : s,
d = v[1] - v[0];
return (
C && ((l -= f), (c -= d + f)),
(r = (e ? g : p) ? Math.max(l, Math.min(c, n[e])) : n[e]),
C
? (i = (r += f) + d)
: (M && (f = Math.max(l, Math.min(c, 2 * M[e] - r))),
r > f ? ((i = r), (r = f)) : (i = f)),
v[0] != r || v[1] != i
? (e ? (a = null) : (o = null), (v[0] = r), (v[1] = i), !0)
: void 0
);
}
function m() {
d(),
k
.style("pointer-events", "all")
.selectAll(".resize")
.style("display", n.empty() ? "none" : null),
ao.select("body").style("cursor", null),
q
.on("mousemove.brush", null)
.on("mouseup.brush", null)
.on("touchmove.brush", null)
.on("touchend.brush", null)
.on("keydown.brush", null)
.on("keyup.brush", null),
z(),
w({ type: "brushend" });
}
var M,
x,
b = this,
_ = ao.select(ao.event.target),
w = l.of(b, arguments),
k = ao.select(b),
N = _.datum(),
E = !/^(n|s)$/.test(N) && c,
A = !/^(e|w)$/.test(N) && f,
C = _.classed("extent"),
z = W(b),
L = ao.mouse(b),
q = ao.select(t(b)).on("keydown.brush", u).on("keyup.brush", v);
if (
(ao.event.changedTouches
? q.on("touchmove.brush", d).on("touchend.brush", m)
: q.on("mousemove.brush", d).on("mouseup.brush", m),
k.interrupt().selectAll("*").interrupt(),
C)
)
(L[0] = s[0] - L[0]), (L[1] = h[0] - L[1]);
else if (N) {
var T = +/w$/.test(N),
R = +/^n/.test(N);
(x = [s[1 - T] - L[0], h[1 - R] - L[1]]), (L[0] = s[T]), (L[1] = h[R]);
} else ao.event.altKey && (M = L.slice());
k
.style("pointer-events", "none")
.selectAll(".resize")
.style("display", null),
ao.select("body").style("cursor", _.style("cursor")),
w({ type: "brushstart" }),
d();
}
var o,
a,
l = N(n, "brushstart", "brush", "brushend"),
c = null,
f = null,
s = [0, 0],
h = [0, 0],
p = !0,
g = !0,
v = Bl[0];
return (
(n.event = function (n) {
n.each(function () {
var n = l.of(this, arguments),
t = { x: s, y: h, i: o, j: a },
e = this.__chart__ || t;
(this.__chart__ = t),
Hl
? ao
.select(this)
.transition()
.each("start.brush", function () {
(o = e.i),
(a = e.j),
(s = e.x),
(h = e.y),
n({ type: "brushstart" });
})
.tween("brush:brush", function () {
var e = xr(s, t.x),
r = xr(h, t.y);
return (
(o = a = null),
function (i) {
(s = t.x = e(i)),
(h = t.y = r(i)),
n({ type: "brush", mode: "resize" });
}
);
})
.each("end.brush", function () {
(o = t.i),
(a = t.j),
n({ type: "brush", mode: "resize" }),
n({ type: "brushend" });
})
: (n({ type: "brushstart" }),
n({ type: "brush", mode: "resize" }),
n({ type: "brushend" }));
});
}),
(n.x = function (t) {
return arguments.length ? ((c = t), (v = Bl[(!c << 1) | !f]), n) : c;
}),
(n.y = function (t) {
return arguments.length ? ((f = t), (v = Bl[(!c << 1) | !f]), n) : f;
}),
(n.clamp = function (t) {
return arguments.length
? (c && f
? ((p = !!t[0]), (g = !!t[1]))
: c
? (p = !!t)
: f && (g = !!t),
n)
: c && f
? [p, g]
: c
? p
: f
? g
: null;
}),
(n.extent = function (t) {
var e, r, i, u, l;
return arguments.length
? (c &&
((e = t[0]),
(r = t[1]),
f && ((e = e[0]), (r = r[0])),
(o = [e, r]),
c.invert && ((e = c(e)), (r = c(r))),
e > r && ((l = e), (e = r), (r = l)),
(e == s[0] && r == s[1]) || (s = [e, r])),
f &&
((i = t[0]),
(u = t[1]),
c && ((i = i[1]), (u = u[1])),
(a = [i, u]),
f.invert && ((i = f(i)), (u = f(u))),
i > u && ((l = i), (i = u), (u = l)),
(i == h[0] && u == h[1]) || (h = [i, u])),
n)
: (c &&
(o
? ((e = o[0]), (r = o[1]))
: ((e = s[0]),
(r = s[1]),
c.invert && ((e = c.invert(e)), (r = c.invert(r))),
e > r && ((l = e), (e = r), (r = l)))),
f &&
(a
? ((i = a[0]), (u = a[1]))
: ((i = h[0]),
(u = h[1]),
f.invert && ((i = f.invert(i)), (u = f.invert(u))),
i > u && ((l = i), (i = u), (u = l)))),
c && f
? [
[e, i],
[r, u],
]
: c
? [e, r]
: f && [i, u]);
}),
(n.clear = function () {
return n.empty() || ((s = [0, 0]), (h = [0, 0]), (o = a = null)), n;
}),
(n.empty = function () {
return (!!c && s[0] == s[1]) || (!!f && h[0] == h[1]);
}),
ao.rebind(n, l, "on")
);
};
var $l = {
n: "ns-resize",
e: "ew-resize",
s: "ns-resize",
w: "ew-resize",
nw: "nwse-resize",
ne: "nesw-resize",
se: "nwse-resize",
sw: "nesw-resize",
},
Bl = [
["n", "e", "s", "w", "nw", "ne", "se", "sw"],
["e", "w"],
["n", "s"],
[],
],
Wl = (ga.format = xa.timeFormat),
Jl = Wl.utc,
Gl = Jl("%Y-%m-%dT%H:%M:%S.%LZ");
(Wl.iso =
Date.prototype.toISOString && +new Date("2000-01-01T00:00:00.000Z")
? eo
: Gl),
(eo.parse = function (n) {
var t = new Date(n);
return isNaN(t) ? null : t;
}),
(eo.toString = Gl.toString),
(ga.second = On(
function (n) {
return new va(1e3 * Math.floor(n / 1e3));
},
function (n, t) {
n.setTime(n.getTime() + 1e3 * Math.floor(t));
},
function (n) {
return n.getSeconds();
}
)),
(ga.seconds = ga.second.range),
(ga.seconds.utc = ga.second.utc.range),
(ga.minute = On(
function (n) {
return new va(6e4 * Math.floor(n / 6e4));
},
function (n, t) {
n.setTime(n.getTime() + 6e4 * Math.floor(t));
},
function (n) {
return n.getMinutes();
}
)),
(ga.minutes = ga.minute.range),
(ga.minutes.utc = ga.minute.utc.range),
(ga.hour = On(
function (n) {
var t = n.getTimezoneOffset() / 60;
return new va(36e5 * (Math.floor(n / 36e5 - t) + t));
},
function (n, t) {
n.setTime(n.getTime() + 36e5 * Math.floor(t));
},
function (n) {
return n.getHours();
}
)),
(ga.hours = ga.hour.range),
(ga.hours.utc = ga.hour.utc.range),
(ga.month = On(
function (n) {
return (n = ga.day(n)), n.setDate(1), n;
},
function (n, t) {
n.setMonth(n.getMonth() + t);
},
function (n) {
return n.getMonth();
}
)),
(ga.months = ga.month.range),
(ga.months.utc = ga.month.utc.range);
var Kl = [
1e3, 5e3, 15e3, 3e4, 6e4, 3e5, 9e5, 18e5, 36e5, 108e5, 216e5, 432e5,
864e5, 1728e5, 6048e5, 2592e6, 7776e6, 31536e6,
],
Ql = [
[ga.second, 1],
[ga.second, 5],
[ga.second, 15],
[ga.second, 30],
[ga.minute, 1],
[ga.minute, 5],
[ga.minute, 15],
[ga.minute, 30],
[ga.hour, 1],
[ga.hour, 3],
[ga.hour, 6],
[ga.hour, 12],
[ga.day, 1],
[ga.day, 2],
[ga.week, 1],
[ga.month, 1],
[ga.month, 3],
[ga.year, 1],
],
nc = Wl.multi([
[
".%L",
function (n) {
return n.getMilliseconds();
},
],
[
":%S",
function (n) {
return n.getSeconds();
},
],
[
"%I:%M",
function (n) {
return n.getMinutes();
},
],
[
"%I %p",
function (n) {
return n.getHours();
},
],
[
"%a %d",
function (n) {
return n.getDay() && 1 != n.getDate();
},
],
[
"%b %d",
function (n) {
return 1 != n.getDate();
},
],
[
"%B",
function (n) {
return n.getMonth();
},
],
["%Y", zt],
]),
tc = {
range: function (n, t, e) {
return ao.range(Math.ceil(n / e) * e, +t, e).map(io);
},
floor: m,
ceil: m,
};
(Ql.year = ga.year),
(ga.scale = function () {
return ro(ao.scale.linear(), Ql, nc);
});
var ec = Ql.map(function (n) {
return [n[0].utc, n[1]];
}),
rc = Jl.multi([
[
".%L",
function (n) {
return n.getUTCMilliseconds();
},
],
[
":%S",
function (n) {
return n.getUTCSeconds();
},
],
[
"%I:%M",
function (n) {
return n.getUTCMinutes();
},
],
[
"%I %p",
function (n) {
return n.getUTCHours();
},
],
[
"%a %d",
function (n) {
return n.getUTCDay() && 1 != n.getUTCDate();
},
],
[
"%b %d",
function (n) {
return 1 != n.getUTCDate();
},
],
[
"%B",
function (n) {
return n.getUTCMonth();
},
],
["%Y", zt],
]);
(ec.year = ga.year.utc),
(ga.scale.utc = function () {
return ro(ao.scale.linear(), ec, rc);
}),
(ao.text = An(function (n) {
return n.responseText;
})),
(ao.json = function (n, t) {
return Cn(n, "application/json", uo, t);
}),
(ao.html = function (n, t) {
return Cn(n, "text/html", oo, t);
}),
(ao.xml = An(function (n) {
return n.responseXML;
})),
"function" == typeof define && define.amd
? ((this.d3 = ao), define(ao))
: "object" == typeof module && module.exports
? (module.exports = ao)
: (this.d3 = ao);
})();