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
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); |
|
})();
|
|
|