D3.js 212 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749
  1. ! function() {
  2. function n(n) { return n && (n.ownerDocument || n.document || n).documentElement }
  3. function t(n) { return n && (n.ownerDocument && n.ownerDocument.defaultView || n.document && n || n.defaultView) }
  4. function e(n, t) { return t > n ? -1 : n > t ? 1 : n >= t ? 0 : NaN }
  5. function r(n) { return null === n ? NaN : +n }
  6. function i(n) { return !isNaN(n) }
  7. 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;
  8. 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;
  9. n(t[u], e) > 0 ? i = u : r = u + 1 } return r } } }
  10. function o(n) { return n.length }
  11. function a(n) { for (var t = 1; n * t % 1;) t *= 10; return t }
  12. function l(n, t) { for (var e in t) Object.defineProperty(n.prototype, e, { value: t[e], enumerable: !1 }) }
  13. function c() { this._ = Object.create(null) }
  14. function f(n) { return (n += "") === bo || n[0] === _o ? _o + n : n }
  15. function s(n) { return (n += "")[0] === _o ? n.slice(1) : n }
  16. function h(n) { return f(n) in this._ }
  17. function p(n) { return (n = f(n)) in this._ && delete this._[n] }
  18. function g() { var n = []; for (var t in this._) n.push(s(t)); return n }
  19. function v() { var n = 0; for (var t in this._) ++n; return n }
  20. function d() { for (var n in this._) return !1; return !0 }
  21. function y() { this._ = Object.create(null) }
  22. function m(n) { return n }
  23. function M(n, t, e) { return function() { var r = e.apply(t, arguments); return r === t ? n : r } }
  24. function x(n, t) { if (t in n) return t;
  25. 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 } }
  26. function b() {}
  27. function _() {}
  28. function w(n) {
  29. 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 = [],
  30. 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 }
  31. function S() { ao.event.preventDefault() }
  32. function k() { for (var n, t = ao.event; n = t.sourceEvent;) t = n; return t }
  33. 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;
  34. i.target = n, ao.event = i, t[i.type].apply(e, r) } finally { ao.event = u } } }, t }
  35. function E(n) { return ko(n, Co), n }
  36. function A(n) { return "function" == typeof n ? n : function() { return No(n, this) } }
  37. function C(n) { return "function" == typeof n ? n : function() { return Eo(n, this) } }
  38. function z(n, t) {
  39. function e() { this.removeAttribute(n) }
  40. function r() { this.removeAttributeNS(n.space, n.local) }
  41. function i() { this.setAttribute(n, t) }
  42. function u() { this.setAttributeNS(n.space, n.local, t) }
  43. function o() { var e = t.apply(this, arguments);
  44. null == e ? this.removeAttribute(n) : this.setAttribute(n, e) }
  45. function a() { var e = t.apply(this, arguments);
  46. 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 }
  47. function L(n) { return n.trim().replace(/\s+/g, " ") }
  48. function q(n) { return new RegExp("(?:^|\\s+)" + ao.requote(n) + "(?:\\s+|$)", "g") }
  49. function T(n) { return (n + "").trim().split(/^|\s+/) }
  50. function R(n, t) {
  51. function e() { for (var e = -1; ++e < i;) n[e](this, t) }
  52. function r() { for (var e = -1, r = t.apply(this, arguments); ++e < i;) n[e](this, r) }
  53. n = T(n).map(D); var i = n.length; return "function" == typeof t ? r : e }
  54. 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") || "";
  55. r ? (t.lastIndex = 0, t.test(i) || e.setAttribute("class", L(i + " " + n))) : e.setAttribute("class", L(i.replace(t, " "))) } }
  56. function P(n, t, e) {
  57. function r() { this.style.removeProperty(n) }
  58. function i() { this.style.setProperty(n, t, e) }
  59. function u() { var r = t.apply(this, arguments);
  60. null == r ? this.style.removeProperty(n) : this.style.setProperty(n, r, e) } return null == t ? r : "function" == typeof t ? u : i }
  61. function U(n, t) {
  62. function e() { delete this[n] }
  63. function r() { this[n] = t }
  64. function i() { var e = t.apply(this, arguments);
  65. null == e ? delete this[n] : this[n] = e } return null == t ? e : "function" == typeof t ? i : r }
  66. function j(n) {
  67. function t() { var t = this.ownerDocument,
  68. e = this.namespaceURI; return e === zo && t.documentElement.namespaceURI === zo ? t.createElement(n) : t.createElementNS(e, n) }
  69. function e() { return this.ownerDocument.createElementNS(n.space, n.local) } return "function" == typeof n ? n : (n = ao.ns.qualify(n)).local ? e : t }
  70. function F() { var n = this.parentNode;
  71. n && n.removeChild(this) }
  72. function H(n) { return { __data__: n } }
  73. function O(n) { return function() { return Ao(this, n) } }
  74. function I(n) { return arguments.length || (n = e),
  75. function(t, e) { return t && e ? n(t.__data__, e.__data__) : !t - !e } }
  76. function Y(n, t) { for (var e = 0, r = n.length; r > e; e++)
  77. for (var i, u = n[e], o = 0, a = u.length; a > o; o++)(i = u[o]) && t(i, o, e); return n }
  78. function Z(n) { return ko(n, qo), n }
  79. function V(n) { var t, e; return function(r, i, u) { var o, a = n[u].update,
  80. l = a.length; for (u != e && (e = u, t = 0), i >= t && (t = i + 1); !(o = a[t]) && ++t < l;); return o } }
  81. function X(n, t, e) {
  82. function r() { var t = this[o];
  83. t && (this.removeEventListener(n, t, t.$), delete this[o]) }
  84. function i() { var i = l(t, co(arguments));
  85. r.call(this), this.addEventListener(n, this[o] = i, i.$ = e), i._ = t }
  86. function u() { var t, e = new RegExp("^__on([^.]+)" + ao.requote(n) + "$"); for (var r in this)
  87. if (t = r.match(e)) { var i = this[r];
  88. this.removeEventListener(t[1], i, i.$), delete this[r] } } var o = "__on" + n,
  89. a = n.indexOf("."),
  90. l = $;
  91. 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 }
  92. function $(n, t) { return function(e) { var r = ao.event;
  93. ao.event = e, t[0] = this.__data__; try { n.apply(this, t) } finally { ao.event = r } } }
  94. function B(n, t) { var e = $(n, t); return function(n) { var t = this,
  95. r = n.relatedTarget;
  96. r && (r === t || 8 & r.compareDocumentPosition(t)) || e.call(t, n) } }
  97. function W(e) { var r = ".dragsuppress-" + ++Do,
  98. i = "click" + r,
  99. 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,
  100. a = o[Ro];
  101. o[Ro] = "none" } return function(n) { if (u.on(r, null), Ro && (o[Ro] = a), n) { var t = function() { u.on(i, null) };
  102. u.on(i, function() { S(), t() }, !0), setTimeout(t, 0) } } }
  103. 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();
  104. 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] }
  105. function G() { return ao.event.changedTouches[0].identifier }
  106. function K(n) { return n > 0 ? 1 : 0 > n ? -1 : 0 }
  107. function Q(n, t, e) { return (t[0] - n[0]) * (e[1] - n[1]) - (t[1] - n[1]) * (e[0] - n[0]) }
  108. function nn(n) { return n > 1 ? 0 : -1 > n ? Fo : Math.acos(n) }
  109. function tn(n) { return n > 1 ? Io : -1 > n ? -Io : Math.asin(n) }
  110. function en(n) { return ((n = Math.exp(n)) - 1 / n) / 2 }
  111. function rn(n) { return ((n = Math.exp(n)) + 1 / n) / 2 }
  112. function un(n) { return ((n = Math.exp(2 * n)) - 1) / (n + 1) }
  113. function on(n) { return (n = Math.sin(n / 2)) * n }
  114. function an() {}
  115. 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) }
  116. function cn(n, t, e) {
  117. 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 }
  118. 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 = .5 >= e ? e * (1 + t) : e + t - e * t, u = 2 * e - o, new mn(i(n + 120), i(n), i(n - 120)) }
  119. 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) }
  120. 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) }
  121. 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) }
  122. function pn(n, t, e) { var r = (n + 16) / 116,
  123. i = r + t / 500,
  124. 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 - .4985314 * u), yn(-.969266 * i + 1.8760108 * r + .041556 * u), yn(.0556434 * i - .2040259 * r + 1.0572252 * u)) }
  125. 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) }
  126. function vn(n) { return n > .206893034 ? n * n * n : (n - 4 / 29) / 7.787037 }
  127. function dn(n) { return n > .008856 ? Math.pow(n, 1 / 3) : 7.787037 * n + 4 / 29 }
  128. function yn(n) { return Math.round(255 * (.00304 >= n ? 12.92 * n : 1.055 * Math.pow(n, 1 / 2.4) - .055)) }
  129. 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) }
  130. function Mn(n) { return new mn(n >> 16, n >> 8 & 255, 255 & n) }
  131. function xn(n) { return Mn(n) + "" }
  132. function bn(n) { return 16 > n ? "0" + Math.max(0, n).toString(16) : Math.min(255, n).toString(16) }
  133. function _n(n, t, e) { var r, i, u, o = 0,
  134. a = 0,
  135. l = 0; if (r = /([a-z]+)\((.*)\)/.exec(n = n.toLowerCase())) switch (i = r[2].split(","), r[1]) {
  136. case "hsl":
  137. return e(parseFloat(i[0]), parseFloat(i[1]) / 100, parseFloat(i[2]) / 100);
  138. case "rgb":
  139. return t(Nn(i[0]), Nn(i[1]), Nn(i[2])) }
  140. 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)) }
  141. function wn(n, t, e) { var r, i, u = Math.min(n /= 255, t /= 255, e /= 255),
  142. o = Math.max(n, t, e),
  143. a = o - u,
  144. l = (o + u) / 2; return a ? (i = .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) }
  145. function Sn(n, t, e) { n = kn(n), t = kn(t), e = kn(e); var r = dn((.4124564 * n + .3575761 * t + .1804375 * e) / na),
  146. i = dn((.2126729 * n + .7151522 * t + .072175 * e) / ta),
  147. u = dn((.0193339 * n + .119192 * t + .9503041 * e) / ea); return hn(116 * i - 16, 500 * (r - i), 200 * (i - u)) }
  148. function kn(n) { return (n /= 255) <= .04045 ? n / 12.92 : Math.pow((n + .055) / 1.055, 2.4) }
  149. function Nn(n) { var t = parseFloat(n); return "%" === n.charAt(n.length - 1) ? Math.round(2.55 * t) : t }
  150. function En(n) { return "function" == typeof n ? n : function() { return n } }
  151. function An(n) { return function(t, e, r) { return 2 === arguments.length && "function" == typeof e && (r = e, e = null), Cn(t, e, n, r) } }
  152. function Cn(n, t, e, r) {
  153. 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) }
  154. o.load.call(u, n) } else o.error.call(u, l) } var u = {},
  155. o = ao.dispatch("beforesend", "progress", "load", "error"),
  156. a = {},
  157. l = new XMLHttpRequest,
  158. 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;
  159. 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)
  160. 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)) }
  161. function zn(n) { return 1 === n.length ? function(t, e) { n(null == t ? e : null) } : n }
  162. function Ln(n) { var t = n.responseType; return t && "text" !== t ? n.response : n.responseText }
  163. function qn(n, t, e) { var r = arguments.length;
  164. 2 > r && (t = 0), 3 > r && (e = Date.now()); var i = e + t,
  165. 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 }
  166. function Tn() { var n = Rn(),
  167. t = Dn() - n;
  168. t > 24 ? (isFinite(t) && (clearTimeout(ca), ca = setTimeout(Tn, t)), la = 0) : (la = 1, fa(Tn)) }
  169. 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 }
  170. 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 }
  171. function Pn(n, t) { return t - (n ? Math.ceil(Math.log(n) / Math.LN10) : 1) }
  172. 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 } }
  173. function jn(n) { var t = n.decimal,
  174. e = n.thousands,
  175. r = n.grouping,
  176. i = n.currency,
  177. 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),
  178. r = e[1] || " ",
  179. o = e[2] || ">",
  180. a = e[3] || "-",
  181. l = e[4] || "",
  182. c = e[5],
  183. f = +e[6],
  184. s = e[7],
  185. h = e[8],
  186. p = e[9],
  187. g = 1,
  188. v = "",
  189. d = "",
  190. y = !1,
  191. m = !0; switch (h && (h = +h.substring(1)), (c || "0" === r && "=" === o) && (c = r = "0", o = "="), p) {
  192. case "n":
  193. s = !0, p = "g"; break;
  194. case "%":
  195. g = 100, d = "%", p = "f"; break;
  196. case "p":
  197. g = 100, d = "%", p = "r"; break;
  198. case "b":
  199. case "o":
  200. case "x":
  201. case "X":
  202. "#" === l && (v = "0" + p.toLowerCase());
  203. case "c":
  204. m = !1;
  205. case "d":
  206. y = !0, h = 0; break;
  207. case "s":
  208. 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);
  209. n = l.scale(n), e = l.symbol + d } else n *= g;
  210. n = p(n, h); var x, b, _ = n.lastIndexOf("."); if (0 > _) { var w = m ? n.lastIndexOf("e") : -1;
  211. 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),
  212. 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 } } }
  213. function Fn(n) { return n + "" }
  214. function Hn() { this._ = new Date(arguments.length > 1 ? Date.UTC.apply(this, arguments) : arguments[0]) }
  215. function On(n, t, e) {
  216. function r(t) { var e = n(t),
  217. r = u(e, 1); return r - t > t - e ? e : r }
  218. function i(e) { return t(e = n(new va(e - 1)), 1), e }
  219. function u(n, e) { return t(n = new va(+n), e), n }
  220. function o(n, r, u) { var o = i(n),
  221. a = []; if (u > 1)
  222. for (; r > o;) e(o) % u || a.push(new Date(+o)), t(o, 1);
  223. else
  224. for (; r > o;) a.push(new Date(+o)), t(o, 1); return a }
  225. function a(n, t, e) { try { va = Hn; var r = new Hn; return r._ = n, o(r, t, e) } finally { va = Date } }
  226. 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 }
  227. function In(n) { return function(t, e) { try { va = Hn; var r = new Hn; return r._ = t, n(r, e)._ } finally { va = Date } } }
  228. function Yn(n) {
  229. function t(n) {
  230. 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 },
  231. 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,
  232. 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 }
  233. 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 }
  234. 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 }
  235. 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 }
  236. 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 }
  237. 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 }
  238. function a(n, t, r) { return e(n, A.c.toString(), t, r) }
  239. function l(n, t, r) { return e(n, A.x.toString(), t, r) }
  240. function c(n, t, r) { return e(n, A.X.toString(), t, r) }
  241. 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,
  242. h = n.date,
  243. p = n.time,
  244. g = n.periods,
  245. v = n.days,
  246. d = n.shortDays,
  247. y = n.months,
  248. m = n.shortMonths;
  249. t.utc = function(n) {
  250. 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(),
  251. x = Vn(v),
  252. b = Xn(v),
  253. _ = Vn(d),
  254. w = Xn(d),
  255. S = Vn(y),
  256. k = Xn(y),
  257. N = Vn(m),
  258. E = Xn(m);
  259. 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 "%" } },
  260. 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 }
  261. function Zn(n, t, e) { var r = 0 > n ? "-" : "",
  262. i = (r ? -n : n) + "",
  263. u = i.length; return r + (e > u ? new Array(e - u + 1).join(t) + i : i) }
  264. function Vn(n) { return new RegExp("^(?:" + n.map(ao.requote).join("|") + ")", "i") }
  265. function Xn(n) { for (var t = new c, e = -1, r = n.length; ++e < r;) t.set(n[e].toLowerCase(), e); return t }
  266. 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 }
  267. 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 }
  268. 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 }
  269. 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 }
  270. 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 }
  271. function Kn(n, t, e) { return /^[+-]\d{4}$/.test(t = t.slice(e, e + 5)) ? (n.Z = -t, e + 5) : -1 }
  272. function Qn(n) { return n + (n > 68 ? 1900 : 2e3) }
  273. 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 }
  274. 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 }
  275. 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 }
  276. 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 }
  277. 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 }
  278. 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 }
  279. 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 }
  280. function at(n) { var t = n.getTimezoneOffset(),
  281. e = t > 0 ? "-" : "+",
  282. r = xo(t) / 60 | 0,
  283. i = xo(t) % 60; return e + Zn(r, "0", 2) + Zn(i, "0", 2) }
  284. function lt(n, t, e) { Ma.lastIndex = 0; var r = Ma.exec(t.slice(e, e + 1)); return r ? e + r[0].length : -1 }
  285. 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) } }
  286. function ft() {}
  287. function st(n, t, e) { var r = e.s = n + t,
  288. i = r - n,
  289. u = r - i;
  290. e.t = n - u + (t - i) }
  291. function ht(n, t) { n && wa.hasOwnProperty(n.type) && wa[n.type](n, t) }
  292. function pt(n, t, e) { var r, i = -1,
  293. u = n.length - e; for (t.lineStart(); ++i < u;) r = n[i], t.point(r[0], r[1], r[2]);
  294. t.lineEnd() }
  295. function gt(n, t) { var e = -1,
  296. r = n.length; for (t.polygonStart(); ++e < r;) pt(n[e], t, 1);
  297. t.polygonEnd() }
  298. function vt() {
  299. function n(n, t) { n *= Yo, t = t * Yo / 2 + Fo / 4; var e = n - r,
  300. o = e >= 0 ? 1 : -1,
  301. a = o * e,
  302. l = Math.cos(t),
  303. c = Math.sin(t),
  304. f = u * c,
  305. s = i * l + f * Math.cos(a),
  306. h = f * o * Math.sin(a);
  307. ka.add(Math.atan2(h, s)), r = n, i = l, u = c } var t, e, r, i, u;
  308. 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) } }
  309. function dt(n) { var t = n[0],
  310. e = n[1],
  311. r = Math.cos(e); return [r * Math.cos(t), r * Math.sin(t), Math.sin(e)] }
  312. function yt(n, t) { return n[0] * t[0] + n[1] * t[1] + n[2] * t[2] }
  313. 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]] }
  314. function Mt(n, t) { n[0] += t[0], n[1] += t[1], n[2] += t[2] }
  315. function xt(n, t) { return [n[0] * t, n[1] * t, n[2] * t] }
  316. function bt(n) { var t = Math.sqrt(n[0] * n[0] + n[1] * n[1] + n[2] * n[2]);
  317. n[0] /= t, n[1] /= t, n[2] /= t }
  318. function _t(n) { return [Math.atan2(n[1], n[0]), tn(n[2])] }
  319. function wt(n, t) { return xo(n[0] - t[0]) < Uo && xo(n[1] - t[1]) < Uo }
  320. function St(n, t) { n *= Yo; var e = Math.cos(t *= Yo);
  321. kt(e * Math.cos(n), e * Math.sin(n), Math.sin(t)) }
  322. function kt(n, t, e) {++Ea, Ca += (n - Ca) / Ea, za += (t - za) / Ea, La += (e - La) / Ea }
  323. function Nt() {
  324. function n(n, i) { n *= Yo; var u = Math.cos(i *= Yo),
  325. o = u * Math.cos(n),
  326. a = u * Math.sin(n),
  327. l = Math.sin(i),
  328. 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);
  329. 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;
  330. ja.point = function(i, u) { i *= Yo; var o = Math.cos(u *= Yo);
  331. t = o * Math.cos(i), e = o * Math.sin(i), r = Math.sin(u), ja.point = n, kt(t, e, r) } }
  332. function Et() { ja.point = St }
  333. function At() {
  334. function n(n, t) { n *= Yo; var e = Math.cos(t *= Yo),
  335. o = e * Math.cos(n),
  336. a = e * Math.sin(n),
  337. l = Math.sin(t),
  338. c = i * l - u * a,
  339. f = u * o - r * l,
  340. s = r * a - i * o,
  341. h = Math.sqrt(c * c + f * f + s * s),
  342. p = r * o + i * a + u * l,
  343. g = h && -nn(p) / h,
  344. v = Math.atan2(h, p);
  345. 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;
  346. ja.point = function(o, a) { t = o, e = a, ja.point = n, o *= Yo; var l = Math.cos(a *= Yo);
  347. 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 } }
  348. function Ct(n, t) {
  349. 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 }
  350. function zt() { return !0 }
  351. function Lt(n, t, e, r, i) { var u = [],
  352. o = []; if (n.forEach(function(n) { if (!((t = n.length - 1) <= 0)) { var t, e = n[0],
  353. 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),
  354. c = new Tt(e, null, l, !1);
  355. 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;)
  356. if ((p = p.n) === h) return;
  357. f = p.z, i.lineStart();
  358. do { if (p.v = p.o.v = !0, p.e) { if (g)
  359. for (var a = 0, c = f.length; c > a; ++a) i.point((s = f[a])[0], s[1]);
  360. else r(p.x, p.n.x, 1, i);
  361. 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);
  362. p = p.p }
  363. p = p.o, f = p.z, g = !g } while (!p.v);
  364. i.lineEnd() } } }
  365. 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;
  366. i.n = e = n[0], e.p = i } }
  367. 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 }
  368. function Rt(n, t, e, r) { return function(i, u) {
  369. function o(t, e) { var r = i(t, e);
  370. n(t = r[0], e = r[1]) && u.point(t, e) }
  371. function a(n, t) { var e = i(n, t);
  372. d.point(e[0], e[1]) }
  373. function l() { m.point = a, d.lineStart() }
  374. function c() { m.point = o, d.lineEnd() }
  375. function f(n, t) { v.push([n, t]); var e = i(n, t);
  376. x.point(e[0], e[1]) }
  377. function s() { x.lineStart(), v = [] }
  378. function h() { f(v[0][0], v[0][1]), x.lineEnd(); var n, t = x.clean(),
  379. e = M.buffer(),
  380. r = e.length; if (v.pop(), g.push(v), v = null, r)
  381. if (1 & t) { n = e[0]; var i, r = n.length - 1,
  382. o = -1; if (r > 0) { for (b || (u.polygonStart(), b = !0), u.lineStart(); ++o < r;) u.point((i = n[o])[0], i[1]);
  383. 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),
  384. y = i.invert(r[0], r[1]),
  385. 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);
  386. 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() } },
  387. M = Pt(),
  388. x = t(M),
  389. b = !1; return m } }
  390. function Dt(n) { return n.length > 1 }
  391. 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())) } } }
  392. 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]) }
  393. function jt(n) { var t, e = NaN,
  394. r = NaN,
  395. i = NaN; return { lineStart: function() { n.lineStart(), t = 1 }, point: function(u, o) { var a = u > 0 ? Fo : -Fo,
  396. l = xo(u - e);
  397. 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 } } }
  398. 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 }
  399. 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);
  400. else if (xo(n[0] - t[0]) > Uo) { var u = n[0] < t[0] ? Fo : -Fo;
  401. i = e * u / 2, r.point(-u, i), r.point(0, i), r.point(u, i) } else r.point(t[0], t[1]) }
  402. function Ot(n, t) { var e = n[0],
  403. r = n[1],
  404. i = [Math.sin(e), -Math.cos(e), 0],
  405. u = 0,
  406. o = 0;
  407. ka.reset(); for (var a = 0, l = t.length; l > a; ++a) { var c = t[a],
  408. f = c.length; if (f)
  409. 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],
  410. m = n[1] / 2 + Fo / 4,
  411. M = Math.sin(m),
  412. x = Math.cos(m),
  413. b = y - h,
  414. _ = b >= 0 ? 1 : -1,
  415. w = _ * b,
  416. S = w > Fo,
  417. 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));
  418. bt(N); var E = mt(i, N);
  419. bt(E); var A = (S ^ b >= 0 ? -1 : 1) * tn(E[2]);
  420. (r > A || r === A && (N[0] || N[1])) && (o += S ^ b >= 0 ? 1 : -1) } if (!d++) break;
  421. h = y, g = M, v = x, s = n } } return (-Uo > u || Uo > u && -Uo > ka) ^ 1 & o }
  422. function It(n) {
  423. function t(n, t) { return Math.cos(n) * Math.cos(t) > u }
  424. 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],
  425. v = t(s, h),
  426. 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;
  427. else if (a && e && o ^ v) { var y;
  428. 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 } } }
  429. function r(n, t, e) { var r = dt(n),
  430. i = dt(t),
  431. o = [1, 0, 0],
  432. a = mt(r, i),
  433. l = yt(a, a),
  434. c = a[0],
  435. f = l - c * c; if (!f) return !e && n; var s = u * l / f,
  436. h = -u * c / f,
  437. p = mt(o, a),
  438. g = xt(o, s),
  439. v = xt(a, h);
  440. Mt(g, v); var d = p,
  441. y = yt(g, d),
  442. m = yt(d, d),
  443. M = y * y - m * (yt(g, g) - 1); if (!(0 > M)) { var x = Math.sqrt(M),
  444. b = xt(d, (-y - x) / m); if (Mt(b, g), b = _t(b), !e) return b; var _, w = n[0],
  445. S = t[0],
  446. k = n[1],
  447. N = t[1];
  448. w > S && (_ = w, w = S, S = _); var E = S - w,
  449. A = xo(E - Fo) < Uo,
  450. 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)] } } }
  451. function i(t, e) { var r = o ? n : Fo - n,
  452. 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),
  453. o = u > 0,
  454. a = xo(u) > Uo,
  455. l = ve(n, 6 * Yo); return Rt(t, e, l, o ? [0, -n] : [-Fo, n - Fo]) }
  456. function Yt(n, t, e, r) { return function(i) { var u, o = i.a,
  457. a = i.b,
  458. l = o.x,
  459. c = o.y,
  460. f = a.x,
  461. s = a.y,
  462. h = 0,
  463. p = 1,
  464. g = f - l,
  465. v = s - c; if (u = n - l, g || !(u > 0)) { if (u /= g, 0 > g) { if (h > u) return;
  466. p > u && (p = u) } else if (g > 0) { if (u > p) return;
  467. u > h && (h = u) } if (u = e - l, g || !(0 > u)) { if (u /= g, 0 > g) { if (u > p) return;
  468. u > h && (h = u) } else if (g > 0) { if (h > u) return;
  469. p > u && (p = u) } if (u = t - c, v || !(u > 0)) { if (u /= v, 0 > v) { if (h > u) return;
  470. p > u && (p = u) } else if (v > 0) { if (u > p) return;
  471. u > h && (h = u) } if (u = r - c, v || !(0 > u)) { if (u /= v, 0 > v) { if (u > p) return;
  472. u > h && (h = u) } else if (v > 0) { if (h > u) return;
  473. 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 } } } } } }
  474. function Zt(n, t, e, r) {
  475. 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 }
  476. function u(n, t) { return o(n.x, t.x) }
  477. function o(n, t) { var e = i(n, 1),
  478. 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) {
  479. function l(n) { for (var t = 0, e = d.length, r = n[1], i = 0; e > i; ++i)
  480. 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 }
  481. function c(u, a, l, c) { var f = 0,
  482. 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]) }
  483. function f(i, u) { return i >= n && e >= i && u >= t && r >= u }
  484. function s(n, t) { f(n, t) && a.point(n, t) }
  485. function h() { C.point = g, d && d.push(y = []), S = !0, w = !1, b = _ = NaN }
  486. function p() { v && (g(m, M), x && w && E.rejoin(), v.push(E.buffer())), C.point = s, w && a.lineEnd() }
  487. 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));
  488. else if (e && w) a.point(n, t);
  489. else { var r = { a: { x: b, y: _ }, b: { x: n, y: t } };
  490. 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) }
  491. b = n, _ = t, w = e } var v, d, y, m, M, x, b, _, w, S, k, N = a,
  492. E = Pt(),
  493. A = Yt(n, t, e, r),
  494. 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]),
  495. e = k && t,
  496. i = v.length;
  497. (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 } }
  498. function Vt(n) { var t = 0,
  499. e = Fo / 3,
  500. r = ae(n),
  501. 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 }
  502. function Xt(n, t) {
  503. 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),
  504. i = (r + Math.sin(t)) / 2,
  505. u = 1 + r * (2 * i - r),
  506. 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 }
  507. function $t() {
  508. function n(n, t) { Ia += i * n - r * t, r = n, i = t } var t, e, r, i;
  509. $a.point = function(u, o) { $a.point = n, t = r = u, e = i = o }, $a.lineEnd = function() { n(t, e) } }
  510. function Bt(n, t) { Ya > n && (Ya = n), n > Va && (Va = n), Za > t && (Za = t), t > Xa && (Xa = t) }
  511. function Wt() {
  512. function n(n, t) { o.push("M", n, ",", t, u) }
  513. function t(n, t) { o.push("M", n, ",", t), a.point = e }
  514. function e(n, t) { o.push("L", n, ",", t) }
  515. function r() { a.point = n }
  516. function i() { o.push("Z") } var u = Jt(4.5),
  517. o = [],
  518. 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 }
  519. 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" }
  520. function Gt(n, t) { Ca += n, za += t, ++La }
  521. function Kt() {
  522. function n(n, r) { var i = n - t,
  523. u = r - e,
  524. o = Math.sqrt(i * i + u * u);
  525. qa += o * (t + n) / 2, Ta += o * (e + r) / 2, Ra += o, Gt(t = n, e = r) } var t, e;
  526. Wa.point = function(r, i) { Wa.point = n, Gt(t = r, e = i) } }
  527. function Qt() { Wa.point = Gt }
  528. function ne() {
  529. function n(n, t) { var e = n - r,
  530. u = t - i,
  531. o = Math.sqrt(e * e + u * u);
  532. 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;
  533. Wa.point = function(u, o) { Wa.point = n, Gt(t = r = u, e = i = o) }, Wa.lineEnd = function() { n(t, e) } }
  534. function te(n) {
  535. function t(t, e) { n.moveTo(t + o, e), n.arc(t, e, o, 0, Ho) }
  536. function e(t, e) { n.moveTo(t, e), a.point = r }
  537. function r(t, e) { n.lineTo(t, e) }
  538. function i() { a.point = t }
  539. function u() { n.closePath() } var o = 4.5,
  540. 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 }
  541. function ee(n) {
  542. function t(n) { return (a ? r : e)(n) }
  543. function e(t) { return ue(t, function(e, r) { e = n(e, r), t.point(e[0], e[1]) }) }
  544. function r(t) {
  545. function e(e, r) { e = n(e, r), t.point(e[0], e[1]) }
  546. function r() { M = NaN, S.point = u, t.lineStart() }
  547. function u(e, r) { var u = dt([e, r]),
  548. o = n(e, r);
  549. 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) }
  550. function o() { S.point = e, t.lineEnd() }
  551. function l() {
  552. r(), S.point = c, S.lineEnd = f
  553. }
  554. function c(n, t) { u(s = n, h = t), p = M, g = x, v = b, d = _, y = w, S.point = u }
  555. function f() { i(M, x, m, b, _, w, p, g, s, v, d, y, a, t), S.lineEnd = o, o() }
  556. 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 } };
  557. return S
  558. }
  559. function i(t, e, r, a, l, c, f, s, h, p, g, v, d, y) { var m = f - t,
  560. M = s - e,
  561. x = m * m + M * M; if (x > 4 * u && d--) { var b = a + p,
  562. _ = l + g,
  563. w = c + v,
  564. S = Math.sqrt(b * b + _ * _ + w * w),
  565. k = Math.asin(w /= S),
  566. N = xo(xo(w) - 1) < Uo || xo(r - h) < Uo ? (r + h) / 2 : Math.atan2(_, b),
  567. E = n(N, k),
  568. A = E[0],
  569. C = E[1],
  570. z = A - t,
  571. L = C - e,
  572. q = M * z - m * L;
  573. (q * q / x > u || xo((m * z + M * L) / x - .5) > .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)) } }
  574. var u = .5,
  575. o = Math.cos(30 * Yo),
  576. a = 16;
  577. return t.precision = function(n) { return arguments.length ? (a = (u = n * n) > 0 && 16, t) : Math.sqrt(u) }, t
  578. }
  579. function re(n) { var t = ee(function(t, e) { return n([t * Zo, e * Zo]) }); return function(n) { return le(t(n)) } }
  580. function ie(n) { this.stream = n }
  581. 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() } } }
  582. function oe(n) { return ae(function() { return n })() }
  583. function ae(n) {
  584. function t(n) { return n = a(n[0] * Yo, n[1] * Yo), [n[0] * h + l, c - n[1] * h] }
  585. function e(n) { return n = a.invert((n[0] - l) / h, (c - n[1]) / h), n && [n[0] * Zo, n[1] * Zo] }
  586. 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() }
  587. 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] }),
  588. h = 150,
  589. p = 480,
  590. g = 250,
  591. v = 0,
  592. d = 0,
  593. y = 0,
  594. M = 0,
  595. x = 0,
  596. b = Fa,
  597. _ = m,
  598. w = null,
  599. 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"),
  600. function() { return u = n.apply(this, arguments), t.invert = u.invert && e, r() } }
  601. function le(n) { return ue(n, function(t, e) { n.point(t * Yo, e * Yo) }) }
  602. function ce(n, t) { return [n, t] }
  603. function fe(n, t) { return [n > Fo ? n - Ho : -Fo > n ? n + Ho : n, t] }
  604. function se(n, t, e) { return n ? t || e ? Ct(pe(n), ge(t, e)) : pe(n) : t || e ? ge(t, e) : fe }
  605. function he(n) { return function(t, e) { return t += n, [t > Fo ? t - Ho : -Fo > t ? t + Ho : t, e] } }
  606. function pe(n) { var t = he(n); return t.invert = he(-n), t }
  607. function ge(n, t) {
  608. function e(n, t) { var e = Math.cos(t),
  609. a = Math.cos(n) * e,
  610. l = Math.sin(n) * e,
  611. c = Math.sin(t),
  612. 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),
  613. i = Math.sin(n),
  614. u = Math.cos(t),
  615. o = Math.sin(t); return e.invert = function(n, t) { var e = Math.cos(t),
  616. a = Math.cos(n) * e,
  617. l = Math.sin(n) * e,
  618. c = Math.sin(t),
  619. f = c * u - l * o; return [Math.atan2(l * u + c * o, a * r + f * i), tn(f * r - a * i)] }, e }
  620. function ve(n, t) { var e = Math.cos(n),
  621. r = Math.sin(n); return function(i, u, o, a) { var l = o * t;
  622. 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 - .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]) } }
  623. function de(n, t) { var e = dt(t);
  624. e[0] -= n, bt(e); var r = nn(-e[1]); return ((-e[2] < 0 ? -r : r) + 2 * Math.PI - Uo) % (2 * Math.PI) }
  625. 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] }) } }
  626. 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] }) } }
  627. function Me(n) { return n.source }
  628. function xe(n) { return n.target }
  629. function be(n, t, e, r) { var i = Math.cos(t),
  630. u = Math.sin(t),
  631. o = Math.cos(r),
  632. a = Math.sin(r),
  633. l = i * Math.cos(n),
  634. c = i * Math.sin(n),
  635. f = o * Math.cos(e),
  636. s = o * Math.sin(e),
  637. h = 2 * Math.asin(Math.sqrt(on(r - t) + i * o * on(e - n))),
  638. p = 1 / Math.sin(h),
  639. g = h ? function(n) { var t = Math.sin(n *= h) * p,
  640. e = Math.sin(h - n) * p,
  641. r = e * l + t * f,
  642. i = e * c + t * s,
  643. 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 }
  644. function _e() {
  645. function n(n, i) { var u = Math.sin(i *= Yo),
  646. o = Math.cos(i),
  647. a = xo((n *= Yo) - t),
  648. l = Math.cos(a);
  649. 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;
  650. 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 } }
  651. function we(n, t) {
  652. function e(t, e) { var r = Math.cos(t),
  653. i = Math.cos(e),
  654. 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),
  655. i = t(r),
  656. u = Math.sin(i),
  657. o = Math.cos(i); return [Math.atan2(n * u, r * o), Math.asin(r && e * u / r)] }, e }
  658. function Se(n, t) {
  659. 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),
  660. i = function(n) { return Math.tan(Fo / 4 + n / 2) },
  661. u = n === t ? Math.sin(n) : Math.log(r / Math.cos(t)) / Math.log(i(t) / i(n)),
  662. o = r * Math.pow(i(n), u) / u; return u ? (e.invert = function(n, t) { var e = o - t,
  663. 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 }
  664. function ke(n, t) {
  665. 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),
  666. i = n === t ? Math.sin(n) : (r - Math.cos(t)) / (t - n),
  667. 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) }
  668. function Ne(n, t) { return [n, Math.log(Math.tan(Fo / 4 + t / 2))] }
  669. function Ee(n) { var t, e = oe(n),
  670. r = e.scale,
  671. i = e.translate,
  672. 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(),
  673. l = i();
  674. u([
  675. [l[0] - a, l[1] - a],
  676. [l[0] + a, l[1] + a]
  677. ]) } } else t && (o = null); return o }, e.clipExtent(null) }
  678. function Ae(n, t) { return [Math.log(Math.tan(Fo / 4 + t / 2)), -n] }
  679. function Ce(n) { return n[0] }
  680. function ze(n) { return n[1] }
  681. 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;
  682. e[r++] = i } return e.slice(0, r) }
  683. function qe(n, t) { return n[0] - t[0] || n[1] - t[1] }
  684. function Te(n, t, e) { return (e[0] - t[0]) * (n[1] - t[1]) < (e[1] - t[1]) * (n[0] - t[0]) }
  685. function Re(n, t, e, r) { var i = n[0],
  686. u = e[0],
  687. o = t[0] - i,
  688. a = r[0] - u,
  689. l = n[1],
  690. c = e[1],
  691. f = t[1] - l,
  692. s = r[1] - c,
  693. h = (a * (l - c) - s * (i - u)) / (s * o - a * f); return [i + h * o, l + h * f] }
  694. function De(n) { var t = n[0],
  695. e = n[n.length - 1]; return !(t[0] - e[0] || t[1] - e[1]) }
  696. function Pe() { rr(this), this.edge = this.site = this.circle = null }
  697. function Ue(n) { var t = cl.pop() || new Pe; return t.site = n, t }
  698. function je(n) { Be(n), ol.remove(n), cl.push(n), rr(n) }
  699. function Fe(n) { var t = n.circle,
  700. e = t.x,
  701. r = t.cy,
  702. i = { x: e, y: r },
  703. u = n.P,
  704. o = n.N,
  705. a = [n];
  706. 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;
  707. 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;
  708. 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);
  709. l = a[0], c = a[s - 1], c.edge = Ke(l.site, c.site, null, i), $e(l), $e(c) }
  710. function He(n) { for (var t, e, r, i, u = n.x, o = n.y, a = ol._; a;)
  711. if (r = Oe(a, o) - u, r > Uo) a = a.L;
  712. 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 }
  713. a = a.R }
  714. 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));
  715. Be(t), Be(e); var c = t.site,
  716. f = c.x,
  717. s = c.y,
  718. h = n.x - f,
  719. p = n.y - s,
  720. g = e.site,
  721. v = g.x - f,
  722. d = g.y - s,
  723. y = 2 * (h * d - p * v),
  724. m = h * h + p * p,
  725. M = v * v + d * d,
  726. x = { x: (d * m - p * M) / y + f, y: (h * M - v * m) / y + s };
  727. nr(e.edge, c, g, x), l.edge = Ke(c, n, null, x), e.edge = Ke(n, g, null, x), $e(t), $e(e) } }
  728. function Oe(n, t) { var e = n.site,
  729. r = e.x,
  730. i = e.y,
  731. u = i - t; if (!u) return r; var o = n.P; if (!o) return -(1 / 0);
  732. e = o.site; var a = e.x,
  733. l = e.y,
  734. c = l - t; if (!c) return a; var f = a - r,
  735. s = 1 / u - 1 / c,
  736. 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 }
  737. 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 }
  738. function Ye(n) { this.site = n, this.edges = [] }
  739. 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--;)
  740. if (u = v[d], u && u.prepare())
  741. 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) }
  742. function Ve(n, t) { return t.angle - n.angle }
  743. function Xe() { rr(this), this.x = this.y = this.arc = this.site = this.cy = null }
  744. function $e(n) { var t = n.P,
  745. e = n.N; if (t && e) { var r = t.site,
  746. i = n.site,
  747. u = e.site; if (r !== u) { var o = i.x,
  748. a = i.y,
  749. l = r.x - o,
  750. c = r.y - a,
  751. f = u.x - o,
  752. s = u.y - a,
  753. h = 2 * (l * s - c * f); if (!(h >= -jo)) { var p = l * l + c * c,
  754. g = f * f + s * s,
  755. v = (s * p - c * g) / h,
  756. d = (l * g - f * p) / h,
  757. s = d + a,
  758. y = fl.pop() || new Xe;
  759. 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;)
  760. if (y.y < M.y || y.y === M.y && y.x <= M.x) { if (!M.L) { m = M.P; break }
  761. M = M.L } else { if (!M.R) { m = M; break }
  762. M = M.R }
  763. ll.insert(m, y), m || (al = y) } } } }
  764. function Be(n) { var t = n.circle;
  765. t && (t.P || (al = t.N), ll.remove(t), fl.push(t), rr(t), n.circle = null) }
  766. 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)) }
  767. function Je(n, t) { var e = n.b; if (e) return !0; var r, i, u = n.a,
  768. o = t[0][0],
  769. a = t[1][0],
  770. l = t[0][1],
  771. c = t[1][1],
  772. f = n.l,
  773. s = n.r,
  774. h = f.x,
  775. p = f.y,
  776. g = s.x,
  777. v = s.y,
  778. d = (h + g) / 2,
  779. 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 };
  780. e = { x: d, y: c } } else { if (u) { if (u.y < l) return } else u = { x: d, y: c };
  781. e = { x: d, y: l } } } else if (r = (h - g) / (v - p), i = y - r * d, -1 > r || r > 1)
  782. if (h > g) { if (u) { if (u.y >= c) return } else u = { x: (l - i) / r, y: l };
  783. e = { x: (c - i) / r, y: c } } else { if (u) { if (u.y < l) return } else u = { x: (c - i) / r, y: c };
  784. e = { x: (l - i) / r, y: l } }
  785. else if (v > p) { if (u) { if (u.x >= a) return } else u = { x: o, y: r * o + i };
  786. e = { x: a, y: r * a + i } } else { if (u) { if (u.x < o) return } else u = { x: a, y: r * a + i };
  787. e = { x: o, y: r * o + i } } return n.a = u, n.b = e, !0 }
  788. function Ge(n, t) { this.l = n, this.r = t, this.a = this.b = null }
  789. 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 }
  790. function Qe(n, t, e) { var r = new Ge(n, null); return r.a = t, r.b = e, il.push(r), r }
  791. 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) }
  792. function tr(n, t, e) { var r = n.a,
  793. i = n.b;
  794. 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) }
  795. function er() { this._ = null }
  796. function rr(n) { n.U = n.C = n.L = n.R = n.P = n.N = null }
  797. function ir(n, t) { var e = t,
  798. r = t.R,
  799. i = e.U;
  800. 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 }
  801. function ur(n, t) { var e = t,
  802. r = t.L,
  803. i = e.U;
  804. 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 }
  805. function or(n) { for (; n.L;) n = n.L; return n }
  806. 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;;)
  807. 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();
  808. else { if (!i) break;
  809. Fe(i.arc) }
  810. t && (We(t), Ze(t)); var o = { cells: ul, edges: il }; return ol = ll = il = ul = null, o }
  811. function lr(n, t) { return t.y - n.y || t.x - n.x }
  812. function cr(n, t, e) { return (n.x - e.x) * (t.y - n.y) - (n.x - t.x) * (e.y - n.y) }
  813. function fr(n) { return n.x }
  814. function sr(n) { return n.y }
  815. function hr() { return { leaf: !0, nodes: [], point: null, x: null, y: null } }
  816. function pr(n, t, e, r, i, u) { if (!n(t, e, r, i, u)) { var o = .5 * (e + i),
  817. a = .5 * (r + u),
  818. l = t.nodes;
  819. 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) } }
  820. 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,
  821. d = e - n.y,
  822. y = v * v + d * d; if (l > y) { var m = Math.sqrt(l = y);
  823. r = t - m, i = e - m, u = t + m, o = e + m, a = g } } for (var M = n.nodes, x = .5 * (f + h), b = .5 * (s + p), _ = t >= x, w = e >= b, S = w << 1 | _, k = S + 4; k > S; ++S)
  824. if (n = M[3 & S]) switch (3 & S) {
  825. case 0:
  826. c(n, f, s, x, b); break;
  827. case 1:
  828. c(n, x, s, h, b); break;
  829. case 2:
  830. c(n, f, b, x, p); break;
  831. case 3:
  832. c(n, x, b, h, p) } } }(n, r, i, u, o), a }
  833. function vr(n, t) { n = ao.rgb(n), t = ao.rgb(t); var e = n.r,
  834. r = n.g,
  835. i = n.b,
  836. u = t.r - e,
  837. o = t.g - r,
  838. 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)) } }
  839. function dr(n, t) { var e, r = {},
  840. 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 } }
  841. function yr(n, t) { return n = +n, t = +t,
  842. function(e) { return n * (1 - e) + t * e } }
  843. function mr(n, t) { var e, r, i, u = hl.lastIndex = pl.lastIndex = 0,
  844. o = -1,
  845. a = [],
  846. l = []; for (n += "", t += "";
  847. (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("") }) }
  848. function Mr(n, t) { for (var e, r = ao.interpolators.length; --r >= 0 && !(e = ao.interpolators[r](n, t));); return e }
  849. function xr(n, t) { var e, r = [],
  850. i = [],
  851. u = n.length,
  852. o = t.length,
  853. 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 } }
  854. function br(n) { return function(t) { return 0 >= t ? 0 : t >= 1 ? 1 : n(t) } }
  855. function _r(n) { return function(t) { return 1 - n(1 - t) } }
  856. function wr(n) { return function(t) { return .5 * (.5 > t ? n(2 * t) : 2 - n(2 - 2 * t)) } }
  857. function Sr(n) { return n * n }
  858. function kr(n) { return n * n * n }
  859. function Nr(n) { if (0 >= n) return 0; if (n >= 1) return 1; var t = n * n,
  860. e = t * n; return 4 * (.5 > n ? e : 3 * (n - t) + e - .75) }
  861. function Er(n) { return function(t) { return Math.pow(t, n) } }
  862. function Ar(n) { return 1 - Math.cos(n * Io) }
  863. function Cr(n) { return Math.pow(2, 10 * (n - 1)) }
  864. function zr(n) { return 1 - Math.sqrt(1 - n * n) }
  865. function Lr(n, t) { var e; return arguments.length < 2 && (t = .45), arguments.length ? e = t / Ho * Math.asin(1 / n) : (n = 1, e = t / 4),
  866. function(r) { return 1 + n * Math.pow(2, -10 * r) * Math.sin((r - e) * Ho / t) } }
  867. function qr(n) { return n || (n = 1.70158),
  868. function(t) { return t * t * ((n + 1) * t - n) } }
  869. function Tr(n) { return 1 / 2.75 > n ? 7.5625 * n * n : 2 / 2.75 > n ? 7.5625 * (n -= 1.5 / 2.75) * n + .75 : 2.5 / 2.75 > n ? 7.5625 * (n -= 2.25 / 2.75) * n + .9375 : 7.5625 * (n -= 2.625 / 2.75) * n + .984375 }
  870. function Rr(n, t) { n = ao.hcl(n), t = ao.hcl(t); var e = n.h,
  871. r = n.c,
  872. i = n.l,
  873. u = t.h - e,
  874. o = t.c - r,
  875. 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),
  876. function(n) { return sn(e + u * n, r + o * n, i + a * n) + "" } }
  877. function Dr(n, t) { n = ao.hsl(n), t = ao.hsl(t); var e = n.h,
  878. r = n.s,
  879. i = n.l,
  880. u = t.h - e,
  881. o = t.s - r,
  882. 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),
  883. function(n) { return cn(e + u * n, r + o * n, i + a * n) + "" } }
  884. function Pr(n, t) { n = ao.lab(n), t = ao.lab(t); var e = n.l,
  885. r = n.a,
  886. i = n.b,
  887. u = t.l - e,
  888. o = t.a - r,
  889. a = t.b - i; return function(n) { return pn(e + u * n, r + o * n, i + a * n) + "" } }
  890. function Ur(n, t) { return t -= n,
  891. function(e) { return Math.round(n + t * e) } }
  892. function jr(n) { var t = [n.a, n.b],
  893. e = [n.c, n.d],
  894. r = Hr(t),
  895. i = Fr(t, e),
  896. u = Hr(Or(e, t, -i)) || 0;
  897. 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 }
  898. function Fr(n, t) { return n[0] * t[0] + n[1] * t[1] }
  899. function Hr(n) { var t = Math.sqrt(Fr(n, n)); return t && (n[0] /= t, n[1] /= t), t }
  900. function Or(n, t, e) { return n[0] += e * t[0], n[1] += e * t[1], n }
  901. function Ir(n) { return n.length ? n.pop() + "," : "" }
  902. function Yr(n, t, e, r) { if (n[0] !== t[0] || n[1] !== t[1]) { var i = e.push("translate(", null, ",", null, ")");
  903. 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 + ")") }
  904. 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 + ")") }
  905. 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 + ")") }
  906. function Xr(n, t, e, r) { if (n[0] !== t[0] || n[1] !== t[1]) { var i = e.push(Ir(e) + "scale(", null, ",", null, ")");
  907. 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 + ")") }
  908. function $r(n, t) { var e = [],
  909. 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,
  910. function(n) { for (var t, i = -1, u = r.length; ++i < u;) e[(t = r[i]).i] = t.x(n); return e.join("") } }
  911. function Br(n, t) { return t = (t -= n = +n) || 1 / t,
  912. function(e) { return (e - n) / t } }
  913. function Wr(n, t) { return t = (t -= n = +n) || 1 / t,
  914. function(e) { return Math.max(0, Math.min(1, (e - n) / t)) } }
  915. 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 }
  916. function Gr(n) { for (var t = [], e = n.parent; null != e;) t.push(n), n = e, e = e.parent; return t.push(n), t }
  917. 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 }
  918. function Qr(n) { n.fixed |= 2 }
  919. function ni(n) { n.fixed &= -7 }
  920. function ti(n) { n.fixed |= 4, n.px = n.x, n.py = n.y }
  921. function ei(n) { n.fixed &= -5 }
  922. function ri(n, t, e) { var r = 0,
  923. i = 0; if (n.charge = 0, !n.leaf)
  924. 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() - .5, n.point.y += Math.random() - .5); var c = t * e[n.point.index];
  925. n.charge += n.pointCharge = c, r += c * n.point.x, i += c * n.point.y }
  926. n.cx = r / n.charge, n.cy = i / n.charge }
  927. function ii(n, t) { return ao.rebind(n, t, "sort", "children", "value"), n.nodes = n, n.links = fi, n }
  928. function ui(n, t) { for (var e = [n]; null != (n = e.pop());)
  929. if (t(n), (i = n.children) && (r = i.length))
  930. for (var r, i; --r >= 0;) e.push(i[r]) }
  931. function oi(n, t) { for (var e = [n], r = []; null != (n = e.pop());)
  932. if (r.push(n), (u = n.children) && (i = u.length))
  933. for (var i, u, o = -1; ++o < i;) e.push(u[o]);
  934. for (; null != (n = r.pop());) t(n) }
  935. function ai(n) { return n.children }
  936. function li(n) { return n.value }
  937. function ci(n, t) { return t.value - n.value }
  938. function fi(n) { return ao.merge(n.map(function(n) { return (n.children || []).map(function(t) { return { source: n, target: t } }) })) }
  939. function si(n) { return n.x }
  940. function hi(n) { return n.y }
  941. function pi(n, t, e) { n.y0 = t, n.y = e }
  942. function gi(n) { return ao.range(n.length) }
  943. function vi(n) { for (var t = -1, e = n[0].length, r = []; ++t < e;) r[t] = 0; return r }
  944. 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 }
  945. function yi(n) { return n.reduce(mi, 0) }
  946. function mi(n, t) { return n + t[1] }
  947. function Mi(n, t) { return xi(n, Math.ceil(Math.log(t.length) / Math.LN2 + 1)) }
  948. 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 }
  949. function bi(n) { return [ao.min(n), ao.max(n)] }
  950. function _i(n, t) { return n.value - t.value }
  951. function wi(n, t) { var e = n._pack_next;
  952. n._pack_next = t, t._pack_prev = n, t._pack_next = e, e._pack_prev = t }
  953. function Si(n, t) { n._pack_next = t, t._pack_prev = n }
  954. function ki(n, t) { var e = t.x - n.x,
  955. r = t.y - n.y,
  956. i = n.r + t.r; return .999 * i * i > e * e + r * r }
  957. function Ni(n) {
  958. 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,
  959. s = -(1 / 0),
  960. h = 1 / 0,
  961. 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))
  962. 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,
  963. v = 1,
  964. d = 1; for (a = i._pack_next; a !== i; a = a._pack_next, v++)
  965. if (ki(a, u)) { g = 1; break }
  966. if (1 == g)
  967. for (l = r._pack_prev; l !== a._pack_prev && !ki(l, u); l = l._pack_prev, d++);
  968. 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)) }
  969. var y = (f + s) / 2,
  970. m = (h + p) / 2,
  971. 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));
  972. n.r = M, e.forEach(Ai) } }
  973. function Ei(n) { n._pack_next = n._pack_prev = n }
  974. function Ai(n) { delete n._pack_next, delete n._pack_prev }
  975. 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)
  976. for (var u = -1, o = i.length; ++u < o;) Ci(i[u], t, e, r) }
  977. function zi(n, t, e) { var r = n.r + e.r,
  978. i = t.x - n.x,
  979. u = t.y - n.y; if (r && (i || u)) { var o = t.r + e.r,
  980. a = i * i + u * u;
  981. o *= o, r *= r; var l = .5 + (r - o) / (2 * a),
  982. c = Math.sqrt(Math.max(0, 2 * o * (r + a) - (r -= a) * r - o * o)) / (2 * a);
  983. 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 }
  984. function Li(n, t) { return n.parent == t.parent ? 1 : 2 }
  985. function qi(n) { var t = n.children; return t.length ? t[0] : n.t }
  986. function Ti(n) { var t, e = n.children; return (t = e.length) ? e[t - 1] : n.t }
  987. function Ri(n, t, e) { var r = e / (t.i - n.i);
  988. t.c -= r, t.s += e, n.c += r, t.z += e, t.m += e }
  989. 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) }
  990. function Pi(n, t, e) { return n.a.parent === t.parent ? n.a : e }
  991. function Ui(n) { return 1 + ao.max(n, function(n) { return n.y }) }
  992. function ji(n) { return n.reduce(function(n, t) { return n + t.x }, 0) / n.length }
  993. function Fi(n) { var t = n.children; return t && t.length ? Fi(t[0]) : n }
  994. function Hi(n) { var t, e = n.children; return e && (t = e.length) ? Hi(e[t - 1]) : n }
  995. function Oi(n) { return { x: n.x, y: n.y, dx: n.dx, dy: n.dy } }
  996. function Ii(n, t) { var e = n.x + t[3],
  997. r = n.y + t[0],
  998. i = n.dx - t[1] - t[3],
  999. 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 } }
  1000. function Yi(n) { var t = n[0],
  1001. e = n[n.length - 1]; return e > t ? [t, e] : [e, t] }
  1002. function Zi(n) { return n.rangeExtent ? n.rangeExtent() : Yi(n.range()) }
  1003. function Vi(n, t, e, r) { var i = e(n[0], n[1]),
  1004. u = r(t[0], t[1]); return function(n) { return u(i(n)) } }
  1005. function Xi(n, t) { var e, r = 0,
  1006. i = n.length - 1,
  1007. u = n[r],
  1008. 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 }
  1009. function $i(n) { return n ? { floor: function(t) { return Math.floor(t / n) * n }, ceil: function(t) { return Math.ceil(t / n) * n } } : Sl }
  1010. function Bi(n, t, e, r) { var i = [],
  1011. u = [],
  1012. o = 0,
  1013. 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)) } }
  1014. function Wi(n, t, e, r) {
  1015. function i() { var i = Math.min(n.length, t.length) > 2 ? Bi : Vi,
  1016. l = r ? Wr : Br; return o = i(n, t, l, e), a = i(t, n, l, Mr), u }
  1017. 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() }
  1018. function Ji(n, t) { return ao.rebind(n, t, "range", "rangeRound", "interpolate", "clamp") }
  1019. function Gi(n, t) { return Xi(n, $i(Ki(n, t)[2])), Xi(n, $i(Ki(n, t)[2])), n }
  1020. function Ki(n, t) { null == t && (t = 10); var e = Yi(n),
  1021. r = e[1] - e[0],
  1022. i = Math.pow(10, Math.floor(Math.log(r / t) / Math.LN10)),
  1023. u = t / r * i; return .15 >= u ? i *= 10 : .35 >= u ? i *= 5 : .75 >= u && (i *= 2), e[0] = Math.ceil(e[0] / i) * i, e[1] = Math.floor(e[1] / i) * i + .5 * i, e[2] = i, e }
  1024. function Qi(n, t) { return ao.range.apply(ao, Ki(n, t)) }
  1025. 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("")),
  1026. function(n) { return e(u.scale(n)) + u.symbol } }
  1027. i[7] || (i[7] = "." + eu(i[8], r)), e = i.join("") } else e = ",." + tu(r[2]) + "f"; return ao.format(e) }
  1028. function tu(n) { return -Math.floor(Math.log(n) / Math.LN10 + .01) }
  1029. 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) }
  1030. function ru(n, t, e, r) {
  1031. function i(n) { return (e ? Math.log(0 > n ? 0 : n) : -Math.log(n > 0 ? 0 : -n)) / Math.log(t) }
  1032. function u(n) { return e ? Math.pow(t, n) : -Math.pow(t, -n) }
  1033. 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),
  1034. o = [],
  1035. a = n[0],
  1036. l = n[1],
  1037. c = Math.floor(i(a)),
  1038. f = Math.ceil(i(l)),
  1039. s = t % 1 ? 2 : t; if (isFinite(f - c)) { if (e) { for (; f > c; c++)
  1040. for (var h = 1; s > h; h++) o.push(u(c) * h);
  1041. o.push(u(c)) } else
  1042. for (o.push(u(c)); c++ < f;)
  1043. 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--);
  1044. o = o.slice(c, f) } return o }, o.tickFormat = function(n, e) { if (!arguments.length) return Nl;
  1045. 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 - .5 > o * t && (o *= t), r >= o ? e(n) : "" } }, o.copy = function() { return ru(n.copy(), t, e, r) }, Ji(o, n) }
  1046. function iu(n, t, e) {
  1047. function r(t) { return n(i(t)) } var i = uu(t),
  1048. 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) }
  1049. function uu(n) { return function(t) { return 0 > t ? -Math.pow(-t, n) : Math.pow(t, n) } }
  1050. function ou(n, t) {
  1051. function e(e) { return u[((i.get(e) || ("range" === t.t ? i.set(e, n.push(e)) : NaN)) - 1) % u.length] }
  1052. 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;
  1053. 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],
  1054. c = i[1],
  1055. 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],
  1056. c = i[1],
  1057. 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],
  1058. f = i[c - 0],
  1059. s = i[1 - c],
  1060. 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],
  1061. f = i[c - 0],
  1062. s = i[1 - c],
  1063. 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) }
  1064. function au(n, t) {
  1065. function u() { var e = 0,
  1066. r = t.length; for (a = []; ++e < r;) a[e - 1] = ao.quantile(n, e / r); return o }
  1067. 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() }
  1068. function lu(n, t, e) {
  1069. function r(t) { return e[Math.max(0, Math.min(o, Math.floor(u * (t - n))))] }
  1070. 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() }
  1071. function cu(n, t) {
  1072. 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 }
  1073. function fu(n) {
  1074. 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 }
  1075. function su() { return 0 }
  1076. function hu(n) { return n.innerRadius }
  1077. function pu(n) { return n.outerRadius }
  1078. function gu(n) { return n.startAngle }
  1079. function vu(n) { return n.endAngle }
  1080. function du(n) { return n && n.padAngle }
  1081. function yu(n, t, e, r) { return (n - e) * t - (t - r) * n > 0 ? 0 : 1 }
  1082. function mu(n, t, e, r, i) { var u = n[0] - t[0],
  1083. o = n[1] - t[1],
  1084. a = (i ? r : -r) / Math.sqrt(u * u + o * o),
  1085. l = a * o,
  1086. c = -a * u,
  1087. f = n[0] + l,
  1088. s = n[1] + c,
  1089. h = t[0] + l,
  1090. p = t[1] + c,
  1091. g = (f + h) / 2,
  1092. v = (s + p) / 2,
  1093. d = h - f,
  1094. y = p - s,
  1095. m = d * d + y * y,
  1096. M = e - r,
  1097. x = f * p - h * s,
  1098. b = (0 > y ? -1 : 1) * Math.sqrt(Math.max(0, M * M * m - x * x)),
  1099. _ = (x * y - d * b) / m,
  1100. w = (-x * d - y * b) / m,
  1101. S = (x * y + d * b) / m,
  1102. k = (-x * d + y * b) / m,
  1103. N = _ - g,
  1104. E = w - v,
  1105. A = S - g,
  1106. C = k - v; return N * N + E * E > A * A + C * C && (_ = S, w = k), [
  1107. [_ - l, w - c],
  1108. [_ * e / M, w * e / M]
  1109. ] }
  1110. function Mu(n) {
  1111. function t(t) {
  1112. 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,
  1113. r = ze,
  1114. i = zt,
  1115. u = xu,
  1116. o = u.key,
  1117. a = .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 }
  1118. function xu(n) { return n.length > 1 ? n.join("L") : n + "Z" }
  1119. function bu(n) { return n.join("L") + "Z" }
  1120. 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("") }
  1121. 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("") }
  1122. 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("") }
  1123. function ku(n, t) { return n.length < 4 ? xu(n) : n[1] + Au(n.slice(1, -1), Cu(n, t)) }
  1124. 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)) }
  1125. function Eu(n, t) { return n.length < 3 ? xu(n) : n[0] + Au(n, Cu(n, t)) }
  1126. 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,
  1127. r = "",
  1128. i = n[0],
  1129. u = n[1],
  1130. o = t[0],
  1131. a = o,
  1132. 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];
  1133. r += "Q" + (u[0] + 2 * a[0] / 3) + "," + (u[1] + 2 * a[1] / 3) + "," + f[0] + "," + f[1] } return r }
  1134. 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 }
  1135. function zu(n) { if (n.length < 3) return xu(n); var t = 1,
  1136. e = n.length,
  1137. r = n[0],
  1138. i = r[0],
  1139. u = r[1],
  1140. o = [i, i, i, (r = n[1])[0]],
  1141. a = [u, u, u, r[1]],
  1142. 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("") }
  1143. 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("") }
  1144. 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("") }
  1145. function Tu(n, t) { var e = n.length - 1; if (e)
  1146. 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) }
  1147. function Ru(n, t) { return n[0] * t[0] + n[1] * t[1] + n[2] * t[2] + n[3] * t[3] }
  1148. 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)) }
  1149. function Pu(n, t) { return (t[1] - n[1]) / (t[0] - n[0]) }
  1150. 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 }
  1151. 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 }
  1152. function Fu(n) { return n.length < 3 ? xu(n) : n[0] + Au(n, ju(n)) }
  1153. 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 }
  1154. function Ou(n) {
  1155. function t(t) {
  1156. function l() { v.push("M", a(n(y), s), f, c(n(d.reverse()), s), "Z") }
  1157. for (var h, p, g, v = [], d = [], y = [], m = -1, M = t.length, x = En(e), b = En(i), _ = e === r ? function() {
  1158. return p
  1159. } : 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 = []);
  1160. return d.length && l(), v.length ? v.join("") : null
  1161. }
  1162. var e = Ce,
  1163. r = Ce,
  1164. i = 0,
  1165. u = ze,
  1166. o = zt,
  1167. a = xu,
  1168. l = a.key,
  1169. c = a,
  1170. f = "L",
  1171. s = .7;
  1172. 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
  1173. }
  1174. function Iu(n) { return n.radius }
  1175. function Yu(n) { return [n.x, n.y] }
  1176. function Zu(n) { return function() { var t = n.apply(this, arguments),
  1177. e = t[0],
  1178. r = t[1] - Io; return [e * Math.cos(r), e * Math.sin(r)] } }
  1179. function Vu() { return 64 }
  1180. function Xu() { return "circle" }
  1181. 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" }
  1182. function Bu(n) { return function() { var t, e, r;
  1183. (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 += .5, r.event && r.event.interrupt.call(this, this.__data__, r.index)) } }
  1184. function Wu(n, t, e) { return ko(n, Yl), n.namespace = t, n.id = e, n }
  1185. function Ju(n, t, e, r) { var i = n.id,
  1186. 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) })) }
  1187. function Gu(n) { return null == n && (n = ""),
  1188. function() { this.textContent = n } }
  1189. function Ku(n) { return null == n ? "__transition__" : "__transition_" + n + "__" }
  1190. function Qu(n, t, e, r, i) {
  1191. function u(n) { var t = v.delay; return f.t = t + l, n >= t ? o(n - t) : void(f.c = o) }
  1192. function o(e) { var i = g.active,
  1193. u = g[i];
  1194. 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)
  1195. if (r > +o) { var c = g[o];
  1196. c.timer.c = null, c.timer.t = NaN, --g.count, delete g[o] }
  1197. 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) {
  1198. (r = r.call(n, n.__data__, t)) && p.push(r) }), h = v.ease, s = v.duration }
  1199. 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 }),
  1200. v = g[r];
  1201. 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) }
  1202. function no(n, t, e) { n.attr("transform", function(n) { var r = t(n); return "translate(" + (isFinite(r) ? r : e(n)) + ",0)" }) }
  1203. function to(n, t, e) { n.attr("transform", function(n) { var r = t(n); return "translate(0," + (isFinite(r) ? r : e(n)) + ")" }) }
  1204. function eo(n) { return n.toISOString() }
  1205. function ro(n, t, e) {
  1206. function r(t) { return n(t) }
  1207. function i(n, e) { var r = n[1] - n[0],
  1208. i = r / e,
  1209. 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) {
  1210. function e(e) { return !isNaN(e) && !n.range(e, io(+e + 1), t).length } var u = r.domain(),
  1211. o = Yi(u),
  1212. 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()),
  1213. 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) }
  1214. function io(n) { return new Date(n) }
  1215. function uo(n) { return JSON.parse(n.responseText) }
  1216. function oo(n) { var t = fo.createRange(); return t.selectNode(fo.body), t.createContextualFragment(n.responseText) }
  1217. var ao = { version: "3.5.17" },
  1218. lo = [].slice,
  1219. co = function(n) { return lo.call(n) },
  1220. fo = this.document;
  1221. 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 } }
  1222. 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,
  1223. go = po.setAttribute,
  1224. vo = po.setAttributeNS,
  1225. yo = this.CSSStyleDeclaration.prototype,
  1226. mo = yo.setProperty;
  1227. 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) } }
  1228. 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,
  1229. u = n.length; if (1 === arguments.length) { for (; ++i < u;)
  1230. if (null != (r = n[i]) && r >= r) { e = r; break }
  1231. for (; ++i < u;) null != (r = n[i]) && e > r && (e = r) } else { for (; ++i < u;)
  1232. if (null != (r = t.call(n, n[i], i)) && r >= r) { e = r; break }
  1233. 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,
  1234. u = n.length; if (1 === arguments.length) { for (; ++i < u;)
  1235. if (null != (r = n[i]) && r >= r) { e = r; break }
  1236. for (; ++i < u;) null != (r = n[i]) && r > e && (e = r) } else { for (; ++i < u;)
  1237. if (null != (r = t.call(n, n[i], i)) && r >= r) { e = r; break }
  1238. 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,
  1239. o = n.length; if (1 === arguments.length) { for (; ++u < o;)
  1240. if (null != (r = n[u]) && r >= r) { e = i = r; break }
  1241. for (; ++u < o;) null != (r = n[u]) && (e > r && (e = r), r > i && (i = r)) } else { for (; ++u < o;)
  1242. if (null != (r = t.call(n, n[u], u)) && r >= r) { e = i = r; break }
  1243. 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,
  1244. u = n.length,
  1245. o = -1; if (1 === arguments.length)
  1246. for (; ++o < u;) i(e = +n[o]) && (r += e);
  1247. else
  1248. for (; ++o < u;) i(e = +t.call(n, n[o], o)) && (r += e); return r }, ao.mean = function(n, t) { var e, u = 0,
  1249. o = n.length,
  1250. a = -1,
  1251. l = o; if (1 === arguments.length)
  1252. for (; ++a < o;) i(e = r(n[a])) ? u += e : --l;
  1253. else
  1254. 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,
  1255. r = Math.floor(e),
  1256. i = +n[r - 1],
  1257. u = e - r; return u ? i + u * (n[r] - i) : i }, ao.median = function(n, t) { var u, o = [],
  1258. a = n.length,
  1259. l = -1; if (1 === arguments.length)
  1260. for (; ++l < a;) i(u = r(n[l])) && o.push(u);
  1261. else
  1262. for (; ++l < a;) i(u = r(t.call(n, n[l], l))) && o.push(u); return o.length ? ao.quantile(o.sort(e), .5) : void 0 }, ao.variance = function(n, t) { var e, u, o = n.length,
  1263. a = 0,
  1264. l = 0,
  1265. c = -1,
  1266. f = 0; if (1 === arguments.length)
  1267. for (; ++c < o;) i(e = r(n[c])) && (u = e - a, a += u / ++f, l += u * (e - a));
  1268. else
  1269. 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 };
  1270. var Mo = u(e);
  1271. 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) {
  1272. (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;)
  1273. 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;)
  1274. for (r = n[i], t = r.length; --t >= 0;) e[--o] = r[t]; return e };
  1275. var xo = Math.abs;
  1276. 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 = [],
  1277. u = a(xo(e)),
  1278. o = -1; if (n *= u, t *= u, e *= u, 0 > e)
  1279. for (;
  1280. (r = n + e * ++o) > t;) i.push(r / u);
  1281. else
  1282. for (;
  1283. (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) });
  1284. else if (Array.isArray(n)) { var r, i = -1,
  1285. u = n.length; if (1 === arguments.length)
  1286. for (; ++i < u;) e.set(i, n[i]);
  1287. else
  1288. for (; ++i < u;) e.set(t.call(n, r = n[i], i), r) } else
  1289. for (var o in n) e.set(o, n[o]); return e };
  1290. var bo = "__proto__",
  1291. _o = "\x00";
  1292. 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() {
  1293. 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 }
  1294. function t(n, e) { if (e >= u.length) return n; var r = [],
  1295. 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 = {},
  1296. u = [],
  1297. 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)
  1298. 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 };
  1299. var wo = ["webkit", "ms", "moz", "Moz", "o", "O"];
  1300. 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("."),
  1301. 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)
  1302. 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, "\\$&") };
  1303. var So = /[\\\^\$\*\+\?\|\[\]\(\)\.\{\}]/g,
  1304. ko = {}.__proto__ ? function(n, t) { n.__proto__ = t } : function(n, t) { for (var e in t) n[e] = t[e] },
  1305. No = function(n, t) { return t.querySelector(n) },
  1306. Eo = function(n, t) { return t.querySelectorAll(n) },
  1307. Ao = function(n, t) { var e = n.matches || n[x(n, "matchesSelector")]; return (Ao = function(n, t) { return e.call(n, t) })(n, t) };
  1308. "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) };
  1309. var Co = ao.selection.prototype = [];
  1310. Co.select = function(n) { var t, e, r, i, u = [];
  1311. 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 = [];
  1312. n = C(n); for (var i = -1, u = this.length; ++i < u;)
  1313. 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) };
  1314. var zo = "http://www.w3.org/1999/xhtml",
  1315. 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/" };
  1316. ao.ns = { prefix: Lo, qualify: function(n) { var t = n.indexOf(":"),
  1317. 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(),
  1318. r = (n = T(n)).length,
  1319. i = -1; if (t = e.classList) { for (; ++i < r;)
  1320. if (!t.contains(n[i])) return !1 } else
  1321. for (t = e.getAttribute("class"); ++i < r;)
  1322. 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) }
  1323. 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);
  1324. 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);
  1325. 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) {
  1326. function e(n, e) { var r, i, u, o = n.length,
  1327. s = e.length,
  1328. h = Math.min(o, s),
  1329. p = new Array(s),
  1330. g = new Array(s),
  1331. v = new Array(o); if (t) { var d, y = new c,
  1332. 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] }
  1333. 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,
  1334. 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([]),
  1335. l = E([]),
  1336. f = E([]); if ("function" == typeof n)
  1337. for (; ++u < o;) e(r = this[u], n.call(r, r.parentNode.__data__, u));
  1338. else
  1339. 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;)
  1340. 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++)
  1341. for (var e = this[n], r = 0, i = e.length; i > r; r++) { var u = e[r]; if (u) return u }
  1342. return null }, Co.size = function() { var n = 0; return Y(this, function() {++n }), n };
  1343. var qo = [];
  1344. 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._;
  1345. e = !1 } return this.each(X(n, t, e)) };
  1346. var To = ao.map({ mouseenter: "mouseover", mouseleave: "mouseout" });
  1347. fo && To.forEach(function(n) { "on" + n in fo && To.remove(n) });
  1348. var Ro, Do = 0;
  1349. ao.mouse = function(n) { return J(n, k()) };
  1350. var Po = this.navigator && /WebKit/.test(this.navigator.userAgent) ? -1 : 0;
  1351. ao.touch = function(n, t, e) { if (arguments.length < 3 && (e = t, t = k().changedTouches), t)
  1352. for (var r, i = 0, u = t.length; u > i; ++i)
  1353. if ((r = t[i]).identifier === e) return J(n, r) }, ao.behavior.drag = function() {
  1354. function n() { this.on("mousedown.drag", u).on("touchstart.drag", o) }
  1355. function e(n, t, e, u, o) { return function() {
  1356. function a() { var n, e, r = t(h, v);
  1357. 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 })) }
  1358. function l() { t(h, v) && (y.on(u + d, null).on(o + d, null), m(g), p({ type: "dragend" })) } var c, f = this,
  1359. s = ao.event.target.correspondingElement || ao.event.target,
  1360. h = f.parentNode,
  1361. p = r.of(f, arguments),
  1362. g = 0,
  1363. v = n(),
  1364. d = ".drag" + (null == v ? "" : "-" + v),
  1365. y = ao.select(e(s)).on(u + d, a).on(o + d, l),
  1366. m = W(s),
  1367. M = t(h, v);
  1368. 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"),
  1369. i = null,
  1370. u = e(b, ao.mouse, t, "mousemove", "mouseup"),
  1371. 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 }) : [] };
  1372. var Uo = 1e-6,
  1373. jo = Uo * Uo,
  1374. Fo = Math.PI,
  1375. Ho = 2 * Fo,
  1376. Oo = Ho - Uo,
  1377. Io = Fo / 2,
  1378. Yo = Fo / 180,
  1379. Zo = 180 / Fo,
  1380. Vo = Math.SQRT2,
  1381. Xo = 2,
  1382. $o = 4;
  1383. ao.interpolateZoom = function(n, t) { var e, r, i = n[0],
  1384. u = n[1],
  1385. o = n[2],
  1386. a = t[0],
  1387. l = t[1],
  1388. c = t[2],
  1389. f = a - i,
  1390. s = l - u,
  1391. 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)] };
  1392. else { var p = Math.sqrt(h),
  1393. g = (c * c - o * o + $o * h) / (2 * o * Xo * p),
  1394. v = (c * c - o * o - $o * h) / (2 * c * Xo * p),
  1395. d = Math.log(Math.sqrt(g * g + 1) - g),
  1396. y = Math.log(Math.sqrt(v * v + 1) - v);
  1397. r = (y - d) / Vo, e = function(n) { var t = n * r,
  1398. e = rn(d),
  1399. 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() {
  1400. function n(n) { n.on(L, s).on(Wo + ".zoom", p).on("dblclick.zoom", g).on(R, h) }
  1401. function e(n) { return [(n[0] - k.x) / k.k, (n[1] - k.y) / k.k] }
  1402. function r(n) { return [n[0] * k.k + k.x, n[1] * k.k + k.y] }
  1403. function i(n) { k.k = Math.max(A[0], Math.min(A[1], n)) }
  1404. function u(n, t) { t = r(t), k.x += n[0] - t[0], k.y += n[1] - t[1] }
  1405. 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) }
  1406. 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)) }
  1407. function l(n) { z++ || n({ type: "zoomstart" }) }
  1408. function c(n) { a(), n({ type: "zoom", scale: k.k, translate: [k.x, k.y] }) }
  1409. function f(n) {--z || (n({ type: "zoomend" }), d = null) }
  1410. function s() {
  1411. function n() { a = 1, u(ao.mouse(i), h), c(o) }
  1412. function r() { s.on(q, null).on(T, null), p(a), f(o) } var i = this,
  1413. o = D.of(i, arguments),
  1414. a = 0,
  1415. s = ao.select(t(i)).on(q, n).on(T, r),
  1416. h = e(ao.mouse(i)),
  1417. p = W(i);
  1418. Il.call(i), l(o) }
  1419. function h() {
  1420. 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 }
  1421. function t() { var t = ao.event.target;
  1422. 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(),
  1423. c = Date.now(); if (1 === l.length) { if (500 > c - M) { var f = l[0];
  1424. o(g, f, d[f.identifier], Math.floor(Math.log(k.k) / Math.LN2) + 1), S() }
  1425. M = c } else if (l.length > 1) { var f = l[0],
  1426. s = l[1],
  1427. h = f[0] - s[0],
  1428. p = f[1] - s[1];
  1429. y = h * h + p * p } }
  1430. function r() { var n, t, e, r, o = ao.touches(g);
  1431. Il.call(g); for (var a = 0, l = o.length; l > a; ++a, r = null)
  1432. if (e = o[a], r = d[e.identifier]) { if (t) break;
  1433. n = e, t = r }
  1434. if (r) { var f = (f = e[0] - n[0]) * f + (f = e[1] - n[1]) * f,
  1435. s = y && Math.sqrt(f / y);
  1436. 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) }
  1437. M = null, u(n, t), c(v) }
  1438. 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() }
  1439. ao.selectAll(_).on(m, null), w.on(L, s).on(R, h), N(), f(v) } var p, g = this,
  1440. v = D.of(g, arguments),
  1441. d = {},
  1442. y = 0,
  1443. m = ".zoom-" + ao.event.changedTouches[0].identifier,
  1444. x = "touchmove" + m,
  1445. b = "touchend" + m,
  1446. _ = [],
  1447. w = ao.select(g),
  1448. N = W(g);
  1449. t(), l(v), w.on(L, null).on(R, t) }
  1450. function p() { var n = D.of(this, arguments);
  1451. 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, .002 * Bo()) * k.k), u(d, v), c(n) }
  1452. function g() { var n = ao.mouse(this),
  1453. t = Math.log(k.k) / Math.LN2;
  1454. 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 },
  1455. E = [960, 500],
  1456. A = Jo,
  1457. C = 250,
  1458. z = 0,
  1459. L = "mousedown.zoom",
  1460. q = "mousemove.zoom",
  1461. T = "mouseup.zoom",
  1462. R = "touchstart.zoom",
  1463. 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),
  1464. t = k;
  1465. 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],
  1466. r = E[1],
  1467. i = d ? d[0] : e / 2,
  1468. u = d ? d[1] : r / 2,
  1469. 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),
  1470. a = e / r[2];
  1471. 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") };
  1472. var Bo, Wo, Jo = [0, 1 / 0];
  1473. ao.color = an, an.prototype.toString = function() { return this.rgb() + "" }, ao.hsl = ln;
  1474. var Go = ln.prototype = new an;
  1475. Go.brighter = function(n) { return n = Math.pow(.7, arguments.length ? n : 1), new ln(this.h, this.s, this.l / n) }, Go.darker = function(n) { return n = Math.pow(.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;
  1476. var Ko = fn.prototype = new an;
  1477. 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;
  1478. var Qo = 18,
  1479. na = .95047,
  1480. ta = 1,
  1481. ea = 1.08883,
  1482. ra = hn.prototype = new an;
  1483. 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;
  1484. var ia = mn.prototype = new an;
  1485. ia.brighter = function(n) { n = Math.pow(.7, arguments.length ? n : 1); var t = this.r,
  1486. e = this.g,
  1487. r = this.b,
  1488. 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(.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) };
  1489. 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 });
  1490. ua.forEach(function(n, t) { ua.set(n, Mn(t)) }), ao.functor = En, ao.xhr = An(m), ao.dsv = function(n, t) {
  1491. 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 }
  1492. function r(n) { return e.parse(n.responseText) }
  1493. function i(n) { return function(t) { return e.parse(t.responseText, n) } }
  1494. function u(t) { return t.map(o).join(n) }
  1495. function o(n) { return a.test(n) ? '"' + n.replace(/\"/g, '""') + '"' : n } var a = new RegExp('["' + n + "\n]"),
  1496. 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(",") + "}");
  1497. r = t ? function(n, e) { return t(i(n), e) } : i }) }, e.parseRows = function(n, t) {
  1498. 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;)
  1499. if (34 === n.charCodeAt(e)) { if (34 !== n.charCodeAt(e + 1)) break;++e }
  1500. 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++),
  1501. a = 1; if (10 === r) i = !0;
  1502. else if (13 === r) i = !0, 10 === n.charCodeAt(f) && (++f, ++a);
  1503. 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;
  1504. (r = e()) !== o;) { for (var h = []; r !== u && r !== o;) h.push(r), r = e();
  1505. 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,
  1506. 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");
  1507. var oa, aa, la, ca, fa = this[x(this, "requestAnimationFrame")] || function(n) { setTimeout(n, 17) };
  1508. 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) };
  1509. var sa = ["y", "z", "a", "f", "p", "n", "\xb5", "m", "", "k", "M", "G", "T", "P", "E", "Z", "Y"].map(Un);
  1510. 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] };
  1511. var ha = /(?:([^{])?([<>=^]))?([+\- ])?([$#])?(0)?(\d+)?(,)?(\.-?\d+)?([a-z%])?/i,
  1512. 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)))) } }),
  1513. ga = ao.time = {},
  1514. va = Date;
  1515. 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) } };
  1516. var da = Date.prototype;
  1517. 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) });
  1518. 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;
  1519. var ya = { "-": "", _: " ", 0: "0" },
  1520. ma = /^\s*\d+/,
  1521. Ma = /^%/;
  1522. ao.locale = function(n) { return { numberFormat: jn(n), timeFormat: Yn(n) } };
  1523. var xa = ao.locale({
  1524. decimal: ".",
  1525. thousands: ",",
  1526. grouping: [3],
  1527. currency: ["$", ""],
  1528. dateTime: "%a %b %e %X %Y",
  1529. date: "%m/%d/%Y",
  1530. time: "%H:%M:%S",
  1531. periods: ["AM", "PM"],
  1532. days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"],
  1533. shortDays: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
  1534. months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],
  1535. shortMonths: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"]
  1536. });
  1537. 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 } };
  1538. var ba = new ft;
  1539. ao.geo.stream = function(n, t) { n && _a.hasOwnProperty(n.type) ? _a[n.type](n, t) : ht(n, t) };
  1540. 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) } },
  1541. 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) } };
  1542. ao.geo.area = function(n) { return Sa = 0, ao.geo.stream(n, Na), Sa };
  1543. var Sa, ka = new ft,
  1544. 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;
  1545. Sa += 0 > n ? 4 * Fo + n : n, Na.lineStart = Na.lineEnd = Na.point = b } };
  1546. ao.geo.bounds = function() {
  1547. function n(n, t) { M.push(x = [f = n, h = n]), s > t && (s = t), t > p && (p = t) }
  1548. function t(t, e) { var r = dt([t * Yo, e * Yo]); if (y) { var i = mt(y, r),
  1549. u = [i[1], -i[0], 0],
  1550. o = mt(u, i);
  1551. bt(o), o = _t(o); var l = t - g,
  1552. c = l > 0 ? 1 : -1,
  1553. v = o[0] * Zo * c,
  1554. d = xo(l) > 180; if (d ^ (v > c * g && c * t > v)) { var m = o[1] * Zo;
  1555. m > p && (p = m) } else if (v = (v + 360) % 360 - 180, d ^ (v > c * g && c * t > v)) { var m = -o[1] * Zo;
  1556. s > m && (s = m) } else s > e && (s = e), e > p && (p = e);
  1557. 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);
  1558. y = r, g = t }
  1559. function e() { b.point = t }
  1560. function r() { x[0] = f, x[1] = h, b.point = n, y = null }
  1561. function i(n, e) { if (y) { var r = n - g;
  1562. m += xo(r) > 180 ? r + (r > 0 ? 360 : -360) : r } else v = n, d = e;
  1563. Na.point(n, e), t(n, e) }
  1564. function u() { Na.lineStart() }
  1565. function o() { i(v, d), Na.lineEnd(), xo(m) > Uo && (f = -(h = 180)), x[0] = f, x[1] = h, y = null }
  1566. function a(n, t) { return (t -= n) < 0 ? t + 360 : t }
  1567. function l(n, t) { return n[0] - t[0] }
  1568. 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 ? [
  1569. [NaN, NaN],
  1570. [NaN, NaN]
  1571. ] : [
  1572. [f, s],
  1573. [h, p]
  1574. ] } }(), 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,
  1575. e = Pa,
  1576. r = Ua,
  1577. 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] };
  1578. 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 } },
  1579. Fa = Rt(zt, jt, Ht, [-Fo, -Fo / 2]),
  1580. Ha = 1e9;
  1581. 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) : [
  1582. [n, t],
  1583. [e, r]
  1584. ] } }; return o.extent([
  1585. [0, 0],
  1586. [960, 500]
  1587. ]) }, (ao.geo.conicEqualArea = function() { return Vt(Xt) }).raw = Xt, ao.geo.albers = function() { return ao.geo.conicEqualArea().rotate([96, 0]).center([-.6, 38.7]).parallels([29.5, 45.5]).scale(1070) }, ao.geo.albersUsa = function() {
  1588. function n(n) { var u = n[0],
  1589. 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(),
  1590. o = ao.geo.conicEqualArea().rotate([154, 0]).center([-2, 58.5]).parallels([55, 65]),
  1591. a = ao.geo.conicEqualArea().rotate([157, 0]).center([-3, 19.9]).parallels([8, 18]),
  1592. l = { point: function(n, e) { t = [n, e] } }; return n.invert = function(n) { var t = u.scale(),
  1593. e = u.translate(),
  1594. r = (n[0] - e[0]) / t,
  1595. i = (n[1] - e[1]) / t; return (i >= .12 && .234 > i && r >= -.425 && -.214 > r ? o : i >= .166 && .234 > i && r >= -.214 && -.115 > r ? a : u).invert(n) }, n.stream = function(n) { var t = u.stream(n),
  1596. e = o.stream(n),
  1597. 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(.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(),
  1598. f = +t[0],
  1599. s = +t[1]; return e = u.translate(t).clipExtent([
  1600. [f - .455 * c, s - .238 * c],
  1601. [f + .455 * c, s + .238 * c]
  1602. ]).stream(l).point, r = o.translate([f - .307 * c, s + .201 * c]).clipExtent([
  1603. [f - .425 * c + Uo, s + .12 * c + Uo],
  1604. [f - .214 * c - Uo, s + .234 * c - Uo]
  1605. ]).stream(l).point, i = a.translate([f - .205 * c, s + .212 * c]).clipExtent([
  1606. [f - .214 * c + Uo, s + .166 * c + Uo],
  1607. [f - .115 * c - Uo, s + .234 * c - Uo]
  1608. ]).stream(l).point, n }, n.scale(1070) };
  1609. 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) } },
  1610. Ba = { point: Bt, lineStart: b, lineEnd: b, polygonStart: b, polygonEnd: b },
  1611. Wa = { point: Gt, lineStart: Kt, lineEnd: Qt, polygonStart: function() { Wa.lineStart = ne }, polygonEnd: function() { Wa.point = Gt, Wa.lineStart = Kt, Wa.lineEnd = Qt } };
  1612. ao.geo.path = function() {
  1613. 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() }
  1614. 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)), [
  1615. [Ya, Za],
  1616. [Va, Xa]
  1617. ] }, 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) {
  1618. 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() {
  1619. function n() { var n = "function" == typeof r ? r.apply(this, arguments) : r,
  1620. t = se(-n[0] * Yo, -n[1] * Yo, 0).invert,
  1621. 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],
  1622. 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,
  1623. i = n[1] * Yo,
  1624. u = t[1] * Yo,
  1625. o = Math.sin(r),
  1626. a = Math.cos(r),
  1627. l = Math.sin(i),
  1628. c = Math.cos(i),
  1629. f = Math.sin(u),
  1630. 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() {
  1631. function n() { return { type: "MultiLineString", coordinates: t() } }
  1632. 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,
  1633. v = g,
  1634. d = 90,
  1635. y = 360,
  1636. 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)) : [
  1637. [u, c],
  1638. [i, l]
  1639. ] }, 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)) : [
  1640. [r, a],
  1641. [e, o]
  1642. ] }, 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([
  1643. [-180, -90 + Uo],
  1644. [180, 90 - Uo]
  1645. ]).minorExtent([
  1646. [-180, -80 - Uo],
  1647. [180, 80 + Uo]
  1648. ]) }, ao.geo.greatArc = function() {
  1649. function n() { return { type: "LineString", coordinates: [t || r.apply(this, arguments), e || i.apply(this, arguments)] } } var t, e, r = Me,
  1650. 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 };
  1651. var Ja, Ga = { sphere: b, point: b, lineStart: _e, lineEnd: b, polygonStart: b, polygonEnd: b },
  1652. Ka = we(function(n) { return Math.sqrt(2 / (1 + n)) }, function(n) { return 2 * Math.asin(n / 2) });
  1653. (ao.geo.azimuthalEqualArea = function() { return oe(Ka) }).raw = Ka;
  1654. var Qa = we(function(n) { var t = Math.acos(n); return t && t / Math.sin(t) }, m);
  1655. (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;
  1656. var nl = we(function(n) { return 1 / n }, Math.atan);
  1657. (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;
  1658. var tl = we(function() { return 1 }, Math.asin);
  1659. (ao.geo.orthographic = function() { return oe(tl) }).raw = tl;
  1660. var el = we(function(n) { return 1 / (1 + n) }, function(n) { return 2 * Math.atan(n) });
  1661. (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),
  1662. t = n.center,
  1663. 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) {
  1664. function t(n) { if (n.length < 3) return []; var t, i = En(e),
  1665. u = En(r),
  1666. o = n.length,
  1667. a = [],
  1668. 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),
  1669. f = Le(l),
  1670. s = f[0] === c[0],
  1671. h = f[f.length - 1] === c[c.length - 1],
  1672. 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,
  1673. 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 };
  1674. var rl = ao.geom.polygon.prototype = [];
  1675. 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 .5 * i }, rl.centroid = function(n) { var t, e, r = -1,
  1676. i = this.length,
  1677. u = 0,
  1678. o = 0,
  1679. 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;
  1680. a && n.push(n[0]), f = i } return n };
  1681. var il, ul, ol, al, ll, cl = [],
  1682. fl = [];
  1683. 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;
  1684. n.L = t } else n.R = t;
  1685. 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;
  1686. 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,
  1687. u = n.L,
  1688. 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);
  1689. 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 }
  1690. t.C = !0, n = i, i = i.U } while (!n.C);
  1691. n && (n.C = !1) } } }, ao.geom.voronoi = function(n) {
  1692. function t(n) { var t = new Array(n.length),
  1693. r = a[0][0],
  1694. i = a[0][1],
  1695. u = a[1][0],
  1696. o = a[1][1]; return ar(e(n), a).cells.forEach(function(e, a) { var l = e.edges,
  1697. c = e.site,
  1698. 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 ? [
  1699. [r, o],
  1700. [u, o],
  1701. [u, i],
  1702. [r, i]
  1703. ] : [];
  1704. f.point = n[a] }), t }
  1705. 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,
  1706. i = ze,
  1707. u = r,
  1708. o = i,
  1709. 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 && [
  1710. [0, 0], n
  1711. ]) : a === sl ? null : a && a[1] }, t) };
  1712. var sl = [
  1713. [-1e6, -1e6],
  1714. [1e6, 1e6]
  1715. ];
  1716. ao.geom.delaunay = function(n) { return ao.geom.voronoi().triangles(n) }, ao.geom.quadtree = function(n, t, e, r, i) {
  1717. function u(n) {
  1718. function u(n, t, e, r, i, u, o, a) { if (!isNaN(e) && !isNaN(r))
  1719. if (n.leaf) { var l = n.x,
  1720. f = n.y; if (null != l)
  1721. if (xo(l - e) + xo(f - r) < .01) c(n, t, e, r, i, u, o, a);
  1722. else { var s = n.point;
  1723. 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) }
  1724. else n.x = e, n.y = r, n.point = t } else c(n, t, e, r, i, u, o, a) }
  1725. function c(n, t, e, r, i, o, a, l) { var c = .5 * (i + a),
  1726. f = .5 * (o + l),
  1727. s = e >= c,
  1728. h = r >= f,
  1729. p = h << 1 | s;
  1730. 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),
  1731. x = En(l); if (null != t) v = t, d = e, y = r, m = i;
  1732. else if (y = m = -(v = d = 1 / 0), s = [], h = [], g = n.length, o)
  1733. 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);
  1734. else
  1735. for (p = 0; g > p; ++p) { var b = +M(f = n[p], p),
  1736. _ = +x(f, p);
  1737. v > b && (v = b), d > _ && (d = _), b > y && (y = b), _ > m && (m = _), s.push(b), h.push(_) }
  1738. var w = y - v,
  1739. S = m - d;
  1740. 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,
  1741. 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 : [
  1742. [t, e],
  1743. [r, i]
  1744. ] }, 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;
  1745. var hl = /[-+]?(?:\d+\.?\d*|\.?\d+)(?:[eE][-+]?\d+)?/g,
  1746. pl = new RegExp(hl.source, "g");
  1747. 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;
  1748. var gl = function() { return m },
  1749. 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 } }),
  1750. dl = ao.map({ "in": m, out: _r, "in-out": wr, "out-in": function(n) { return wr(_r(n)) } });
  1751. ao.ease = function(n) { var t = n.indexOf("-"),
  1752. e = t >= 0 ? n.slice(0, t) : n,
  1753. 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 + ")" };
  1754. var yl = { a: 1, b: 0, c: 0, d: 1, e: 0, f: 0 };
  1755. 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() {
  1756. function n() { var n, c, s, h, p, g = {},
  1757. v = [],
  1758. d = ao.range(u),
  1759. y = []; for (e = [], r = [], n = 0, h = -1; ++h < u;) { for (c = 0, p = -1; ++p < u;) c += i[h][p];
  1760. 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],
  1761. M = y[m][p],
  1762. x = i[m][M],
  1763. b = c,
  1764. _ = c += x * n;
  1765. g[m + "-" + M] = { index: m, subindex: M, startAngle: b, endAngle: _, value: x } }
  1766. r[m] = { index: m, startAngle: s, endAngle: c, value: v[m] }, c += f } for (h = -1; ++h < u;)
  1767. for (p = h - 1; ++p < u;) { var w = g[h + "-" + p],
  1768. S = g[p + "-" + h];
  1769. (w.value || S.value) && e.push(w.value < S.value ? { source: S, target: w } : { source: w, target: S }) }
  1770. l && t() }
  1771. 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 = {},
  1772. 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() {
  1773. function n(n) { return function(t, e, r, i) { if (t.point !== n) { var u = t.cx - n.x,
  1774. o = t.cy - n.y,
  1775. a = i - e,
  1776. l = u * u + o * o; if (l > a * a / y) { if (v > l) { var c = t.charge / l;
  1777. n.px -= u * c, n.py -= o * c } return !0 } if (t.point && l && v > l) { var c = t.pointCharge / l;
  1778. n.px -= u * c, n.py -= o * c } } return !t.charge } }
  1779. function t(n) { n.px = ao.event.x, n.py = ao.event.y, l.resume() } var e, r, i, u, o, a, l = {},
  1780. c = ao.dispatch("start", "tick", "end"),
  1781. f = [1, 1],
  1782. s = .9,
  1783. h = ml,
  1784. p = Ml,
  1785. g = -30,
  1786. v = xl,
  1787. d = .1,
  1788. y = .64,
  1789. M = [],
  1790. x = []; return l.tick = function() { if ((i *= .99) < .005) return e = null, c.end({ type: "end", alpha: i = 0 }), !0; var t, r, l, h, p, v, y, m, b, _ = M.length,
  1791. 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) : .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))
  1792. for (; ++r < _;) l = M[r], l.x += (m - l.x) * y, l.y += (b - l.y) * y; if (g)
  1793. 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);
  1794. 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() {
  1795. 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];
  1796. 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;)
  1797. if (!isNaN(o = a[l][n])) return o;
  1798. return Math.random() * r } var t, e, r, i = M.length,
  1799. c = x.length,
  1800. s = f[0],
  1801. 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)
  1802. for (t = 0; c > t; ++t) u[t] = +h.call(this, x[t], t);
  1803. else
  1804. for (t = 0; c > t; ++t) u[t] = h; if (o = [], "function" == typeof p)
  1805. for (t = 0; c > t; ++t) o[t] = +p.call(this, x[t], t);
  1806. else
  1807. for (t = 0; c > t; ++t) o[t] = p; if (a = [], "function" == typeof g)
  1808. for (t = 0; i > t; ++t) a[t] = +g.call(this, M[t], t);
  1809. else
  1810. for (t = 0; i > t; ++t) a[t] = g; return l.resume() }, l.resume = function() { return l.alpha(.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") };
  1811. var ml = 20,
  1812. Ml = 1,
  1813. xl = 1 / 0;
  1814. ao.layout.hierarchy = function() {
  1815. function n(i) { var u, o = [i],
  1816. a = []; for (i.depth = 0; null != (u = o.pop());)
  1817. 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;
  1818. r && (u.value = 0), u.children = c } else r && (u.value = +r.call(n, u, u.depth) || 0), delete u.children;
  1819. return oi(i, function(n) { var e, i;
  1820. t && (e = n.children) && e.sort(t), r && (i = n.parent) && (i.value += n.value) }), a } var t = ci,
  1821. e = ai,
  1822. 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;
  1823. t.children || (t.value = +r.call(n, t, t.depth) || 0), (e = t.parent) && (e.value += t.value) })), t }, n }, ao.layout.partition = function() {
  1824. 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 } }
  1825. function t(n) { var e = n.children,
  1826. r = 0; if (e && (i = e.length))
  1827. for (var i, u = -1; ++u < i;) r = Math.max(r, t(e[u])); return 1 + r }
  1828. 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(),
  1829. i = [1, 1]; return e.size = function(n) { return arguments.length ? (i = n, e) : i }, ii(e, r) }, ao.layout.pie = function() {
  1830. function n(o) { var a, l = o.length,
  1831. c = o.map(function(e, r) { return +t.call(n, e, r) }),
  1832. f = +("function" == typeof r ? r.apply(this, arguments) : r),
  1833. s = ("function" == typeof i ? i.apply(this, arguments) : i) - f,
  1834. h = Math.min(Math.abs(s) / l, +("function" == typeof u ? u.apply(this, arguments) : u)),
  1835. p = h * (0 > s ? -1 : 1),
  1836. g = ao.sum(c),
  1837. v = g ? (s - l * p) / g : 0,
  1838. d = ao.range(l),
  1839. 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,
  1840. e = bl,
  1841. r = 0,
  1842. i = Ho,
  1843. 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 };
  1844. var bl = {};
  1845. ao.layout.stack = function() {
  1846. function n(a, l) { if (!(h = a.length)) return a; var c = a.map(function(e, r) { return t.call(n, e, r) }),
  1847. f = c.map(function(t) { return t.map(function(t, e) { return [u.call(n, t, e), o.call(n, t, e)] }) }),
  1848. s = e.call(n, f, l);
  1849. c = ao.permute(c, s), f = ao.permute(f, s); var h, p, g, v, d = r.call(n, f, l),
  1850. y = c[0].length; for (g = 0; y > g; ++g)
  1851. 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,
  1852. e = gi,
  1853. r = vi,
  1854. i = pi,
  1855. u = si,
  1856. 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 };
  1857. var _l = ao.map({ "inside-out": function(n) { var t, e, r = n.length,
  1858. i = n.map(di),
  1859. u = n.map(yi),
  1860. o = ao.range(r).sort(function(n, t) { return i[n] - i[t] }),
  1861. a = 0,
  1862. l = 0,
  1863. c = [],
  1864. 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 }),
  1865. wl = ao.map({ silhouette: function(n) { var t, e, r, i = n.length,
  1866. u = n[0].length,
  1867. o = [],
  1868. a = 0,
  1869. l = []; for (e = 0; u > e; ++e) { for (t = 0, r = 0; i > t; t++) r += n[t][e][1];
  1870. 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,
  1871. s = n[0],
  1872. h = s.length,
  1873. 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;
  1874. u += o * n[t][e][1] }
  1875. 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,
  1876. u = n[0].length,
  1877. o = 1 / i,
  1878. a = []; for (e = 0; u > e; ++e) { for (t = 0, r = 0; i > t; t++) r += n[t][e][1]; if (r)
  1879. for (t = 0; i > t; t++) n[t][e][1] /= r;
  1880. else
  1881. for (t = 0; i > t; t++) n[t][e][1] = o } for (e = 0; u > e; ++e) a[e] = 0; return a }, zero: vi });
  1882. ao.layout.histogram = function() {
  1883. 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)
  1884. 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,
  1885. e = Number,
  1886. r = bi,
  1887. 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() {
  1888. function n(n, u) { var o = e.call(this, n, u),
  1889. a = o[0],
  1890. l = i[0],
  1891. c = i[1],
  1892. 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;
  1893. 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),
  1894. r = 0,
  1895. 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() {
  1896. function n(n, i) { var f = o.call(this, n, i),
  1897. s = f[0],
  1898. h = t(s); if (oi(h, e), h.parent.m = -h.z, ui(h, r), c) ui(s, u);
  1899. else { var p = s,
  1900. g = s,
  1901. v = s;
  1902. 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,
  1903. y = l[0] / (g.x + a(g, p) / 2 + d),
  1904. m = l[1] / (v.depth || 1);
  1905. ui(s, function(n) { n.x = (n.x + d) * y, n.y = n.depth * m }) } return f }
  1906. function t(n) { for (var t, e = { A: null, children: [n] }, r = [e]; null != (t = r.pop());)
  1907. 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] }
  1908. function e(n) { var t = n.children,
  1909. e = n.parent.children,
  1910. r = n.i ? e[n.i - 1] : null; if (t.length) { Di(n); var u = (t[0].z + t[t.length - 1].z) / 2;
  1911. 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._));
  1912. n.parent.A = i(n, r, n.parent.A || e[0]) }
  1913. function r(n) { n._.x = n.z + n.parent.m, n.m += n.parent.m }
  1914. 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;
  1915. o && !Ti(u) && (u.t = o, u.m += s - f), i && !qi(l) && (l.t = i, l.m += c - h, e = n) } return e }
  1916. function u(n) { n.x *= l[0], n.y = n.depth * l[1] } var o = ao.layout.hierarchy().sort(null).value(null),
  1917. a = Li,
  1918. l = [1, 1],
  1919. 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() {
  1920. function n(n, u) { var o, a = t.call(this, n, u),
  1921. l = a[0],
  1922. c = 0;
  1923. oi(l, function(n) { var t = n.children;
  1924. 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),
  1925. s = Hi(l),
  1926. h = f.x - e(f, s) / 2,
  1927. 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),
  1928. e = Li,
  1929. r = [1, 1],
  1930. 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() {
  1931. 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 }
  1932. function t(e) { var u = e.children; if (u && u.length) { var o, a, l, c = s(e),
  1933. f = [],
  1934. h = u.slice(),
  1935. g = 1 / 0,
  1936. 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;
  1937. (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);
  1938. f.length && (i(f, v, c, !0), f.length = f.area = 0), u.forEach(t) } }
  1939. function e(t) { var r = t.children; if (r && r.length) { var u, o = s(t),
  1940. a = r.slice(),
  1941. 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);
  1942. r.forEach(e) } }
  1943. 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 }
  1944. function i(n, t, e, r) {
  1945. var i, u = -1,
  1946. o = n.length,
  1947. a = e.x,
  1948. c = e.y,
  1949. f = t ? l(n.area / t) : 0;
  1950. 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);
  1951. 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);
  1952. i.z = !1, i.dy += e.y + e.dy - c, e.x += f, e.dx -= f }
  1953. }
  1954. function u(r) { var i = o || a(r),
  1955. 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 }
  1956. var o, a = ao.layout.hierarchy(),
  1957. l = Math.round,
  1958. c = [1, 1],
  1959. f = null,
  1960. s = Oi,
  1961. h = !1,
  1962. p = "squarify",
  1963. g = .5 * (1 + Math.sqrt(5));
  1964. return u.size = function(n) { return arguments.length ? (c = n, u) : c }, u.padding = function(n) {
  1965. 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) }
  1966. 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)
  1967. }, ao.random = { normal: function(n, t) { var e = arguments.length; return 2 > e && (t = 1), 1 > e && (n = 0),
  1968. function() { var e, r, i;
  1969. 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 = {};
  1970. var Sl = { floor: m, ceil: m };
  1971. ao.scale.linear = function() { return Wi([0, 1], [0, 1], Mr, !1) };
  1972. var kl = { s: 1, g: 1, p: 1, r: 1, e: 1 };
  1973. ao.scale.log = function() { return ru(ao.scale.linear().domain([0, 1]), 10, !0, [1, 10]) };
  1974. var Nl = ao.format(".0e"),
  1975. El = { floor: function(n) { return -Math.ceil(-n) }, ceil: function(n) { return -Math.floor(-n) } };
  1976. ao.scale.pow = function() { return iu(ao.scale.linear(), 1, [0, 1]) }, ao.scale.sqrt = function() { return ao.scale.pow().exponent(.5) }, ao.scale.ordinal = function() { return ou([], { t: "range", a: [
  1977. []
  1978. ] }) }, 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) };
  1979. var Al = [2062260, 16744206, 2924588, 14034728, 9725885, 9197131, 14907330, 8355711, 12369186, 1556175].map(xn),
  1980. Cl = [2062260, 11454440, 16744206, 16759672, 2924588, 10018698, 14034728, 16750742, 9725885, 12955861, 9197131, 12885140, 14907330, 16234194, 8355711, 13092807, 12369186, 14408589, 1556175, 10410725].map(xn),
  1981. zl = [3750777, 5395619, 7040719, 10264286, 6519097, 9216594, 11915115, 13556636, 9202993, 12426809, 15186514, 15190932, 8666169, 11356490, 14049643, 15177372, 8077683, 10834324, 13528509, 14589654].map(xn),
  1982. Ll = [3244733, 7057110, 10406625, 13032431, 15095053, 16616764, 16625259, 16634018, 3253076, 7652470, 10607003, 13101504, 7695281, 10394312, 12369372, 14342891, 6513507, 9868950, 12434877, 14277081].map(xn);
  1983. ao.scale.quantile = function() { return au([], []) }, ao.scale.quantize = function() { return lu(0, 1, [0, 1]) }, ao.scale.threshold = function() { return cu([.5], [0, 1]) }, ao.scale.identity = function() { return fu([0, 1]) }, ao.svg = {}, ao.svg.arc = function() {
  1984. function n() { var n = Math.max(0, +e.apply(this, arguments)),
  1985. c = Math.max(0, +r.apply(this, arguments)),
  1986. f = o.apply(this, arguments) - Io,
  1987. s = a.apply(this, arguments) - Io,
  1988. h = Math.abs(s - f),
  1989. 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,
  1990. E = 0,
  1991. 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;
  1992. 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;
  1993. _ = 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))) > .001) { v = c > n ^ p ? 0 : 1; var T = g,
  1994. R = g; if (Fo > h) { var D = null == S ? [_, w] : null == x ? [m, M] : Re([m, M], [S, k], [x, b], [_, w]),
  1995. P = m - D[0],
  1996. U = M - D[1],
  1997. j = x - D[0],
  1998. F = b - D[1],
  1999. H = 1 / Math.sin(Math.acos((P * j + U * F) / (Math.sqrt(P * P + U * U) * Math.sqrt(j * j + F * F))) / 2),
  2000. O = Math.sqrt(D[0] * D[0] + D[1] * D[1]);
  2001. 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),
  2002. Y = mu([x, b], [_, w], c, T, p);
  2003. 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),
  2004. V = mu([_, w], null == x ? [m, M] : [x, b], n, -R, p);
  2005. 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("") }
  2006. 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,
  2007. r = pu,
  2008. i = su,
  2009. u = ql,
  2010. o = gu,
  2011. a = vu,
  2012. 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,
  2013. t = (+o.apply(this, arguments) + +a.apply(this, arguments)) / 2 - Io; return [Math.cos(t) * n, Math.sin(t) * n] }, n };
  2014. var ql = "auto";
  2015. ao.svg.line = function() { return Mu(m) };
  2016. 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 });
  2017. Tl.forEach(function(n, t) { t.key = n, t.closed = /-closed$/.test(n) });
  2018. var Rl = [0, 2 / 3, 1 / 3, 0],
  2019. Dl = [0, 1 / 3, 2 / 3, 0],
  2020. Pl = [0, 1 / 6, 2 / 3, 1 / 6];
  2021. 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() {
  2022. function n(n, a) { var l = t(this, u, n, a),
  2023. 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" }
  2024. function t(n, t, e, r) { var i = t.call(n, e, r),
  2025. u = a.call(n, i, r),
  2026. o = l.call(n, i, r) - Io,
  2027. 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)] } }
  2028. function e(n, t) { return n.a0 == t.a0 && n.a1 == t.a1 }
  2029. function r(n, t, e) { return "A" + n + "," + n + " 0 " + +(e > Fo) + ",1 " + t }
  2030. function i(n, t, e, r) { return "Q 0,0 " + r } var u = Me,
  2031. o = xe,
  2032. a = Iu,
  2033. l = gu,
  2034. 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() {
  2035. function n(n, i) { var u = t.call(this, n, i),
  2036. o = e.call(this, n, i),
  2037. a = (u.y + o.y) / 2,
  2038. 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,
  2039. e = xe,
  2040. 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(),
  2041. t = Yu,
  2042. e = n.projection; return n.projection = function(n) { return arguments.length ? e(Zu(t = n)) : t }, n }, ao.svg.symbol = function() {
  2043. function n(n, r) { return (Ul.get(t.call(this, n, r)) || $u)(e.call(this, n, r)) } var t = Xu,
  2044. 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 };
  2045. 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)),
  2046. 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),
  2047. e = t * jl / 2; return "M0," + e + "L" + t + "," + -e + " " + -t + "," + -e + "Z" }, "triangle-up": function(n) { var t = Math.sqrt(n / jl),
  2048. e = t * jl / 2; return "M0," + -e + "L" + t + "," + e + " " + -t + "," + e + "Z" } });
  2049. ao.svg.symbolTypes = Ul.keys();
  2050. var jl = Math.sqrt(3),
  2051. Fl = Math.tan(30 * Yo);
  2052. 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))) };
  2053. var Hl, Ol, Il = Bu(Ku()),
  2054. Yl = [],
  2055. Zl = 0;
  2056. 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,
  2057. u = this.namespace,
  2058. o = [];
  2059. 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,
  2060. a = this.namespace,
  2061. l = [];
  2062. n = C(n); for (var c = -1, f = this.length; ++c < f;)
  2063. for (var s = this[c], h = -1, p = s.length; ++h < p;)
  2064. 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) }
  2065. 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,
  2066. 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) {
  2067. function e() { this.removeAttribute(a) }
  2068. function r() { this.removeAttributeNS(a.space, a.local) }
  2069. 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)) }) }) }
  2070. 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,
  2071. a = ao.ns.qualify(n); return Ju(this, "attr." + n, t, a.local ? u : i) }, Yl.attrTween = function(n, t) {
  2072. function e(n, e) { var r = t.call(this, n, e, this.getAttribute(i)); return r && function(n) { this.setAttribute(i, r(n)) } }
  2073. 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) {
  2074. function i() { this.style.removeProperty(n) }
  2075. 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 }
  2076. r = "" } return Ju(this, "style." + n, e, u) }, Yl.styleTween = function(n, e, r) {
  2077. 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;
  2078. this[n].count < 2 && (t = this.parentNode) && t.removeChild(this) }) }, Yl.ease = function(n) { var t = this.id,
  2079. 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,
  2080. 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,
  2081. 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,
  2082. r = this.namespace; if (arguments.length < 2) { var i = Ol,
  2083. 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];
  2084. (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() {
  2085. function n(n) { n.each(function() { var n, c = ao.select(this),
  2086. f = this.__chart__ || e,
  2087. s = this.__chart__ = e.copy(),
  2088. h = null == l ? s.ticks ? s.ticks.apply(s, a) : s.domain() : l,
  2089. p = null == t ? s.tickFormat ? s.tickFormat.apply(s, a) : m : t,
  2090. g = c.selectAll(".tick").data(h, s),
  2091. v = g.enter().insert("g", ".domain").attr("class", "tick").style("opacity", Uo),
  2092. d = ao.transition(g.exit()).style("opacity", Uo).remove(),
  2093. y = ao.transition(g.order()).style("opacity", 1),
  2094. M = Math.max(i, 0) + o,
  2095. x = Zi(s),
  2096. b = c.selectAll(".domain").data([0]),
  2097. _ = (b.enter().append("path").attr("class", "domain"), ao.transition(b));
  2098. v.append("line"), v.append("text"); var w, S, k, N, E = v.select("line"),
  2099. A = y.select("line"),
  2100. C = g.select("text").text(p),
  2101. z = v.select("text"),
  2102. L = y.select("text"),
  2103. 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,
  2104. R = T.rangeBand() / 2;
  2105. f = s = function(n) { return T(n) + R } } else f.rangeBand ? f = s : d.call(n, s, f);
  2106. v.call(n, f, s), y.call(n, s, s) }) } var t, e = ao.scale.linear(),
  2107. r = Vl,
  2108. i = 6,
  2109. u = 6,
  2110. o = 3,
  2111. a = [10],
  2112. 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 };
  2113. var Vl = "bottom",
  2114. Xl = { top: 1, right: 1, bottom: 1, left: 1 };
  2115. ao.svg.brush = function() {
  2116. 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),
  2117. o = t.selectAll(".background").data([0]);
  2118. 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);
  2119. 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),
  2120. h = ao.transition(o);
  2121. 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) }) }
  2122. function e(n) { n.selectAll(".resize").attr("transform", function(n) { return "translate(" + s[+/e$/.test(n)] + "," + h[+/^s/.test(n)] + ")" }) }
  2123. function r(n) { n.select(".extent").attr("x", s[0]), n.selectAll(".extent,.n>rect,.s>rect").attr("width", s[1] - s[0]) }
  2124. function i(n) { n.select(".extent").attr("y", h[0]), n.selectAll(".extent,.e>rect,.w>rect").attr("height", h[1] - h[0]) }
  2125. function u() {
  2126. function u() { 32 == ao.event.keyCode && (C || (M = null, L[0] -= s[1], L[1] -= h[1], C = 2), S()) }
  2127. function v() { 32 == ao.event.keyCode && 2 == C && (L[0] += s[1], L[1] += h[1], C = 0, S()) }
  2128. function d() { var n = ao.mouse(b),
  2129. t = !1;
  2130. 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" })) }
  2131. function y(n, t, e) { var r, i, u = Zi(t),
  2132. l = u[0],
  2133. c = u[1],
  2134. f = L[e],
  2135. v = e ? h : s,
  2136. 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 }
  2137. 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,
  2138. _ = ao.select(ao.event.target),
  2139. w = l.of(b, arguments),
  2140. k = ao.select(b),
  2141. N = _.datum(),
  2142. E = !/^(n|s)$/.test(N) && c,
  2143. A = !/^(e|w)$/.test(N) && f,
  2144. C = _.classed("extent"),
  2145. z = W(b),
  2146. L = ao.mouse(b),
  2147. 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];
  2148. else if (N) { var T = +/w$/.test(N),
  2149. R = +/^n/.test(N);
  2150. 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());
  2151. 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"),
  2152. c = null,
  2153. f = null,
  2154. s = [0, 0],
  2155. h = [0, 0],
  2156. p = !0,
  2157. g = !0,
  2158. v = Bl[0]; return n.event = function(n) { n.each(function() { var n = l.of(this, arguments),
  2159. t = { x: s, y: h, i: o, j: a },
  2160. e = this.__chart__ || t;
  2161. 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),
  2162. r = xr(h, t.y); return o = a = null,
  2163. 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 ? [
  2164. [e, i],
  2165. [r, u]
  2166. ] : 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") };
  2167. 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" },
  2168. Bl = [
  2169. ["n", "e", "s", "w", "nw", "ne", "se", "sw"],
  2170. ["e", "w"],
  2171. ["n", "s"],
  2172. []
  2173. ],
  2174. Wl = ga.format = xa.timeFormat,
  2175. Jl = Wl.utc,
  2176. Gl = Jl("%Y-%m-%dT%H:%M:%S.%LZ");
  2177. 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;
  2178. var Kl = [1e3, 5e3, 15e3, 3e4, 6e4, 3e5, 9e5, 18e5, 36e5, 108e5, 216e5, 432e5, 864e5, 1728e5, 6048e5, 2592e6, 7776e6, 31536e6],
  2179. Ql = [
  2180. [ga.second, 1],
  2181. [ga.second, 5],
  2182. [ga.second, 15],
  2183. [ga.second, 30],
  2184. [ga.minute, 1],
  2185. [ga.minute, 5],
  2186. [ga.minute, 15],
  2187. [ga.minute, 30],
  2188. [ga.hour, 1],
  2189. [ga.hour, 3],
  2190. [ga.hour, 6],
  2191. [ga.hour, 12],
  2192. [ga.day, 1],
  2193. [ga.day, 2],
  2194. [ga.week, 1],
  2195. [ga.month, 1],
  2196. [ga.month, 3],
  2197. [ga.year, 1]
  2198. ],
  2199. nc = Wl.multi([
  2200. [".%L", function(n) { return n.getMilliseconds() }],
  2201. [":%S", function(n) { return n.getSeconds() }],
  2202. ["%I:%M", function(n) { return n.getMinutes() }],
  2203. ["%I %p", function(n) { return n.getHours() }],
  2204. ["%a %d", function(n) { return n.getDay() && 1 != n.getDate() }],
  2205. ["%b %d", function(n) { return 1 != n.getDate() }],
  2206. ["%B", function(n) { return n.getMonth() }],
  2207. ["%Y", zt]
  2208. ]),
  2209. tc = { range: function(n, t, e) { return ao.range(Math.ceil(n / e) * e, +t, e).map(io) }, floor: m, ceil: m };
  2210. Ql.year = ga.year, ga.scale = function() { return ro(ao.scale.linear(), Ql, nc) };
  2211. var ec = Ql.map(function(n) { return [n[0].utc, n[1]] }),
  2212. rc = Jl.multi([
  2213. [".%L", function(n) { return n.getUTCMilliseconds() }],
  2214. [":%S", function(n) { return n.getUTCSeconds() }],
  2215. ["%I:%M", function(n) { return n.getUTCMinutes() }],
  2216. ["%I %p", function(n) { return n.getUTCHours() }],
  2217. ["%a %d", function(n) { return n.getUTCDay() && 1 != n.getUTCDate() }],
  2218. ["%b %d", function(n) { return 1 != n.getUTCDate() }],
  2219. ["%B", function(n) { return n.getUTCMonth() }],
  2220. ["%Y", zt]
  2221. ]);
  2222. 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
  2223. }();