diff --git a/.vscode/launch.json b/.vscode/launch.json index 699ca991..f72e06f3 100644 --- a/.vscode/launch.json +++ b/.vscode/launch.json @@ -2,6 +2,7 @@ { "version": "0.1.0", "configurations": [ + { "name": "Launch Extension", "type": "extensionHost", @@ -45,6 +46,21 @@ "cwd": "${workspaceRoot}" // "preLaunchTask": "npm" }, + { + "name": "PyOCD debug server", + "type": "node", + "request": "launch", + "runtimeArgs": [ "--nolazy" ], + "program": "${workspaceRoot}/src/pyocd.ts", + "stopOnEntry": false, + "args": [ "--server=4711" ], + "sourceMaps": true, + "outFiles": [ + "${workspaceRoot}/out/**/*.js" + ], + "cwd": "${workspaceRoot}" + // "preLaunchTask": "npm" + }, { "name": "Launch Tests", "type": "extensionHost", diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 00000000..d77cdaf1 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,8 @@ +# V0.1.6 + +* Improved parsing of SVD definitions (registers without fields; repeating registesr (dim, dimInteger, dimIncrement)) +* Added initial support for PyOCD GDB Server (SWO not supported) + +# V0.1.5 + +* Initial Public Preview on VS Code Market Place \ No newline at end of file diff --git a/README.md b/README.md index 69604a77..73e67c9b 100644 --- a/README.md +++ b/README.md @@ -1,22 +1,29 @@ # Cortex Debug +![Visual Studio Code with Cortex-Debug Installed](./images/vs-code-screenshot.png) + Debugging support for ARM Cortex-M Microcontrollers with the following features: * Supports J-Link or OpenOCD GDB Server * Cortex Core Register Viewer * Peripheral Register Viewer (Defined through standard SVD file) -* SWO Deocding - "console" text output and binary data (signed and unsigned 32-bit integers, Q16.16 fixed point integers) - * Currently SWO decoding is not supported when using OpenOCD on Windows -* Live graphing of SWO decoded data. +* SWO Deocding - "console" text output and binary data (signed and unsigned 32-bit integers, Q16.16 fixed point integers, single percision floating point values) + * Currently decoding of ITM Timestamp and Synchronization packets are not supported; these features will need to be disabled in the code for the microcontroller. +* Support for Custom ITM Data Decoders: + * Ability to define JavaScript modules to decode complex data formats streamed over a particular ITM port. Data can be printed to a output window, or sent to the graphing system. +* Live graphing of decoded ITM data. +* Raw Memory Viewer (From the command menu select Cortex-Debug: View Memory) +* Initial support for PyOCD GDB Server (No SWO support for PyOCD) + +### In Progress Features +* RTOS/Muti-Threaded Support (Dependant on GDB server support) ### Planned Features * Additional Graphing Options -* Raw Memory Viewer * Enhanced SVD Auto-selection * Support for Black Magic Probe -* SWO Decoding for OpenOCD on Windows -* SWO Decoding for 32-bit floating point number +* Semihosting Support ## Installation @@ -27,8 +34,6 @@ Requirements: * J-Link Software Tools - provides the J-Link GDB Server for J-Link based debuggers (https://www.segger.com/downloads/jlink) * OpenOCD - provides a GDB Server that can be used with a number of debuggers (http://openocd.org) -The extension is not currently available through the Visual Studio Code Extension Marketplace, to install download the cortex-debug.vsix extension file (from the releases page https://github.com/Marus/cortex-debug/releases) and install using the 'Extensions: Install from VSIX...' command in Visual Studio Code. - ## Usage See https://marcelball.ca/projects/cortex-debug/ for usage information diff --git a/config_base.json b/config_base.json index bc207165..1048b97e 100644 --- a/config_base.json +++ b/config_base.json @@ -66,17 +66,14 @@ "default": 65535, "description": "Maximum value for the X-Axis" }, - "ports": { + "plots": { "type": "array", "items": { "type": "object", "properties": { - "number": { - "type": "number", - "minimum": 0, - "maximum": 31, - "description": "The SWO port number", - "default": 0 + "graphId": { + "type": "string", + "description": "Graph Data Source Id for the plot." }, "label": { "type": "string", @@ -88,11 +85,10 @@ } }, "required": [ - "number", - "label" + "graphId" ] }, - "description": "SWO Port configuration. Ports selected must be configured as a \"graph\" format port in the \"swoConfig\" section" + "description": "Plot configurations. Data sources must be configured for \"graph\" (or \"advanced\" with a decoder that sends graph data) in the \"swoConfig\" section" }, "annotate": { "type": "boolean", @@ -104,7 +100,7 @@ "description": "Label for Graph" } }, - "required": [ "label", "ports", "minimum", "maximum" ] + "required": [ "label", "plots", "minimum", "maximum" ] }, { "type": "object", @@ -115,13 +111,13 @@ "x-y-plot" ] }, - "xPort": { - "type": "number", - "description": "SWO Port for the X axis" + "xGraphId": { + "type": "string", + "description": "Graph Data Source Id for the X axis" }, - "yPort": { - "type": "number", - "description": "SWO Port for the Y axis" + "yGraphId": { + "type": "string", + "description": "Graph Data Source Id Port for the Y axis" }, "label": { "type": "string", @@ -154,8 +150,8 @@ } }, "required": [ - "xPort", - "yPort", + "xGraphId", + "yGraphId", "label" ] } @@ -184,42 +180,82 @@ "type": "array", "description": "SWO Port Configuration", "items": { - "type": "object", - "properties": { - "number": { - "type": "number", - "description": "SWO Port Number", - "minimum": 0, - "maximum": 31 + "anyOf": [ + { + "type": "object", + "properties": { + "type": { "type": "string", "enum": ["console"] }, + "number": { "type": "number", "description": "SWO Port Number", "minimum": 0, "maximum": 31 }, + "label": { "type": "string", "description": "A label for the output window." } + }, + "required": [ "number" ] }, - "format": { - "type": "string", - "description": "Output format for this port.", - "enum": [ - "console", - "binary", - "graph" - ] + { + "type": "object", + "properties": { + "type": { "type": "string", "enum": ["binary"] }, + "number": { "type": "number", "description": "ITM Port Number", "minimum": 0, "maximum": 31 }, + "encoding": { + "type": "string", + "description": "This property is only used for binary and graph output formats.", + "default": "unsigned", + "enum": [ + "unsigned", + "signed", + "Q16.16", + "float" + ] + }, + "scale": { + "type": "number", + "description": "This setting will scale the raw value from the ITM port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", + "default": 1 + }, + "label": { "type": "string", "description": "A label for the output window." } + }, + "required": ["number"] }, - "encoding": { - "type": "string", - "description": "This property is only used for binary and graph output formats.", - "default": "unsigned", - "enum": [ - "unsigned", - "signed", - "Q16.16" - ] + { + "type": "object", + "properties": { + "type": { "type": "string", "enum": ["graph"] }, + "number": { "type": "number", "description": "ITM Port Number", "minimum": 0, "maximum": 31 }, + "encoding": { + "type": "string", + "description": "This property is only used for binary and graph output formats.", + "default": "unsigned", + "enum": [ + "unsigned", + "signed", + "Q16.16", + "float" + ] + }, + "scale": { + "type": "number", + "description": "This setting will scale the raw value from the ITM port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", + "default": 1 + }, + "graphId": { + "type": "string", + "description": "The identifier to use for this data in graph configurations." + } + }, + "required": ["number", "graphId"] }, - "scale": { - "type": "number", - "description": "This setting will scale the raw value from the SWO port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", - "default": 1 + { + "type": "object", + "properties": { + "type": { "type": "string", "enum": ["advanced"] }, + "number": { "type": "number", "description": "ITM Port Number", "minimum": 0, "maximum": 31 }, + "decoder": { + "type": "string", + "description": "Path to a javascript module to implement the decoding functionality." + }, + "config": { "type": "object", "additionalProperties": true } + }, + "required": ["number", "decoder"] } - }, - "required": [ - "number", - "format" ] } } @@ -313,5 +349,35 @@ "required": [], "properties": {} } + }, + "pyocd-gdb": { + "common": { + "properties": { + "pyocdPath": { + "type": "string", + "description": "Path to the pyocd-gdbserver executable", + "default": "pyocd-gdbserver" + }, + "boardId": { + "type": "string", + "description": "Connect to board by board id. Only needed if multiple PyOCD compatible boards are connected." + }, + "target": { + "type": "string", + "description": "PyOCD Target identifier. Needed if debugging custom hardware; not needed for official MBed boards.", + "enum": ["kl25z","kl26z","lpc824","k82f25615","lpc11xx_32","kinetis","lpc800","lpc4088qsb","maxwsnenv","kl05z","k64f","lpc1768","lpc4088","lpc4330","max32600mbed","k66f18","w7500","ke18f16","k22f","lpc4088dm","ke15z7","kv11z7","nrf51","nrf52","kv10z7","k20d50m","kl46z","stm32f103rc","kl27z4","kw40z4","cortex_m","lpc11u24","stm32f051","kl02z","ncs36510","kl28z","kl43z4","kw01z4"] + } + }, + "required": [] + }, + "launch": { + "required": [], + "properties": {} + }, + "attach": { + "required": [], + "properties": {} + }, + "removeProperties": [ "swoConfig", "graphConfig" ] } } \ No newline at end of file diff --git a/grapher/main.bundle.js b/grapher/main.bundle.js index bd66bcf4..2df9cf97 100644 --- a/grapher/main.bundle.js +++ b/grapher/main.bundle.js @@ -1,2 +1,2 @@ -!function(t){function n(e){if(r[e])return r[e].exports;var i=r[e]={i:e,l:!1,exports:{}};return t[e].call(i.exports,i,i.exports,n),i.l=!0,i.exports}var r={};n.m=t,n.c=r,n.i=function(t){return t},n.d=function(t,r,e){n.o(t,r)||Object.defineProperty(t,r,{configurable:!1,enumerable:!0,get:e})},n.n=function(t){var r=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(r,"a",r),r},n.o=function(t,n){return Object.prototype.hasOwnProperty.call(t,n)},n.p="",n(n.s=469)}([function(t,n,r){"use strict";function e(t){return t>1?0:t<-1?c:Math.acos(t)}function i(t){return t>1?f:t<-1?-f:Math.asin(t)}function u(t){return(t=w(t/2))*t}r.d(n,"o",function(){return o}),r.d(n,"w",function(){return a}),r.d(n,"a",function(){return c}),r.d(n,"k",function(){return f}),r.d(n,"v",function(){return s}),r.d(n,"b",function(){return l}),r.d(n,"h",function(){return h}),r.d(n,"g",function(){return d}),r.d(n,"p",function(){return p}),r.d(n,"l",function(){return v}),r.d(n,"e",function(){return g}),r.d(n,"c",function(){return y}),r.d(n,"u",function(){return _}),r.d(n,"m",function(){return b}),r.d(n,"i",function(){return m}),r.d(n,"r",function(){return x}),r.d(n,"d",function(){return w}),r.d(n,"q",function(){return M}),r.d(n,"n",function(){return k}),r.d(n,"j",function(){return T}),n.s=e,n.f=i,n.t=u;var o=1e-6,a=1e-12,c=Math.PI,f=c/2,s=c/4,l=2*c,h=180/c,d=c/180,p=Math.abs,v=Math.atan,g=Math.atan2,y=Math.cos,_=Math.ceil,b=Math.exp,m=(Math.floor,Math.log),x=Math.pow,w=Math.sin,M=Math.sign||function(t){return t>0?1:t<0?-1:0},k=Math.sqrt,T=Math.tan},function(t,n,r){"use strict";var e=r(74);r.d(n,"a",function(){return e.a});var i=r(361);r.d(n,"b",function(){return i.a});var u=r(146);r.d(n,"c",function(){return u.a});var o=r(362);r.d(n,"d",function(){return o.a});var a=r(75);r.d(n,"e",function(){return a.a});var c=r(76);r.d(n,"f",function(){return c.a});var f=r(41);r.d(n,"g",function(){return f.a});var s=r(363);r.d(n,"h",function(){return s.a});var l=r(364);r.d(n,"i",function(){return l.a});var h=r(5);r.d(n,"j",function(){return h.a});var d=r(78);r.d(n,"k",function(){return d.a});var p=r(150);r.d(n,"l",function(){return p.a});var v=r(149);r.d(n,"m",function(){return v.a});var g=r(391);r.d(n,"n",function(){return g.a});var y=r(392);r.d(n,"o",function(){return y.a});var _=r(80);r.d(n,"p",function(){return _.a});var b=r(77);r.d(n,"q",function(){return b.a}),r.d(n,"r",function(){return b.b})},function(t,n,r){"use strict";function e(t,n,r,o){function a(n){return t(n=new Date(+n)),n}return a.floor=a,a.ceil=function(r){return t(r=new Date(r-1)),n(r,1),t(r),r},a.round=function(t){var n=a(t),r=a.ceil(t);return t-n0))return o;do{o.push(u=new Date(+r)),n(r,i),t(r)}while(u=n)for(;t(n),!r(n);)n.setTime(n-1)},function(t,e){if(t>=t)if(e<0)for(;++e<=0;)for(;n(t,-1),!r(t););else for(;--e>=0;)for(;n(t,1),!r(t););})},r&&(a.count=function(n,e){return i.setTime(+n),u.setTime(+e),t(i),t(u),Math.floor(r(i,u))},a.every=function(t){return t=Math.floor(t),isFinite(t)&&t>0?t>1?a.filter(o?function(n){return o(n)%t==0}:function(n){return a.count(0,n)%t==0}):a:null}),a}n.a=e;var i=new Date,u=new Date},function(t,n,r){"use strict";var e=r(92);r.d(n,"a",function(){return e.a}),r.d(n,"b",function(){return e.b}),r.d(n,"c",function(){return e.c});var i=r(17);r.d(n,"d",function(){return i.a});var u=r(93);r.d(n,"e",function(){return u.a});var o=r(177);r.d(n,"f",function(){return o.a});var a=r(178);r.d(n,"g",function(){return a.a});var c=r(94);r.d(n,"h",function(){return c.a});var f=r(95);r.d(n,"i",function(){return f.a});var s=r(179);r.d(n,"j",function(){return s.a});var l=r(189);r.d(n,"k",function(){return l.a});var h=r(190);r.d(n,"l",function(){return h.a});var d=r(99);r.d(n,"m",function(){return d.a});var p=r(181);r.d(n,"n",function(){return p.a});var v=r(182);r.d(n,"o",function(){return v.a});var g=r(183);r.d(n,"p",function(){return g.a});var y=r(184);r.d(n,"q",function(){return y.a});var _=r(96);r.d(n,"r",function(){return _.a});var b=r(97);r.d(n,"s",function(){return b.a});var m=r(185);r.d(n,"t",function(){return m.a});var x=r(50);r.d(n,"u",function(){return x.a});var w=r(98);r.d(n,"v",function(){return w.a});var M=r(186);r.d(n,"w",function(){return M.a});var k=r(187);r.d(n,"x",function(){return k.a});var T=r(188);r.d(n,"y",function(){return T.a});var E=r(100);r.d(n,"z",function(){return E.a}),r.d(n,"A",function(){return E.b}),r.d(n,"B",function(){return E.c});var A=r(101);r.d(n,"C",function(){return A.a});var N=r(102);r.d(n,"D",function(){return N.a});var S=r(191);r.d(n,"E",function(){return S.a})},function(t,n,r){"use strict";var e=r(69);r.d(n,"a",function(){return e.a});var i=r(132);r.d(n,"b",function(){return i.a});var u=r(68);r.d(n,"c",function(){return u.a});var o=r(133);r.d(n,"d",function(){return o.a});var a=r(135);r.d(n,"e",function(){return a.a});var c=r(38);r.d(n,"f",function(){return c.a});var f=r(136);r.d(n,"g",function(){return f.a});var s=r(301);r.d(n,"h",function(){return s.a});var l=r(138);r.d(n,"i",function(){return l.a});var h=r(303);r.d(n,"j",function(){return h.a}),r.d(n,"k",function(){return h.b});var d=r(305);r.d(n,"l",function(){return d.a});var p=r(137);r.d(n,"m",function(){return p.a}),r.d(n,"n",function(){return p.b}),r.d(n,"o",function(){return p.c});var v=r(298);r.d(n,"p",function(){return v.a}),r.d(n,"q",function(){return v.b});var g=r(299);r.d(n,"r",function(){return g.a});var y=r(297);r.d(n,"s",function(){return y.a}),r.d(n,"t",function(){return y.b});var _=r(296);r.d(n,"u",function(){return _.a}),r.d(n,"v",function(){return _.b});var b=r(300);r.d(n,"w",function(){return b.a})},function(t,n,r){"use strict";function e(t,n){this._groups=t,this._parents=n}function i(){return new e([[document.documentElement]],L)}var u=r(386),o=r(387),a=r(375),c=r(369),f=r(147),s=r(374),l=r(379),h=r(382),d=r(389),p=r(367),v=r(381),g=r(380),y=r(388),_=r(373),b=r(372),m=r(366),x=r(149),w=r(383),M=r(368),k=r(390),T=r(376),E=r(384),A=r(378),N=r(365),S=r(377),C=r(385),q=r(370),z=r(77),P=r(371);r.d(n,"c",function(){return L}),n.b=e;var L=[null];e.prototype=i.prototype={constructor:e,select:u.a,selectAll:o.a,filter:a.a,data:c.a,enter:f.a,exit:s.a,merge:l.a,order:h.a,sort:d.a,call:p.a,nodes:v.a,node:g.a,size:y.a,empty:_.a,each:b.a,attr:m.a,style:x.b,property:w.a,classed:M.a,text:k.a,html:T.a,raise:E.a,lower:A.a,append:N.a,insert:S.a,remove:C.a,datum:q.a,on:z.c,dispatch:P.a},n.a=i},function(t,n,r){"use strict";function e(t,n){var r=u(t,n);if(r.state>l)throw new Error("too late; already scheduled");return r}function i(t,n){var r=u(t,n);if(r.state>d)throw new Error("too late; already started");return r}function u(t,n){var r=t.__transition;if(!r||!(r=r[n]))throw new Error("transition not found");return r}function o(t,n,e){function i(t){e.state=h,e.timer.restart(u,e.delay,e.time),e.delay<=t&&u(t-e.delay)}function u(i){var l,g,_,b;if(e.state!==h)return a();for(l in s)if(b=s[l],b.name===e.name){if(b.state===p)return r.i(c.d)(u);b.state===v?(b.state=y,b.timer.stop(),b.on.call("interrupt",t,t.__data__,b.index,b.group),delete s[l]):+l2?t[2]%360*l.g:0,d()):[P*l.h,L*l.h,D*l.h]},n.precision=function(t){return arguments.length?(F=r.i(v.a)(u,I=t*t),y()):r.i(l.n)(I)},n.fitExtent=function(t,e){return r.i(p.a)(n,t,e)},n.fitSize=function(t,e){return r.i(p.b)(n,t,e)},n.fitWidth=function(t,e){return r.i(p.c)(n,t,e)},n.fitHeight=function(t,e){return r.i(p.d)(n,t,e)},function(){return _=t.apply(this,arguments),n.invert=_.invert&&i,d()}}var o=r(115),a=r(117),c=r(34),f=r(120),s=r(60),l=r(0),h=r(35),d=r(36),p=r(63),v=r(271);n.a=i,n.b=u;var g=r.i(d.b)({point:function(t,n){this.stream.point(t*l.g,n*l.g)}})},function(t,n,r){"use strict";r.d(n,"e",function(){return e}),r.d(n,"d",function(){return i}),r.d(n,"c",function(){return u}),r.d(n,"b",function(){return o}),r.d(n,"a",function(){return a});var e=1e3,i=6e4,u=36e5,o=864e5,a=6048e5},function(t,n,r){"use strict";function e(){}n.a=e},function(t,n,r){"use strict";function e(t,n,r,e){this._groups=t,this._parents=n,this._name=r,this._id=e}function i(t){return r.i(o.j)().transition(t)}function u(){return++k}var o=r(1),a=r(439),c=r(440),f=r(441),s=r(442),l=r(443),h=r(444),d=r(445),p=r(446),v=r(447),g=r(448),y=r(449),_=r(450),b=r(451),m=r(452),x=r(453),w=r(454),M=r(48);n.b=e,n.a=i,n.c=u;var k=0,T=o.j.prototype;e.prototype=i.prototype={constructor:e,select:g.a,selectAll:y.a,filter:h.a,merge:d.a,selection:_.a,transition:w.a,call:T.call,nodes:T.nodes,node:T.node,size:T.size,empty:T.empty,each:T.each,on:p.a,attr:a.a,attrTween:c.a,style:b.a,styleTween:m.a,text:x.a,remove:v.a,tween:M.a,delay:f.a,duration:s.a,ease:l.a}},function(t,n,r){"use strict";var e=r(213);r.d(n,"a",function(){return e.a})},function(t,n,r){"use strict";function e(t,n){t&&a.hasOwnProperty(t.type)&&a[t.type](t,n)}function i(t,n,r){var e,i=-1,u=t.length-r;for(n.lineStart();++in?1:t>=n?0:NaN}},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(){this.reset()}function i(t,n,r){var e=t.s=n+r,i=e-n,u=e-i;t.t=n-u+(r-i)}n.a=function(){return new e},e.prototype={constructor:e,reset:function(){this.s=this.t=0},add:function(t){i(u,t,this.t),i(this,u.s,this.s),this.s?this.t+=u.t:this.s=u.t},valueOf:function(){return this.s}};var u=new e},function(t,n,r){"use strict";n.a=function(){return Math.random()}},function(t,n,r){"use strict";n.a=function(t){return null===t?NaN:+t}},function(t,n,r){"use strict";var e=r(208);r.d(n,"a",function(){return e.a});var i=r(209);r.d(n,"b",function(){return i.a});var u=r(51);r.d(n,"c",function(){return u.a});var o=r(207);r.d(n,"d",function(){return o.a});var a=r(210);r.d(n,"e",function(){return a.a});var c=r(206);r.d(n,"f",function(){return c.a})},function(t,n,r){"use strict";function e(t){return[r.i(s.e)(t[1],t[0]),r.i(s.f)(t[2])]}function i(t){var n=t[0],e=t[1],i=r.i(s.c)(e);return[i*r.i(s.c)(n),i*r.i(s.d)(n),r.i(s.d)(e)]}function u(t,n){return t[0]*n[0]+t[1]*n[1]+t[2]*n[2]}function o(t,n){return[t[1]*n[2]-t[2]*n[1],t[2]*n[0]-t[0]*n[2],t[0]*n[1]-t[1]*n[0]]}function a(t,n){t[0]+=n[0],t[1]+=n[1],t[2]+=n[2]}function c(t,n){return[t[0]*n,t[1]*n,t[2]*n]}function f(t){var n=r.i(s.n)(t[0]*t[0]+t[1]*t[1]+t[2]*t[2]);t[0]/=n,t[1]/=n,t[2]/=n}var s=r(0);n.g=e,n.a=i,n.d=u,n.b=o,n.f=a,n.e=c,n.c=f},function(t,n,r){"use strict";function e(t){return function(n,e){var i=r.i(u.c)(n),o=r.i(u.c)(e),a=t(i*o);return[a*o*r.i(u.d)(n),a*r.i(u.d)(e)]}}function i(t){return function(n,e){var i=r.i(u.n)(n*n+e*e),o=t(i),a=r.i(u.d)(o),c=r.i(u.c)(o);return[r.i(u.e)(n*a,i*c),r.i(u.f)(i&&e*a/i)]}}var u=r(0);n.b=e,n.a=i},function(t,n,r){"use strict";n.a=function(t,n,r,e,i){for(var u,o=t.children,a=-1,c=o.length,f=t.value&&(e-n)/t.value;++a180||i<-180?i-360*Math.round(i/360):i):r.i(c.a)(isNaN(t)?n:t)}function o(t){return 1==(t=+t)?a:function(n,e){return e-n?i(n,e,t):r.i(c.a)(isNaN(n)?e:n)}}function a(t,n){var i=n-t;return i?e(t,i):r.i(c.a)(isNaN(t)?n:t)}var c=r(134);n.b=u,n.c=o,n.a=a},function(t,n,r){"use strict";n.a=function(t){return t.match(/.{6}/g).map(function(t){return"#"+t})}},function(t,n,r){"use strict";function e(t){var n=t.domain;return t.ticks=function(t){var e=n();return r.i(u.z)(e[0],e[e.length-1],null==t?10:t)},t.tickFormat=function(t,e){return r.i(c.a)(n(),t,e)},t.nice=function(e){null==e&&(e=10);var i,o=n(),a=0,c=o.length-1,f=o[a],s=o[c];return s0?(f=Math.floor(f/i)*i,s=Math.ceil(s/i)*i,i=r.i(u.A)(f,s,e)):i<0&&(f=Math.ceil(f*i)/i,s=Math.floor(s*i)/i,i=r.i(u.A)(f,s,e)),i>0?(o[a]=Math.floor(f/i)*i,o[c]=Math.ceil(s/i)*i,n(o)):i<0&&(o[a]=Math.ceil(f*i)/i,o[c]=Math.floor(s*i)/i,n(o)),t},t}function i(){var t=r.i(a.a)(a.b,o.f);return t.copy=function(){return r.i(a.c)(t,i())},e(t)}var u=r(3),o=r(4),a=r(40),c=r(357);n.b=e,n.a=i},function(t,n,r){"use strict";function e(t){return t>1?0:t<-1?d:Math.acos(t)}function i(t){return t>=1?p:t<=-1?-p:Math.asin(t)}r.d(n,"g",function(){return u}),r.d(n,"m",function(){return o}),r.d(n,"h",function(){return a}),r.d(n,"e",function(){return c}),r.d(n,"j",function(){return f}),r.d(n,"i",function(){return s}),r.d(n,"d",function(){return l}),r.d(n,"a",function(){return h}),r.d(n,"b",function(){return d}),r.d(n,"f",function(){return p}),r.d(n,"c",function(){return v}),n.l=e,n.k=i;var u=Math.abs,o=Math.atan2,a=Math.cos,c=Math.max,f=Math.min,s=Math.sin,l=Math.sqrt,h=1e-12,d=Math.PI,p=d/2,v=2*d},function(t,n,r){"use strict";n.a=function(t,n){if((i=t.length)>1)for(var r,e,i,u=1,o=t[n[0]],a=o.length;u=0;)r[n]=n;return r}},function(t,n,r){"use strict";function e(t,n,r){return(t[0]-r[0])*(n[1]-t[1])-(t[0]-n[0])*(r[1]-t[1])}function i(t,n){return n[1]-t[1]||n[0]-t[0]}function u(t,n){var e,u,v,g=t.sort(i).pop();for(p=[],h=new Array(t.length),l=new s.a,d=new s.a;;)if(v=c.a,g&&(!v||g[1]=a)return null;var c=t-i.site[0],f=n-i.site[1],s=c*c+f*f;do{i=u.cells[e=o],o=null,i.halfedges.forEach(function(r){var e=u.edges[r],a=e.left;if(a!==i.site&&a||(a=e.right)){var c=t-a[0],f=n-a[1],l=c*c+f*f;l0)do{o.point(0===a||3===a?t:e,a>1?l:n)}while((a=(a+u+4)%4)!==c);else o.point(i[0],i[1])}function p(u,o){return r.i(i.p)(u[0]-t)0?0:3:r.i(i.p)(u[0]-e)0?2:1:r.i(i.p)(u[1]-n)0?1:0:o>0?3:2}function v(t,n){return g(t.x,n.x)}function g(t,n){var r=p(t,1),e=p(n,1);return r!==e?r-e:0===r?n[1]-t[1]:1===r?t[0]-n[0]:2===r?t[1]-n[1]:n[0]-t[0]}return function(i){function p(t,n){h(t,n)&&P.point(t,n)}function g(){for(var n=0,r=0,e=M.length;rl&&(s-i)*(l-u)>(h-u)*(t-i)&&++n:h<=l&&(s-i)*(l-u)<(h-u)*(t-i)&&--n;return n}function y(){P=L,w=[],M=[],z=!0}function _(){var t=g(),n=z&&t,e=(w=r.i(c.q)(w)).length;(n||e)&&(i.polygonStart(),n&&(i.lineStart(),d(null,null,1,i),i.lineEnd()),e&&r.i(a.a)(w,v,t,d,i),i.polygonEnd()),P=i,w=M=k=null}function b(){D.point=x,M&&M.push(k=[]),q=!0,C=!1,N=S=NaN}function m(){w&&(x(T,E),A&&C&&L.rejoin(),w.push(L.result())),D.point=p,C&&P.lineEnd()}function x(i,u){var a=h(i,u);if(M&&k.push([i,u]),q)T=i,E=u,A=a,q=!1,a&&(P.lineStart(),P.point(i,u));else if(a&&C)P.point(i,u);else{var c=[N=Math.max(s,Math.min(f,N)),S=Math.max(s,Math.min(f,S))],d=[i=Math.max(s,Math.min(f,i)),u=Math.max(s,Math.min(f,u))];r.i(o.a)(c,d,t,n,e,l)?(C||(P.lineStart(),P.point(c[0],c[1])),P.point(d[0],d[1]),a||P.lineEnd(),z=!1):a&&(P.lineStart(),P.point(i,u),z=!1)}N=i,S=u,C=a}var w,M,k,T,E,A,N,S,C,q,z,P=i,L=r.i(u.a)(),D={point:p,lineStart:b,lineEnd:m,polygonStart:y,polygonEnd:_};return D}}var i=r(0),u=r(116),o=r(250),a=r(119),c=r(3);n.a=e;var f=1e9,s=-f},function(t,n,r){"use strict";function e(t,n){return[t>f.a?t-f.b:t<-f.a?t+f.b:t,n]}function i(t,n,i){return(t%=f.b)?n||i?r.i(c.a)(o(t),a(n,i)):o(t):n||i?a(n,i):e}function u(t){return function(n,r){return n+=t,[n>f.a?n-f.b:n<-f.a?n+f.b:n,r]}}function o(t){var n=u(t);return n.invert=u(-t),n}function a(t,n){function e(t,n){var e=r.i(f.c)(n),c=r.i(f.c)(t)*e,s=r.i(f.d)(t)*e,l=r.i(f.d)(n),h=l*i+c*u;return[r.i(f.e)(s*o-h*a,c*i-l*u),r.i(f.f)(h*o+s*a)]}var i=r.i(f.c)(t),u=r.i(f.d)(t),o=r.i(f.c)(n),a=r.i(f.d)(n);return e.invert=function(t,n){var e=r.i(f.c)(n),c=r.i(f.c)(t)*e,s=r.i(f.d)(t)*e,l=r.i(f.d)(n),h=l*o-s*a;return[r.i(f.e)(s*o+l*a,c*i+h*u),r.i(f.f)(h*i-c*u)]},e}var c=r(120),f=r(0);n.b=i,e.invert=e,n.a=function(t){function n(n){return n=t(n[0]*f.g,n[1]*f.g),n[0]*=f.h,n[1]*=f.h,n}return t=i(t[0]*f.g,t[1]*f.g,t.length>2?t[2]*f.g:0),n.invert=function(n){return n=t.invert(n[0]*f.g,n[1]*f.g),n[0]*=f.h,n[1]*=f.h,n},n}},function(t,n,r){"use strict";function e(t){return function(n){var r=new i;for(var e in t)r[e]=t[e];return r.stream=n,r}}function i(){}n.b=e,n.a=function(t){return{stream:e(t)}},i.prototype={constructor:i,point:function(t,n){this.stream.point(t,n)},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()}}},function(t,n,r){"use strict";n.a=function(t,n,r,e,i){for(var u,o=t.children,a=-1,c=o.length,f=t.value&&(i-r)/t.value;++a=r?1:e(t)}}}function u(t){return function(n,r){var e=t(n=+n,r=+r);return function(t){return t<=0?n:t>=1?r:e(t)}}}function o(t,n,r,e){var i=t[0],u=t[1],o=n[0],a=n[1];return u2?a:o,s=d=null,c}function c(n){return(s||(s=f(g,y,b?i(t):t,_)))(+n)}var f,s,d,g=v,y=v,_=l.a,b=!1;return c.invert=function(t){return(d||(d=f(y,g,e,b?u(n):n)))(+t)},c.domain=function(t){return arguments.length?(g=h.a.call(t,p.a),r()):g.slice()},c.range=function(t){return arguments.length?(y=h.b.call(t),r()):y.slice()},c.rangeRound=function(t){return y=h.b.call(t),_=l.h,r()},c.clamp=function(t){return arguments.length?(b=!!t,r()):b},c.interpolate=function(t){return arguments.length?(_=t,r()):_},r()}var s=r(3),l=r(4),h=r(15),d=r(73),p=r(143);n.b=e,n.c=c,n.a=f;var v=[0,1]},function(t,n,r){"use strict";n.a=function(t,n){var r=t.ownerSVGElement||t;if(r.createSVGPoint){var e=r.createSVGPoint();return e.x=n.clientX,e.y=n.clientY,e=e.matrixTransform(t.getScreenCTM().inverse()),[e.x,e.y]}var i=t.getBoundingClientRect();return[n.clientX-i.left-t.clientLeft,n.clientY-i.top-t.clientTop]}},function(t,n,r){"use strict";function e(t,n,r){t._context.bezierCurveTo((2*t._x0+t._x1)/3,(2*t._y0+t._y1)/3,(t._x0+2*t._x1)/3,(t._y0+2*t._y1)/3,(t._x0+4*t._x1+n)/6,(t._y0+4*t._y1+r)/6)}function i(t){this._context=t}n.c=e,n.b=i,i.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){switch(this._point){case 3:e(this,this._x1,this._y1);case 2:this._context.lineTo(this._x1,this._y1)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3,this._context.lineTo((5*this._x0+this._x1)/6,(5*this._y0+this._y1)/6);default:e(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}},n.a=function(t){return new i(t)}},function(t,n,r){"use strict";function e(t,n,r){t._context.bezierCurveTo(t._x1+t._k*(t._x2-t._x0),t._y1+t._k*(t._y2-t._y0),t._x2+t._k*(t._x1-n),t._y2+t._k*(t._y1-r),t._x2,t._y2)}function i(t,n){this._context=t,this._k=(1-n)/6}n.c=e,n.b=i,i.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:e(this,this._x1,this._y1)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2,this._x1=t,this._y1=n;break;case 2:this._point=3;default:e(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return new i(t,n)}return r.tension=function(n){return t(+n)},r}(0)},function(t,n,r){"use strict";function e(t){this._context=t}e.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;default:this._context.lineTo(t,n)}}},n.a=function(t){return new e(t)}},function(t,n,r){"use strict";n.a=function(){}},function(t,n,r){"use strict";var e=r(2);r.d(n,"a",function(){return e.a});var i=r(421);r.d(n,"b",function(){return i.a}),r.d(n,"c",function(){return i.b}),r.d(n,"d",function(){return i.a}),r.d(n,"e",function(){return i.b});var u=r(424);r.d(n,"f",function(){return u.a}),r.d(n,"g",function(){return u.b}),r.d(n,"h",function(){return u.a}),r.d(n,"i",function(){return u.b});var o=r(422);r.d(n,"j",function(){return o.a}),r.d(n,"k",function(){return o.b});var a=r(420);r.d(n,"l",function(){return a.a}),r.d(n,"m",function(){return a.b});var c=r(419);r.d(n,"n",function(){return c.a}),r.d(n,"o",function(){return c.b});var f=r(431);r.d(n,"p",function(){return f.a}),r.d(n,"q",function(){return f.b}),r.d(n,"r",function(){return f.a}),r.d(n,"s",function(){return f.b}),r.d(n,"t",function(){return f.c}),r.d(n,"u",function(){return f.d}),r.d(n,"v",function(){return f.e}),r.d(n,"w",function(){return f.f}),r.d(n,"x",function(){return f.g}),r.d(n,"y",function(){return f.h}),r.d(n,"z",function(){return f.i}),r.d(n,"A",function(){return f.j}),r.d(n,"B",function(){return f.k}),r.d(n,"C",function(){return f.l}),r.d(n,"D",function(){return f.m}),r.d(n,"E",function(){return f.n});var s=r(423);r.d(n,"F",function(){return s.a}),r.d(n,"G",function(){return s.b});var l=r(432);r.d(n,"H",function(){return l.a}),r.d(n,"I",function(){return l.b});var h=r(427);r.d(n,"J",function(){return h.a}),r.d(n,"K",function(){return h.b});var d=r(426);r.d(n,"L",function(){return d.a}),r.d(n,"M",function(){return d.b});var p=r(425);r.d(n,"N",function(){return p.a}),r.d(n,"O",function(){return p.b});var v=r(429);r.d(n,"P",function(){return v.a}),r.d(n,"Q",function(){return v.b}),r.d(n,"R",function(){return v.a}),r.d(n,"S",function(){return v.b}),r.d(n,"T",function(){return v.c}),r.d(n,"U",function(){return v.d}),r.d(n,"V",function(){return v.e}),r.d(n,"W",function(){return v.f}),r.d(n,"X",function(){return v.g}),r.d(n,"Y",function(){return v.h}),r.d(n,"Z",function(){return v.i}),r.d(n,"_0",function(){return v.j}),r.d(n,"_1",function(){return v.k}),r.d(n,"_2",function(){return v.l}),r.d(n,"_3",function(){return v.m}),r.d(n,"_4",function(){return v.n});var g=r(428);r.d(n,"_5",function(){return g.a}),r.d(n,"_6",function(){return g.b});var y=r(430);r.d(n,"_7",function(){return y.a}),r.d(n,"_8",function(){return y.b})},function(t,n,r){"use strict";var e=r(87);r.d(n,"a",function(){return e.a}),r.d(n,"b",function(){return e.b}),r.d(n,"c",function(){return e.c});var i=r(434);r.d(n,"d",function(){return i.a});var u=r(433);r.d(n,"e",function(){return u.a})},function(t,n,r){"use strict";function e(t,n){var e,i;return function(){var u=r.i(o.e)(this,t),a=u.tween;if(a!==e){i=e=a;for(var c=0,f=i.length;c=1)return+r(t[i-1],i-1,t);var i,u=(i-1)*n,o=Math.floor(u),a=+r(t[o],o,t);return a+(+r(t[o+1],o+1,t)-a)*(u-o)}}},function(t,n,r){"use strict";function e(){}function i(t,n){var r=new e;if(t instanceof e)t.each(function(t,n){r.set(n,t)});else if(Array.isArray(t)){var i,u=-1,o=t.length;if(null==n)for(;++u>8&15|n>>4&240,n>>4&15|240&n,(15&n)<<4|15&n,1)):(n=w.exec(t))?u(parseInt(n[1],16)):(n=M.exec(t))?new f(n[1],n[2],n[3],1):(n=k.exec(t))?new f(255*n[1]/100,255*n[2]/100,255*n[3]/100,1):(n=T.exec(t))?o(n[1],n[2],n[3],n[4]):(n=E.exec(t))?o(255*n[1]/100,255*n[2]/100,255*n[3]/100,n[4]):(n=A.exec(t))?s(n[1],n[2]/100,n[3]/100,1):(n=N.exec(t))?s(n[1],n[2]/100,n[3]/100,n[4]):S.hasOwnProperty(t)?u(S[t]):"transparent"===t?new f(NaN,NaN,NaN,0):null}function u(t){return new f(t>>16&255,t>>8&255,255&t,1)}function o(t,n,r,e){return e<=0&&(t=n=r=NaN),new f(t,n,r,e)}function a(t){return t instanceof e||(t=i(t)),t?(t=t.rgb(),new f(t.r,t.g,t.b,t.opacity)):new f}function c(t,n,r,e){return 1===arguments.length?a(t):new f(t,n,r,null==e?1:e)}function f(t,n,r,e){this.r=+t,this.g=+n,this.b=+r,this.opacity=+e}function s(t,n,r,e){return e<=0?t=n=r=NaN:r<=0||r>=1?t=n=NaN:n<=0&&(t=NaN),new d(t,n,r,e)}function l(t){if(t instanceof d)return new d(t.h,t.s,t.l,t.opacity);if(t instanceof e||(t=i(t)),!t)return new d;if(t instanceof d)return t;t=t.rgb();var n=t.r/255,r=t.g/255,u=t.b/255,o=Math.min(n,r,u),a=Math.max(n,r,u),c=NaN,f=a-o,s=(a+o)/2;return f?(c=n===a?(r-u)/f+6*(r0&&s<1?0:c,new d(c,f,s,t.opacity)}function h(t,n,r,e){return 1===arguments.length?l(t):new d(t,n,r,null==e?1:e)}function d(t,n,r,e){this.h=+t,this.s=+n,this.l=+r,this.opacity=+e}function p(t,n,r){return 255*(t<60?n+(r-n)*t/60:t<180?r:t<240?n+(r-n)*(240-t)/60:n)}var v=r(53);n.f=e,r.d(n,"h",function(){return g}),r.d(n,"g",function(){return y}),n.a=i,n.e=a,n.b=c,n.d=f,n.c=h;var g=.7,y=1/g,_="\\s*([+-]?\\d+)\\s*",b="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)\\s*",m="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)%\\s*",x=/^#([0-9a-f]{3})$/,w=/^#([0-9a-f]{6})$/,M=new RegExp("^rgb\\("+[_,_,_]+"\\)$"),k=new RegExp("^rgb\\("+[m,m,m]+"\\)$"),T=new RegExp("^rgba\\("+[_,_,_,b]+"\\)$"),E=new RegExp("^rgba\\("+[m,m,m,b]+"\\)$"),A=new RegExp("^hsl\\("+[b,m,m]+"\\)$"),N=new RegExp("^hsla\\("+[b,m,m,b]+"\\)$"),S={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};r.i(v.a)(e,i,{displayable:function(){return this.rgb().displayable()},toString:function(){return this.rgb()+""}}),r.i(v.a)(f,c,r.i(v.b)(e,{brighter:function(t){return t=null==t?y:Math.pow(y,t),new f(this.r*t,this.g*t,this.b*t,this.opacity)},darker:function(t){return t=null==t?g:Math.pow(g,t),new f(this.r*t,this.g*t,this.b*t,this.opacity)},rgb:function(){return this},displayable:function(){return 0<=this.r&&this.r<=255&&0<=this.g&&this.g<=255&&0<=this.b&&this.b<=255&&0<=this.opacity&&this.opacity<=1},toString:function(){var t=this.opacity;return t=isNaN(t)?1:Math.max(0,Math.min(1,t)),(1===t?"rgb(":"rgba(")+Math.max(0,Math.min(255,Math.round(this.r)||0))+", "+Math.max(0,Math.min(255,Math.round(this.g)||0))+", "+Math.max(0,Math.min(255,Math.round(this.b)||0))+(1===t?")":", "+t+")")}})),r.i(v.a)(d,h,r.i(v.b)(e,{brighter:function(t){return t=null==t?y:Math.pow(y,t),new d(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?g:Math.pow(g,t),new d(this.h,this.s,this.l*t,this.opacity)},rgb:function(){var t=this.h%360+360*(this.h<0),n=isNaN(t)||isNaN(this.s)?0:this.s,r=this.l,e=r+(r<.5?r:1-r)*n,i=2*r-e;return new f(p(t>=240?t-240:t+120,i,e),p(t,i,e),p(t<120?t+240:t-120,i,e),this.opacity)},displayable:function(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1}}))},function(t,n,r){"use strict";function e(t,n){var r=Object.create(t.prototype);for(var e in n)r[e]=n[e];return r}n.b=e,n.a=function(t,n,r){t.prototype=n.prototype=r,r.constructor=t}},function(t,n,r){"use strict";var e=r(215);r.d(n,"a",function(){return e.a});var i=r(105);r.d(n,"b",function(){return i.a}),r.d(n,"c",function(){return i.b})},function(t,n,r){"use strict";var e=r(56);r.d(n,"a",function(){return e.a});var i=r(217);r.d(n,"b",function(){return i.a}),r.d(n,"c",function(){return i.b}),r.d(n,"d",function(){return i.c}),r.d(n,"e",function(){return i.d});var u=r(218);r.d(n,"f",function(){return u.a}),r.d(n,"g",function(){return u.b}),r.d(n,"h",function(){return u.c}),r.d(n,"i",function(){return u.d})},function(t,n,r){"use strict";function e(t){return new Function("d","return {"+t.map(function(t,n){return JSON.stringify(t)+": d["+n+"]"}).join(",")+"}")}function i(t,n){var r=e(t);return function(e,i){return n(r(e),i,t)}}function u(t){var n=Object.create(null),r=[];return t.forEach(function(t){for(var e in t)e in n||r.push(n[e]=e)}),r}var o={},a={},c=34,f=10,s=13;n.a=function(t){function n(t,n){var u,o,a=r(t,function(t,r){if(u)return u(t,r-1);o=t,u=n?i(t,n):e(t)});return a.columns=o||[],a}function r(t,n){function r(){if(d)return a;if(p)return p=!1,o;var n,r,e=l;if(t.charCodeAt(e)===c){for(;l++=u?d=!0:(r=t.charCodeAt(l++))===f?p=!0:r===s&&(p=!0,t.charCodeAt(l)===f&&++l),t.slice(e+1,n-1).replace(/""/g,'"')}for(;l1?e[0]+e.slice(2):e,+t.slice(r+1)]}},function(t,n,r){"use strict";n.a=function(t){return t}},function(t,n,r){"use strict";function e(t){var n=0,e=i.a/3,o=r.i(u.b)(t),a=o(n,e);return a.parallels=function(t){return arguments.length?o(n=t[0]*i.g,e=t[1]*i.g):[n*i.h,e*i.h]},a}var i=r(0),u=r(8);n.a=e},function(t,n,r){"use strict";function e(t,n){function e(t,n){var e=r.i(i.n)(c-2*a*r.i(i.d)(n))/a;return[e*r.i(i.d)(t*=a),f-e*r.i(i.c)(t)]}var u=r.i(i.d)(t),a=(u+r.i(i.d)(n))/2;if(r.i(i.p)(a)=0;--o)h.push(e=r.children[o]=new c(i[o])),e.parent=r,e.depth=r.depth+1;return s.eachBefore(a)}function i(){return e(this).eachBefore(o)}function u(t){return t.children}function o(t){t.data=t.data.data}function a(t){var n=0;do{t.height=n}while((t=t.parent)&&t.height<++n)}function c(t){this.data=t,this.depth=this.height=0,this.parent=null}var f=r(278),s=r(280),l=r(282),h=r(281),d=r(287),p=r(286),v=r(285),g=r(277),y=r(279),_=r(283),b=r(284);n.a=e,n.c=a,n.b=c,c.prototype=e.prototype={constructor:c,count:f.a,each:s.a,eachAfter:h.a,eachBefore:l.a,sum:d.a,sort:p.a,path:v.a,ancestors:g.a,descendants:y.a,leaves:_.a,links:b.a,copy:i}},function(t,n,r){"use strict";function e(t,n,e,o,a,c){for(var f,s,l,h,d,p,v,g,y,_,b,m=[],x=n.children,w=0,M=0,k=x.length,T=n.value;wv&&(v=s),b=d*d*_,(g=Math.max(v/b,b/p))>y){d-=s;break}y=g}m.push(f={value:d,dice:l1?n:1)},r}(o)},function(t,n,r){"use strict";function e(t,n,r,e,i){var u=t*t,o=u*t;return((1-3*t+3*u-o)*n+(4-6*u+3*o)*r+(1+3*t+3*u-3*o)*e+o*i)/6}n.b=e,n.a=function(t){var n=t.length-1;return function(r){var i=r<=0?r=0:r>=1?(r=1,n-1):Math.floor(r*n),u=t[i],o=t[i+1],a=i>0?t[i-1]:2*u-o,c=i=200&&r<300||304===r){if(s)try{n=s.call(c,p)}catch(t){return void h.call("error",c,t)}else n=p;h.call("load",c,n)}else h.call("error",c,t)}var c,f,s,l,h=r.i(o.a)("beforesend","progress","load","error"),d=r.i(u.c)(),p=new XMLHttpRequest,v=null,g=null,y=0;if("undefined"==typeof XDomainRequest||"withCredentials"in p||!/^(http(s)?:)?\/\//.test(t)||(p=new XDomainRequest),"onload"in p?p.onload=p.onerror=p.ontimeout=a:p.onreadystatechange=function(t){p.readyState>3&&a(t)},p.onprogress=function(t){h.call("progress",c,t)},c={header:function(t,n){return t=(t+"").toLowerCase(),arguments.length<2?d.get(t):(null==n?d.remove(t):d.set(t,n+""),c)},mimeType:function(t){return arguments.length?(f=null==t?null:t+"",c):f},responseType:function(t){return arguments.length?(l=t,c):l},timeout:function(t){return arguments.length?(y=+t,c):y},user:function(t){return arguments.length<1?v:(v=null==t?null:t+"",c)},password:function(t){return arguments.length<1?g:(g=null==t?null:t+"",c)},response:function(t){return s=t,c},get:function(t,n){return c.send("GET",t,n)},post:function(t,n){return c.send("POST",t,n)},send:function(n,r,i){return p.open(n,t,!0,v,g),null==f||d.has("accept")||d.set("accept",f+",*/*"),p.setRequestHeader&&d.each(function(t,n){p.setRequestHeader(n,t)}),null!=f&&p.overrideMimeType&&p.overrideMimeType(f),null!=l&&(p.responseType=l),y>0&&(p.timeout=y),null==i&&"function"==typeof r&&(i=r,r=null),null!=i&&1===i.length&&(i=e(i)),null!=i&&c.on("error",i).on("load",function(t){i(null,t)}),h.call("beforesend",c,p),p.send(null==r?null:r),c},abort:function(){return p.abort(),c},on:function(){var t=h.on.apply(h,arguments);return t===h?c:t}},null!=n){if("function"!=typeof n)throw new Error("invalid callback: "+n);return c.get(n)}return c}},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(t){return function(){var n=this.ownerDocument,r=this.namespaceURI;return r===o.b&&n.documentElement.namespaceURI===o.b?n.createElement(t):n.createElementNS(r,t)}}function i(t){return function(){return this.ownerDocument.createElementNS(t.space,t.local)}}var u=r(75),o=r(76);n.a=function(t){var n=r.i(u.a)(t);return(n.local?i:e)(n)}},function(t,n,r){"use strict";var e=r(76);n.a=function(t){var n=t+="",r=n.indexOf(":");return r>=0&&"xmlns"!==(n=t.slice(0,r))&&(t=t.slice(r+1)),e.a.hasOwnProperty(n)?{space:e.a[n],local:t}:t}},function(t,n,r){"use strict";r.d(n,"b",function(){return e});var e="http://www.w3.org/1999/xhtml";n.a={svg:"http://www.w3.org/2000/svg",xhtml:e,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"}},function(t,n,r){"use strict";function e(t,n,r){return t=i(t,n,r),function(n){var r=n.relatedTarget;r&&(r===this||8&r.compareDocumentPosition(this))||t.call(this,n)}}function i(t,n,r){return function(e){var i=s;s=e;try{t.call(this,this.__data__,n,r)}finally{s=i}}}function u(t){return t.trim().split(/^|\s+/).map(function(t){var n="",r=t.indexOf(".");return r>=0&&(n=t.slice(r+1),t=t.slice(0,r)),{type:t,name:n}})}function o(t){return function(){var n=this.__on;if(n){for(var r,e=0,i=-1,u=n.length;eu.a){var c=2*t._l01_2a+3*t._l01_a*t._l12_a+t._l12_2a,f=3*t._l01_a*(t._l01_a+t._l12_a);e=(e*c-t._x0*t._l12_2a+t._x2*t._l01_2a)/f,i=(i*c-t._y0*t._l12_2a+t._y2*t._l01_2a)/f}if(t._l23_a>u.a){var s=2*t._l23_2a+3*t._l23_a*t._l12_a+t._l12_2a,l=3*t._l23_a*(t._l23_a+t._l12_a);o=(o*s+t._x1*t._l23_2a-n*t._l12_2a)/l,a=(a*s+t._y1*t._l23_2a-r*t._l12_2a)/l}t._context.bezierCurveTo(e,i,o,a,t._x2,t._y2)}function i(t,n){this._context=t,this._alpha=n}var u=r(29),o=r(43);n.b=e,i.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:this.point(this._x2,this._y2)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){if(t=+t,n=+n,this._point){var r=this._x2-t,i=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(r*r+i*i,this._alpha))}switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3;default:e(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return n?new i(t,n):new o.b(t,0)}return r.alpha=function(n){return t(+n)},r}(.5)},function(t,n,r){"use strict";var e=r(14),i=r(16),u=r(44),o=r(84);n.a=function(){function t(t){var i,u,o,h=t.length,d=!1;for(null==f&&(l=s(o=r.i(e.a)())),i=0;i<=h;++i)!(i=0&&n._call.call(null,t),n=n._next;--p}function c(){b=(_=x.now())+m,p=v=0;try{a()}finally{p=0,s(),b=0}}function f(){var t=x.now(),n=t-_;n>y&&(m-=n,_=t)}function s(){for(var t,n,r=h,e=1/0;r;)r._call?(e>r._time&&(e=r._time),t=r,r=r._next):(n=r._next,r._next=null,r=t?t._next=n:h=n);d=t,l(e)}function l(t){if(!p){v&&(v=clearTimeout(v));t-b>24?(t<1/0&&(v=setTimeout(c,t-x.now()-m)),g&&(g=clearInterval(g))):(g||(_=x.now(),g=setInterval(f,y)),p=1,w(c))}}n.a=e,n.d=u,n.b=o,n.c=a;var h,d,p=0,v=0,g=0,y=1e3,_=0,b=0,m=0,x="object"==typeof performance&&performance.now?performance:Date,w="object"==typeof window&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(t){setTimeout(t,17)};u.prototype=o.prototype={constructor:u,restart:function(t,n,r){if("function"!=typeof t)throw new TypeError("callback is not a function");r=(null==r?e():+r)+(null==n?0:+n),this._next||d===this||(d?d._next=this:h=this,d=this),this._call=t,this._time=r,l()},stop:function(){this._call&&(this._call=null,this._time=1/0,l())}}},function(t,n,r){"use strict";var e=(r(436),r(11));r.d(n,"a",function(){return e.a});var i=r(435);r.d(n,"b",function(){return i.a});var u=r(167);r.d(n,"c",function(){return u.a})},function(t,n,r){"use strict";function e(t,n,r,e){var i=[null,null],o=f.d.push(i)-1;return i.left=t,i.right=n,r&&u(i,t,n,r),e&&u(i,n,t,e),f.c[t.index].halfedges.push(o),f.c[n.index].halfedges.push(o),i}function i(t,n,r){var e=[n,r];return e.left=t,e}function u(t,n,r,e){t[0]||t[1]?t.left===r?t[1]=e:t[0]=e:(t[0]=e,t.left=n,t.right=r)}function o(t,n,r,e,i){var u,o=t[0],a=t[1],c=o[0],f=o[1],s=a[0],l=a[1],h=0,d=1,p=s-c,v=l-f;if(u=n-c,p||!(u>0)){if(u/=p,p<0){if(u0){if(u>d)return;u>h&&(h=u)}if(u=e-c,p||!(u<0)){if(u/=p,p<0){if(u>d)return;u>h&&(h=u)}else if(p>0){if(u0)){if(u/=v,v<0){if(u0){if(u>d)return;u>h&&(h=u)}if(u=i-f,v||!(u<0)){if(u/=v,v<0){if(u>d)return;u>h&&(h=u)}else if(v>0){if(u0||d<1)||(h>0&&(t[0]=[c+h*p,f+h*v]),d<1&&(t[1]=[c+d*p,f+d*v]),!0)}}}}}function a(t,n,r,e,i){var u=t[1];if(u)return!0;var o,a,c=t[0],f=t.left,s=t.right,l=f[0],h=f[1],d=s[0],p=s[1],v=(l+d)/2,g=(h+p)/2;if(p===h){if(v=e)return;if(l>d){if(c){if(c[1]>=i)return}else c=[v,r];u=[v,i]}else{if(c){if(c[1]1)if(l>d){if(c){if(c[1]>=i)return}else c=[(r-a)/o,r];u=[(i-a)/o,i]}else{if(c){if(c[1]=e)return}else c=[n,o*n+a];u=[e,o*e+a]}else{if(c){if(c[0]f.b||Math.abs(i[0][1]-i[1][1])>f.b)||delete f.d[u]}var f=r(32);n.d=e,n.b=i,n.c=u,n.a=c},function(t,n,r){"use strict";function e(){this._=null}function i(t){t.U=t.C=t.L=t.R=t.P=t.N=null}function u(t,n){var r=n,e=n.R,i=r.U;i?i.L===r?i.L=e:i.R=e:t._=e,e.U=i,r.U=e,r.R=e.L,r.R&&(r.R.U=r),e.L=r}function o(t,n){var r=n,e=n.L,i=r.U;i?i.L===r?i.L=e:i.R=e:t._=e,e.U=i,r.U=e,r.L=e.R,r.L&&(r.L.U=r),e.R=r}function a(t){for(;t.L;)t=t.L;return t}n.b=i,e.prototype={constructor:e,insert:function(t,n){var r,e,i;if(t){if(n.P=t,n.N=t.N,t.N&&(t.N.P=n),t.N=n,t.R){for(t=t.R;t.L;)t=t.L;t.L=n}else t.R=n;r=t}else this._?(t=a(this._),n.P=null,n.N=t,t.P=t.L=n,r=t):(n.P=n.N=null,this._=n,r=null);for(n.L=n.R=null,n.U=r,n.C=!0,t=n;r&&r.C;)e=r.U,r===e.L?(i=e.R,i&&i.C?(r.C=i.C=!1,e.C=!0,t=e):(t===r.R&&(u(this,r),t=r,r=t.U),r.C=!1,e.C=!0,o(this,e))):(i=e.L,i&&i.C?(r.C=i.C=!1,e.C=!0,t=e):(t===r.L&&(o(this,r),t=r,r=t.U),r.C=!1,e.C=!0,u(this,e))),r=t.U;this._.C=!1},remove:function(t){t.N&&(t.N.P=t.P),t.P&&(t.P.N=t.N),t.N=t.P=null;var n,r,e,i=t.U,c=t.L,f=t.R;if(r=c?f?a(f):c:f,i?i.L===t?i.L=r:i.R=r:this._=r,c&&f?(e=r.C,r.C=t.C,r.L=c,c.U=r,r!==f?(i=r.U,r.U=t.U,t=r.R,i.L=t,r.R=f,f.U=r):(r.U=i,i=r,t=r.R)):(e=t.C,t=r),t&&(t.U=i),!e){if(t&&t.C)return void(t.C=!1);do{if(t===this._)break;if(t===i.L){if(n=i.R,n.C&&(n.C=!1,i.C=!0,u(this,i),n=i.R),n.L&&n.L.C||n.R&&n.R.C){n.R&&n.R.C||(n.L.C=!1,n.C=!0,o(this,n),n=i.R),n.C=i.C,i.C=n.R.C=!1,u(this,i),t=this._;break}}else if(n=i.L,n.C&&(n.C=!1,i.C=!0,o(this,i),n=i.L),n.L&&n.L.C||n.R&&n.R.C){n.L&&n.L.C||(n.R.C=!1,n.C=!0,u(this,n),n=i.L),n.C=i.C,i.C=n.L.C=!1,o(this,i),t=this._;break}n.C=!0,t=i,i=i.U}while(!t.C);t&&(t.C=!1)}}},n.a=e},function(t,n,r){"use strict";r.d(n,"b",function(){return i}),r.d(n,"a",function(){return u});var e=Array.prototype,i=e.slice,u=e.map},function(t,n,r){"use strict";var e=r(17),i=r(93);r.d(n,"b",function(){return o}),r.d(n,"c",function(){return a});var u=r.i(i.a)(e.a),o=u.right,a=u.left;n.a=o},function(t,n,r){"use strict";function e(t){return function(n,e){return r.i(i.a)(t(n),e)}}var i=r(17);n.a=function(t){return 1===t.length&&(t=e(t)),{left:function(n,r,e,i){for(null==e&&(e=0),null==i&&(i=n.length);e>>1;t(n[u],r)<0?e=u+1:i=u}return e},right:function(n,r,e,i){for(null==e&&(e=0),null==i&&(i=n.length);e>>1;t(n[u],r)>0?i=u:e=u+1}return e}}}},function(t,n,r){"use strict";var e=r(102);n.a=function(t,n){var i=r.i(e.a)(t,n);return i?Math.sqrt(i):i}},function(t,n,r){"use strict";n.a=function(t,n){var r,e,i,u=t.length,o=-1;if(null==n){for(;++o=r)for(e=i=r;++or&&(e=r),i=r)for(e=i=r;++or&&(e=r),i=r)for(e=r;++ur&&(e=r)}else for(;++u=r)for(e=r;++ur&&(e=r);return e}},function(t,n,r){"use strict";function e(t,n){return[t,n]}n.b=e,n.a=function(t,n){null==n&&(n=e);for(var r=0,i=t.length-1,u=t[0],o=new Array(i<0?0:i);r=0?(c>=u?10:c>=o?5:c>=a?2:1)*Math.pow(10,i):-Math.pow(10,-i)/(c>=u?10:c>=o?5:c>=a?2:1)}function i(t,n,r){var e=Math.abs(n-t)/Math.max(0,r),i=Math.pow(10,Math.floor(Math.log(e)/Math.LN10)),c=e/i;return c>=u?i*=10:c>=o?i*=5:c>=a&&(i*=2),n0)return[t];if((i=n0)for(t=Math.ceil(t/a),n=Math.floor(n/a),o=new Array(u=Math.ceil(n-t+1));++c1)return s/(a-1)}},function(t,n,r){"use strict";r.d(n,"b",function(){return e}),r.d(n,"c",function(){return i}),r.d(n,"a",function(){return o}),r.d(n,"e",function(){return a}),r.d(n,"d",function(){return c});var e=Math.cos,i=Math.sin,u=Math.PI,o=u/2,a=2*u,c=Math.max},function(t,n,r){"use strict";r.d(n,"b",function(){return e}),r.d(n,"a",function(){return i});var e=Math.PI/180,i=180/Math.PI},function(t,n,r){"use strict";function e(t,n){var e=t.document.documentElement,o=r.i(i.h)(t).on("dragstart.drag",null);n&&(o.on("click.drag",u.a,!0),setTimeout(function(){o.on("click.drag",null)},0)),"onselectstart"in e?o.on("selectstart.drag",null):(e.style.MozUserSelect=e.__noselect,delete e.__noselect)}var i=r(1),u=r(106);n.b=e,n.a=function(t){var n=t.document.documentElement,e=r.i(i.h)(t).on("dragstart.drag",u.a,!0);"onselectstart"in n?e.on("selectstart.drag",u.a,!0):(n.__noselect=n.style.MozUserSelect,n.style.MozUserSelect="none")}},function(t,n,r){"use strict";function e(){i.q.stopImmediatePropagation()}var i=r(1);n.b=e,n.a=function(){i.q.preventDefault(),i.q.stopImmediatePropagation()}},function(t,n,r){"use strict";var e=r(225);r.d(n,"a",function(){return e.a});var i=r(227);r.d(n,"b",function(){return i.a}),r.d(n,"c",function(){return i.b}),r.d(n,"d",function(){return i.c}),r.d(n,"e",function(){return i.a});var u=r(222);r.d(n,"f",function(){return u.a}),r.d(n,"g",function(){return u.b}),r.d(n,"h",function(){return u.c}),r.d(n,"i",function(){return u.a});var o=r(226);r.d(n,"j",function(){return o.a}),r.d(n,"k",function(){return o.b}),r.d(n,"l",function(){return o.c}),r.d(n,"m",function(){return o.a});var a=r(228);r.d(n,"n",function(){return a.a}),r.d(n,"o",function(){return a.b}),r.d(n,"p",function(){return a.c}),r.d(n,"q",function(){return a.a});var c=r(224);r.d(n,"r",function(){return c.a}),r.d(n,"s",function(){return c.b}),r.d(n,"t",function(){return c.c}),r.d(n,"u",function(){return c.a});var f=r(221);r.d(n,"v",function(){return f.a}),r.d(n,"w",function(){return f.b}),r.d(n,"x",function(){return f.c}),r.d(n,"y",function(){return f.a});var s=r(220);r.d(n,"z",function(){return s.a}),r.d(n,"A",function(){return s.b}),r.d(n,"B",function(){return s.a}),r.d(n,"C",function(){return s.c});var l=r(219);r.d(n,"D",function(){return l.a}),r.d(n,"E",function(){return l.b}),r.d(n,"F",function(){return l.c}),r.d(n,"G",function(){return l.a});var h=r(223);r.d(n,"H",function(){return h.a}),r.d(n,"I",function(){return h.b}),r.d(n,"J",function(){return h.a}),r.d(n,"K",function(){return h.c})},function(t,n,r){"use strict";function e(t){return t.x}function i(t){return t.y}var u=r(12),o=r(22),a=r(47);n.b=e,n.c=i;var c=Math.PI*(3-Math.sqrt(5));n.a=function(t){function n(){e(),_.call("tick",s),l1?(null==n?g.remove(t):g.set(t,f(n)),s):g.get(t)},find:function(n,r,e){var i,u,o,a,c,f=0,s=t.length;for(null==e?e=1/0:e*=e,f=0;f1?(_.on(t,n),s):_.on(t)}}}},function(t,n,r){"use strict";var e=r(59);r.d(n,"b",function(){return i});var i;n.a=function(t,n){var u=r.i(e.a)(t,n);if(!u)return t+"";var o=u[0],a=u[1],c=a-(i=3*Math.max(-8,Math.min(8,Math.floor(a/3))))+1,f=o.length;return c===f?o:c>f?o+new Array(c-f+1).join("0"):c>0?o.slice(0,c)+"."+o.slice(c):"0."+new Array(1-c).join("0")+r.i(e.a)(t,Math.max(0,n+c-1))[0]}},function(t,n,r){"use strict";function e(t){return new i(t)}function i(t){if(!(n=o.exec(t)))throw new Error("invalid format: "+t);var n,r=n[1]||" ",e=n[2]||">",i=n[3]||"-",a=n[4]||"",c=!!n[5],f=n[6]&&+n[6],s=!!n[7],l=n[8]&&+n[8].slice(1),h=n[9]||"";"n"===h?(s=!0,h="g"):u.a[h]||(h=""),(c||"0"===r&&"="===e)&&(c=!0,r="0",e="="),this.fill=r,this.align=e,this.sign=i,this.symbol=a,this.zero=c,this.width=f,this.comma=s,this.precision=l,this.type=h}var u=r(111);n.a=e;var o=/^(?:(.)?([<>=^]))?([+\-\( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?([a-z%])?$/i;e.prototype=i.prototype,i.prototype.toString=function(){return this.fill+this.align+this.sign+this.symbol+(this.zero?"0":"")+(null==this.width?"":Math.max(1,0|this.width))+(this.comma?",":"")+(null==this.precision?"":"."+Math.max(0,0|this.precision))+this.type}},function(t,n,r){"use strict";var e=r(238),i=r(109),u=r(241);n.a={"":e.a,"%":function(t,n){return(100*t).toFixed(n)},b:function(t){return Math.round(t).toString(2)},c:function(t){return t+""},d:function(t){return Math.round(t).toString(10)},e:function(t,n){return t.toExponential(n)},f:function(t,n){return t.toFixed(n)},g:function(t,n){return t.toPrecision(n)},o:function(t){return Math.round(t).toString(8)},p:function(t,n){return r.i(u.a)(100*t,n)},r:u.a,s:i.a,X:function(t){return Math.round(t).toString(16).toUpperCase()},x:function(t){return Math.round(t).toString(16)}}},function(t,n,r){"use strict";var e=r(33),i=r(239),u=r(240),o=r(110),a=r(111),c=r(109),f=r(242),s=["y","z","a","f","p","n","µ","m","","k","M","G","T","P","E","Z","Y"];n.a=function(t){function n(t){function n(t){var n,r,o,a=x,f=w;if("c"===m)f=M(t)+f,t="";else{t=+t;var d=t<0;if(t=M(Math.abs(t),b),d&&0==+t&&(d=!1),a=(d?"("===u?u:"-":"-"===u||"("===u?"":u)+a,f=f+("s"===m?s[8+c.b/3]:"")+(d&&"("===u?")":""),k)for(n=-1,r=t.length;++n(o=t.charCodeAt(n))||o>57){f=(46===o?p+t.slice(n+1):t.slice(n))+f,t=t.slice(0,n);break}}_&&!l&&(t=h(t,1/0));var g=a.length+t.length+f.length,T=g>1)+a+t+f+T.slice(g);break;default:t=T+a+t+f}return v(t)}t=r.i(o.a)(t);var e=t.fill,i=t.align,u=t.sign,f=t.symbol,l=t.zero,y=t.width,_=t.comma,b=t.precision,m=t.type,x="$"===f?d[0]:"#"===f&&/[boxX]/.test(m)?"0"+m.toLowerCase():"",w="$"===f?d[1]:/[%p]/.test(m)?g:"",M=a.a[m],k=!m||/[defgprs%]/.test(m);return b=null==b?m?6:12:/[gprs]/.test(m)?Math.max(1,Math.min(21,b)):Math.max(0,Math.min(20,b)),n.toString=function(){return t+""},n}function l(t,i){var u=n((t=r.i(o.a)(t),t.type="f",t)),a=3*Math.max(-8,Math.min(8,Math.floor(r.i(e.a)(i)/3))),c=Math.pow(10,-a),f=s[8+a/3];return function(t){return u(c*t)+f}}var h=t.grouping&&t.thousands?r.i(i.a)(t.grouping,t.thousands):f.a,d=t.currency,p=t.decimal,v=t.numerals?r.i(u.a)(t.numerals):f.a,g=t.percent||"%";return{format:n,formatPrefix:l}}},function(t,n,r){"use strict";function e(){_.point=u}function i(){o(l,h)}function u(t,n){_.point=o,l=t,h=n,t*=c.g,n*=c.g,d=t,p=r.i(c.c)(n=n/2+c.v),v=r.i(c.d)(n)}function o(t,n){t*=c.g,n*=c.g,n=n/2+c.v;var e=t-d,i=e>=0?1:-1,u=i*e,o=r.i(c.c)(n),a=r.i(c.d)(n),f=v*a,s=p*o+f*r.i(c.c)(u),l=f*i*r.i(c.d)(u);g.add(r.i(c.e)(l,s)),d=t,p=o,v=a}var a=r(19),c=r(0),f=r(10),s=r(13);r.d(n,"c",function(){return g}),r.d(n,"b",function(){return _});var l,h,d,p,v,g=r.i(a.a)(),y=r.i(a.a)(),_={point:f.a,lineStart:f.a,lineEnd:f.a,polygonStart:function(){g.reset(),_.lineStart=e,_.lineEnd=i},polygonEnd:function(){var t=+g;y.add(t<0?c.b+t:t),this.lineStart=this.lineEnd=this.point=f.a},sphere:function(){y.add(c.b)}};n.a=function(t){return y.reset(),r.i(s.a)(t,_),2*y}},function(t,n,r){"use strict";function e(t,n,e,o,c,f){if(e){var s=r.i(a.c)(n),l=r.i(a.d)(n),h=o*e;null==c?(c=n+o*a.b,f=n-h/2):(c=i(s,c),f=i(s,f),(o>0?cf)&&(c+=o*a.b));for(var d,p=c;o>0?p>f:p0?a.a:-a.a,l=r.i(a.p)(c-e);r.i(a.p)(l-a.a)0?a.k:-a.k),t.point(o,u),t.lineEnd(),t.lineStart(),t.point(s,u),t.point(c,u),n=0):o!==s&&l>=a.a&&(r.i(a.p)(e-o)a.o?r.i(a.l)((r.i(a.d)(n)*(o=r.i(a.c)(i))*r.i(a.d)(e)-r.i(a.d)(i)*(u=r.i(a.c)(n))*r.i(a.d)(t))/(u*o*c)):(n+i)/2}function u(t,n,e,i){var u;if(null==t)u=e*a.k,i.point(-a.a,u),i.point(0,u),i.point(a.a,u),i.point(a.a,0),i.point(a.a,-u),i.point(0,-u),i.point(-a.a,-u),i.point(-a.a,0),i.point(-a.a,u);else if(r.i(a.p)(t[0]-n[0])>a.o){var o=t[0]1&&n.push(n.pop().concat(n.shift()))},result:function(){var r=n;return n=[],t=null,r}}}},function(t,n,r){"use strict";var e=r(23),i=r(114),u=r(0),o=r(124),a=r(118);n.a=function(t){function n(n,e,u,o){r.i(i.b)(o,t,d,u,n,e)}function c(t,n){return r.i(u.c)(t)*r.i(u.c)(n)>h}function f(t){var n,e,i,a,f;return{lineStart:function(){a=i=!1,f=1},point:function(h,d){var g,y=[h,d],_=c(h,d),b=p?_?0:l(h,d):_?l(h+(h<0?u.a:-u.a),d):0;if(!n&&(a=i=_)&&t.lineStart(),_!==i&&(!(g=s(n,y))||r.i(o.a)(n,g)||r.i(o.a)(y,g))&&(y[0]+=u.o,y[1]+=u.o,_=c(y[0],y[1])),_!==i)f=0,_?(t.lineStart(),g=s(y,n),t.point(g[0],g[1])):(g=s(n,y),t.point(g[0],g[1]),t.lineEnd()),n=g;else if(v&&n&&p^_){var m;b&e||!(m=s(y,n,!0))||(f=0,p?(t.lineStart(),t.point(m[0][0],m[0][1]),t.point(m[1][0],m[1][1]),t.lineEnd()):(t.point(m[1][0],m[1][1]),t.lineEnd(),t.lineStart(),t.point(m[0][0],m[0][1])))}!_||n&&r.i(o.a)(n,y)||t.point(y[0],y[1]),n=y,i=_,e=b},lineEnd:function(){i&&t.lineEnd(),n=null},clean:function(){return f|(a&&i)<<1}}}function s(t,n,i){var o=r.i(e.a)(t),a=r.i(e.a)(n),c=[1,0,0],f=r.i(e.b)(o,a),s=r.i(e.d)(f,f),l=f[0],d=s-l*l;if(!d)return!i&&t;var p=h*s/d,v=-h*l/d,g=r.i(e.b)(c,f),y=r.i(e.e)(c,p),_=r.i(e.e)(f,v);r.i(e.f)(y,_);var b=g,m=r.i(e.d)(y,b),x=r.i(e.d)(b,b),w=m*m-x*(r.i(e.d)(y,y)-1);if(!(w<0)){var M=r.i(u.n)(w),k=r.i(e.e)(b,(-m-M)/x);if(r.i(e.f)(k,y),k=r.i(e.g)(k),!i)return k;var T,E=t[0],A=n[0],N=t[1],S=n[1];A0^k[1]<(r.i(u.p)(k[0]-E)u.a^(E<=k[0]&&k[0]<=A)){var P=r.i(e.e)(b,(-m+M)/x);return r.i(e.f)(P,y),[k,r.i(e.g)(P)]}}}function l(n,r){var e=p?t:u.a-t,i=0;return n<-e?i|=1:n>e&&(i|=2),r<-e?i|=4:r>e&&(i|=8),i}var h=r.i(u.c)(t),d=6*u.g,p=h>0,v=r.i(u.p)(h)>u.o;return r.i(a.a)(c,f,n,p?[0,-t]:[-u.a,t-u.a])}},function(t,n,r){"use strict";function e(t){return t.length>1}function i(t,n){return((t=t.x)[0]<0?t[1]-a.k-a.o:a.k-t[1])-((n=n.x)[0]<0?n[1]-a.k-a.o:a.k-n[1])}var u=r(116),o=r(119),a=r(0),c=r(125),f=r(3);n.a=function(t,n,a,s){return function(l){function h(n,r){t(n,r)&&l.point(n,r)}function d(t,n){w.point(t,n)}function p(){E.point=d,w.lineStart()}function v(){E.point=h,w.lineEnd()}function g(t,n){x.push([t,n]),k.point(t,n)}function y(){k.lineStart(),x=[]}function _(){g(x[0][0],x[0][1]),k.lineEnd();var t,n,r,i,u=k.clean(),o=M.result(),a=o.length;if(x.pop(),b.push(x),x=null,a)if(1&u){if(r=o[0],(n=r.length-1)>0){for(T||(l.polygonStart(),T=!0),l.lineStart(),t=0;t1&&2&u&&o.push(o.pop().concat(o.shift())),m.push(o.filter(e))}var b,m,x,w=n(l),M=r.i(u.a)(),k=n(M),T=!1,E={point:h,lineStart:p,lineEnd:v,polygonStart:function(){E.point=g,E.lineStart=y,E.lineEnd=_,m=[],b=[]},polygonEnd:function(){E.point=h,E.lineStart=p,E.lineEnd=v,m=r.i(f.q)(m);var t=r.i(c.a)(b,s);m.length?(T||(l.polygonStart(),T=!0),r.i(o.a)(m,i,t,a,l)):t&&(T||(l.polygonStart(),T=!0),l.lineStart(),a(null,null,1,l),l.lineEnd()),T&&(l.polygonEnd(),T=!1),m=b=null},sphere:function(){l.polygonStart(),l.lineStart(),a(null,null,1,l),l.lineEnd(),l.polygonEnd()}};return E}}},function(t,n,r){"use strict";function e(t,n,r,e){this.x=t,this.z=n,this.o=r,this.e=e,this.v=!1,this.n=this.p=null}function i(t){if(n=t.length){for(var n,r,e=0,i=t[0];++e=0;--f)c.point((p=d[f])[0],p[1]);else a(g.x,g.p.x,-1,c);g=g.p}g=g.o,d=g.z,y=!y}while(!g.v);c.lineEnd()}}}},function(t,n,r){"use strict";n.a=function(t,n){function r(r,e){return r=t(r,e),n(r[0],r[1])}return t.invert&&n.invert&&(r.invert=function(r,e){return(r=n.invert(r,e))&&t.invert(r[0],r[1])}),r}},function(t,n,r){"use strict";var e=r(122),i=[null,null],u={type:"LineString",coordinates:i};n.a=function(t,n){return i[0]=t,i[1]=n,r.i(e.a)(u)}},function(t,n,r){"use strict";function e(){v.point=u,v.lineEnd=i}function i(){v.point=v.lineEnd=h.a}function u(t,n){t*=l.g,n*=l.g,a=t,c=r.i(l.d)(n),f=r.i(l.c)(n),v.point=o}function o(t,n){t*=l.g,n*=l.g;var e=r.i(l.d)(n),i=r.i(l.c)(n),u=r.i(l.p)(t-a),o=r.i(l.c)(u),s=r.i(l.d)(u),h=i*s,d=f*e-c*i*o,v=c*e+f*i*o;p.add(r.i(l.e)(r.i(l.n)(h*h+d*d),v)),a=t,c=e,f=i}var a,c,f,s=r(19),l=r(0),h=r(10),d=r(13),p=r.i(s.a)(),v={sphere:h.a,point:h.a,lineStart:e,lineEnd:h.a,polygonStart:h.a,polygonEnd:h.a};n.a=function(t){return p.reset(),r.i(d.a)(t,v),+p}},function(t,n,r){"use strict";function e(t,n){ta&&(a=t),nc&&(c=n)}var i=r(10),u=1/0,o=u,a=-u,c=a,f={point:e,lineStart:i.a,lineEnd:i.a,polygonStart:i.a,polygonEnd:i.a,result:function(){var t=[[u,o],[a,c]];return a=c=-(o=u=1/0),t}};n.a=f},function(t,n,r){"use strict";var e=r(0);n.a=function(t,n){return r.i(e.p)(t[0]-n[0])=0?1:-1,N=A*E,S=N>u.a,C=_*k;if(o.add(r.i(u.e)(C*A*r.i(u.d)(N),b*T+C*r.i(u.c)(N))),f+=S?E+A*u.b:E,S^g>=e^w>=e){var q=r.i(i.b)(r.i(i.a)(v),r.i(i.a)(x));r.i(i.c)(q);var z=r.i(i.b)(c,q);r.i(i.c)(z);var P=(S^E>=0?-1:1)*r.i(u.f)(z[2]);(a>P||a===P&&(q[0]||q[1]))&&(s+=S^E>=0?1:-1)}}return(f<-u.o||f0&&r*r>e*e+i*i}function o(t,n){for(var r=0;rr*r+e*e}function u(t){var n=t._,r=t.next._,e=n.r+r.r,i=(n.x*r.r+r.x*n.r)/e,u=(n.y*r.r+r.y*n.r)/e;return i*i+u*u}function o(t){this._=t,this.next=null,this.previous=null}function a(t){if(!(s=t.length))return 0;var n,a,f,s,l,h,d,p,v,g,y;if(n=t[0],n.x=0,n.y=0,!(s>1))return n.r;if(a=t[1],n.x=-a.r,a.x=n.r,a.y=0,!(s>2))return n.r+a.r;e(a,n,f=t[2]),n=new o(n),a=new o(a),f=new o(f),n.next=f.previous=a,a.next=n.previous=f,f.next=a.previous=n;t:for(d=3;dl&&(s=n.slice(l,s),d[h]?d[h]+=s:d[++h]=s),(c=c[0])===(f=f[0])?d[h]?d[h]+=f:d[++h]=f:(d[++h]=null,p.push({i:h,x:r.i(u.a)(c,f)})),l=a.lastIndex;return l1);return t+r*u*Math.sqrt(-2*Math.log(i)/i)}}return r.source=t,r}(e.a)},function(t,n,r){"use strict";function e(t,n){return function(r){return t(r.responseText,n)}}var i=r(72);n.a=function(t,n){return function(u,o,a){arguments.length<3&&(a=o,o=null);var c=r.i(i.a)(u).mimeType(t);return c.row=function(t){return arguments.length?c.response(e(n,o=t)):o},c.row(o),a?c.get(a):c}}},function(t,n,r){"use strict";n.a=function(t,n){t=t.slice();var r,e=0,i=t.length-1,u=t[e],o=t[i];return o1?this.each((null==n?e:"function"==typeof n?u:i)(t,n,null==r?"":r)):o(this.node(),t)}},function(t,n,r){"use strict";function e(){return[]}n.a=function(t){return null==t?e:function(){return this.querySelectorAll(t)}}},function(t,n,r){"use strict";var e=r(14),i=r(16),u=r(44),o=r(82),a=r(84);n.a=function(){function t(t){var n,i,u,o,a,g=t.length,y=!1,_=new Array(g),b=new Array(g);for(null==d&&(v=p(a=r.i(e.a)())),n=0;n<=g;++n){if(!(n=i;--u)v.point(_[u],b[u]);v.lineEnd(),v.areaEnd()}y&&(_[n]=+c(o,n,t),b[n]=+s(o,n,t),v.point(f?+f(o,n,t):_[n],l?+l(o,n,t):b[n]))}if(a)return v=null,a+""||null}function n(){return r.i(o.a)().defined(h).curve(p).context(d)}var c=a.a,f=null,s=r.i(i.a)(0),l=a.b,h=r.i(i.a)(!0),d=null,p=u.a,v=null;return t.x=function(n){return arguments.length?(c="function"==typeof n?n:r.i(i.a)(+n),f=null,t):c},t.x0=function(n){return arguments.length?(c="function"==typeof n?n:r.i(i.a)(+n),t):c},t.x1=function(n){return arguments.length?(f=null==n?null:"function"==typeof n?n:r.i(i.a)(+n),t):f},t.y=function(n){return arguments.length?(s="function"==typeof n?n:r.i(i.a)(+n),l=null,t):s},t.y0=function(n){return arguments.length?(s="function"==typeof n?n:r.i(i.a)(+n),t):s},t.y1=function(n){return arguments.length?(l=null==n?null:"function"==typeof n?n:r.i(i.a)(+n),t):l},t.lineX0=t.lineY0=function(){return n().x(c).y(s)},t.lineY1=function(){return n().x(c).y(l)},t.lineX1=function(){return n().x(f).y(s)},t.defined=function(n){return arguments.length?(h="function"==typeof n?n:r.i(i.a)(!!n),t):h},t.curve=function(n){return arguments.length?(p=n,null!=d&&(v=p(d)),t):p},t.context=function(n){return arguments.length?(null==n?d=v=null:v=p(d=n),t):d},t}},function(t,n,r){"use strict";r.d(n,"a",function(){return e});var e=Array.prototype.slice},function(t,n,r){"use strict";function e(t,n){this._context=t,this._k=(1-n)/6}var i=r(45),u=r(43);n.b=e,e.prototype={areaStart:i.a,areaEnd:i.a,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x3,this._y3),this._context.closePath();break;case 2:this._context.lineTo(this._x3,this._y3),this._context.closePath();break;case 3:this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5)}},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._x3=t,this._y3=n;break;case 1:this._point=2,this._context.moveTo(this._x4=t,this._y4=n);break;case 2:this._point=3,this._x5=t,this._y5=n;break;default:r.i(u.c)(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return new e(t,n)}return r.tension=function(n){return t(+n)},r}(0)},function(t,n,r){"use strict";function e(t,n){this._context=t,this._k=(1-n)/6}var i=r(43);n.b=e,e.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:r.i(i.c)(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return new e(t,n)}return r.tension=function(n){return t(+n)},r}(0)},function(t,n,r){"use strict";function e(t){this._curve=t}function i(t){function n(n){return new e(t(n))}return n._curve=t,n}var u=r(44);r.d(n,"b",function(){return o}),n.a=i;var o=i(u.a);e.prototype={areaStart:function(){this._curve.areaStart()},areaEnd:function(){this._curve.areaEnd()},lineStart:function(){this._curve.lineStart()},lineEnd:function(){this._curve.lineEnd()},point:function(t,n){this._curve.point(n*Math.sin(t),n*-Math.cos(t))}}},function(t,n,r){"use strict";function e(t){var n=t.curve;return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t.curve=function(t){return arguments.length?n(r.i(i.a)(t)):n()._curve},t}var i=r(155),u=r(82);n.b=e,n.a=function(){return e(r.i(u.a)().curve(i.b))}},function(t,n,r){"use strict";n.a=function(t,n){return[(n=+n)*Math.cos(t-=Math.PI/2),n*Math.sin(t)]}},function(t,n,r){"use strict";var e=r(29);n.a={draw:function(t,n){var r=Math.sqrt(n/e.b);t.moveTo(r,0),t.arc(0,0,r,0,e.c)}}},function(t,n,r){"use strict";n.a={draw:function(t,n){var r=Math.sqrt(n/5)/2;t.moveTo(-3*r,-r),t.lineTo(-r,-r),t.lineTo(-r,-3*r),t.lineTo(r,-3*r),t.lineTo(r,-r),t.lineTo(3*r,-r),t.lineTo(3*r,r),t.lineTo(r,r),t.lineTo(r,3*r),t.lineTo(-r,3*r),t.lineTo(-r,r),t.lineTo(-3*r,r),t.closePath()}}},function(t,n,r){"use strict";var e=Math.sqrt(1/3),i=2*e;n.a={draw:function(t,n){var r=Math.sqrt(n/i),u=r*e;t.moveTo(0,-r),t.lineTo(u,0),t.lineTo(0,r),t.lineTo(-u,0),t.closePath()}}},function(t,n,r){"use strict";n.a={draw:function(t,n){var r=Math.sqrt(n),e=-r/2;t.rect(e,e,r,r)}}},function(t,n,r){"use strict";var e=r(29),i=Math.sin(e.b/10)/Math.sin(7*e.b/10),u=Math.sin(e.c/10)*i,o=-Math.cos(e.c/10)*i;n.a={draw:function(t,n){var r=Math.sqrt(.8908130915292852*n),i=u*r,a=o*r;t.moveTo(0,-r),t.lineTo(i,a);for(var c=1;c<5;++c){var f=e.c*c/5,s=Math.cos(f),l=Math.sin(f);t.lineTo(l*r,-s*r),t.lineTo(s*i-l*a,l*i+s*a)}t.closePath()}}},function(t,n,r){"use strict";var e=Math.sqrt(3);n.a={draw:function(t,n){var r=-Math.sqrt(n/(3*e));t.moveTo(0,2*r),t.lineTo(-e*r,-r),t.lineTo(e*r,-r),t.closePath()}}},function(t,n,r){"use strict";var e=-.5,i=Math.sqrt(3)/2,u=1/Math.sqrt(12),o=3*(u/2+1);n.a={draw:function(t,n){var r=Math.sqrt(n/o),a=r/2,c=r*u,f=a,s=r*u+r,l=-f,h=s;t.moveTo(a,c),t.lineTo(f,s),t.lineTo(l,h),t.lineTo(e*a-i*c,i*a+e*c),t.lineTo(e*f-i*s,i*f+e*s),t.lineTo(e*l-i*h,i*l+e*h),t.lineTo(e*a+i*c,e*c-i*a),t.lineTo(e*f+i*s,e*s-i*f),t.lineTo(e*l+i*h,e*h-i*l),t.closePath()}}},function(t,n,r){"use strict";function e(t){return t.toISOString()}var i=r(86);r.d(n,"b",function(){return u});var u="%Y-%m-%dT%H:%M:%S.%LZ",o=Date.prototype.toISOString?e:r.i(i.d)(u);n.a=o},function(t,n,r){"use strict";function e(t){if(0<=t.y&&t.y<100){var n=new Date(-1,t.m,t.d,t.H,t.M,t.S,t.L);return n.setFullYear(t.y),n}return new Date(t.y,t.m,t.d,t.H,t.M,t.S,t.L)}function i(t){if(0<=t.y&&t.y<100){var n=new Date(Date.UTC(-1,t.m,t.d,t.H,t.M,t.S,t.L));return n.setUTCFullYear(t.y),n}return new Date(Date.UTC(t.y,t.m,t.d,t.H,t.M,t.S,t.L))}function u(t){return{y:t,m:0,d:1,H:0,M:0,S:0,L:0}}function o(t){function n(t,n){return function(r){var e,i,u,o=[],a=-1,c=0,f=t.length;for(r instanceof Date||(r=new Date(+r));++a53)return null;"w"in f||(f.w=1),"Z"in f?(o=i(u(f.y)),c=o.getUTCDay(),o=c>4||0===c?dt.T.ceil(o):r.i(dt.T)(o),o=dt.N.offset(o,7*(f.V-1)),f.y=o.getUTCFullYear(),f.m=o.getUTCMonth(),f.d=o.getUTCDate()+(f.w+6)%7):(o=n(u(f.y)),c=o.getDay(),o=c>4||0===c?dt.t.ceil(o):r.i(dt.t)(o),o=dt.n.offset(o,7*(f.V-1)),f.y=o.getFullYear(),f.m=o.getMonth(),f.d=o.getDate()+(f.w+6)%7)}else("W"in f||"U"in f)&&("w"in f||(f.w="u"in f?f.u%7:"W"in f?1:0),c="Z"in f?i(u(f.y)).getUTCDay():n(u(f.y)).getDay(),f.m=0,f.d="W"in f?(f.w+6)%7+7*f.W-(c+5)%7:f.w+7*f.U-(c+6)%7);return"Z"in f?(f.H+=f.Z/100|0,f.M+=f.Z%100,i(f)):n(f)}}function a(t,n,r,e){for(var i,u,o=0,a=n.length,c=r.length;o=c)return-1;if(37===(i=n.charCodeAt(o++))){if(i=n.charAt(o++),!(u=Jt[i in pt?n.charAt(o++):i])||(e=u(t,r,e))<0)return-1}else if(i!=r.charCodeAt(e++))return-1}return e}function c(t,n,r){var e=It.exec(n.slice(r));return e?(t.p=Ft[e[0].toLowerCase()],r+e[0].length):-1}function vt(t,n,r){var e=Ht.exec(n.slice(r));return e?(t.w=Xt[e[0].toLowerCase()],r+e[0].length):-1}function gt(t,n,r){var e=Yt.exec(n.slice(r));return e?(t.w=Bt[e[0].toLowerCase()],r+e[0].length):-1}function yt(t,n,r){var e=Wt.exec(n.slice(r));return e?(t.m=Zt[e[0].toLowerCase()],r+e[0].length):-1}function _t(t,n,r){var e=Vt.exec(n.slice(r));return e?(t.m=Gt[e[0].toLowerCase()],r+e[0].length):-1}function bt(t,n,r){return a(t,zt,n,r)}function mt(t,n,r){return a(t,Pt,n,r)}function xt(t,n,r){return a(t,Lt,n,r)}function wt(t){return Ut[t.getDay()]}function Mt(t){return Rt[t.getDay()]}function kt(t){return jt[t.getMonth()]}function Tt(t){return Ot[t.getMonth()]}function Et(t){return Dt[+(t.getHours()>=12)]}function At(t){return Ut[t.getUTCDay()]}function Nt(t){return Rt[t.getUTCDay()]}function St(t){return jt[t.getUTCMonth()]}function Ct(t){return Ot[t.getUTCMonth()]}function qt(t){return Dt[+(t.getUTCHours()>=12)]}var zt=t.dateTime,Pt=t.date,Lt=t.time,Dt=t.periods,Rt=t.days,Ut=t.shortDays,Ot=t.months,jt=t.shortMonths,It=f(Dt),Ft=s(Dt),Yt=f(Rt),Bt=s(Rt),Ht=f(Ut),Xt=s(Ut),Vt=f(Ot),Gt=s(Ot),Wt=f(jt),Zt=s(jt),$t={a:wt,A:Mt,b:kt,B:Tt,c:null,d:C,e:C,f:D,H:q,I:z,j:P,L:L,m:R,M:U,p:Et,Q:lt,s:ht,S:O,u:j,U:I,V:F,w:Y,W:B,x:null,X:null,y:H,Y:X,Z:V,"%":st},Qt={a:At,A:Nt,b:St,B:Ct,c:null,d:G,e:G,f:J,H:W,I:Z,j:$,L:Q,m:K,M:tt,p:qt,Q:lt,s:ht,S:nt,u:rt,U:et,V:it,w:ut,W:ot,x:null,X:null,y:at,Y:ct,Z:ft,"%":st},Jt={a:vt,A:gt,b:yt,B:_t,c:bt,d:m,e:m,f:E,H:w,I:w,j:x,L:T,m:b,M:M,p:c,Q:N,s:S,S:k,u:h,U:d,V:p,w:l,W:v,x:mt,X:xt,y:y,Y:g,Z:_,"%":A};return $t.x=n(Pt,$t),$t.X=n(Lt,$t),$t.c=n(zt,$t),Qt.x=n(Pt,Qt),Qt.X=n(Lt,Qt),Qt.c=n(zt,Qt),{format:function(t){var r=n(t+="",$t);return r.toString=function(){return t},r},parse:function(t){var n=o(t+="",e);return n.toString=function(){return t},n},utcFormat:function(t){var r=n(t+="",Qt);return r.toString=function(){return t},r},utcParse:function(t){var n=o(t,i);return n.toString=function(){return t},n}}}function a(t,n,r){var e=t<0?"-":"",i=(e?-t:t)+"",u=i.length;return e+(u68?1900:2e3),r+e[0].length):-1}function _(t,n,r){var e=/^(Z)|([+-]\d\d)(?::?(\d\d))?/.exec(n.slice(r,r+6));return e?(t.Z=e[1]?0:-(e[2]+(e[3]||"00")),r+e[0].length):-1}function b(t,n,r){var e=vt.exec(n.slice(r,r+2));return e?(t.m=e[0]-1,r+e[0].length):-1}function m(t,n,r){var e=vt.exec(n.slice(r,r+2));return e?(t.d=+e[0],r+e[0].length):-1}function x(t,n,r){var e=vt.exec(n.slice(r,r+3));return e?(t.m=0,t.d=+e[0],r+e[0].length):-1}function w(t,n,r){var e=vt.exec(n.slice(r,r+2));return e?(t.H=+e[0],r+e[0].length):-1}function M(t,n,r){var e=vt.exec(n.slice(r,r+2));return e?(t.M=+e[0],r+e[0].length):-1}function k(t,n,r){var e=vt.exec(n.slice(r,r+2));return e?(t.S=+e[0],r+e[0].length):-1}function T(t,n,r){var e=vt.exec(n.slice(r,r+3));return e?(t.L=+e[0],r+e[0].length):-1}function E(t,n,r){var e=vt.exec(n.slice(r,r+6));return e?(t.L=Math.floor(e[0]/1e3),r+e[0].length):-1}function A(t,n,r){var e=gt.exec(n.slice(r,r+1));return e?r+e[0].length:-1}function N(t,n,r){var e=vt.exec(n.slice(r));return e?(t.Q=+e[0],r+e[0].length):-1}function S(t,n,r){var e=vt.exec(n.slice(r));return e?(t.Q=1e3*+e[0],r+e[0].length):-1}function C(t,n){return a(t.getDate(),n,2)}function q(t,n){return a(t.getHours(),n,2)}function z(t,n){return a(t.getHours()%12||12,n,2)}function P(t,n){return a(1+dt.n.count(r.i(dt.H)(t),t),n,3)}function L(t,n){return a(t.getMilliseconds(),n,3)}function D(t,n){return L(t,n)+"000"}function R(t,n){return a(t.getMonth()+1,n,2)}function U(t,n){return a(t.getMinutes(),n,2)}function O(t,n){return a(t.getSeconds(),n,2)}function j(t){var n=t.getDay();return 0===n?7:n}function I(t,n){return a(dt.r.count(r.i(dt.H)(t),t),n,2)}function F(t,n){var e=t.getDay();return t=e>=4||0===e?r.i(dt.z)(t):dt.z.ceil(t),a(dt.z.count(r.i(dt.H)(t),t)+(4===r.i(dt.H)(t).getDay()),n,2)}function Y(t){return t.getDay()}function B(t,n){return a(dt.t.count(r.i(dt.H)(t),t),n,2)}function H(t,n){return a(t.getFullYear()%100,n,2)}function X(t,n){return a(t.getFullYear()%1e4,n,4)}function V(t){var n=t.getTimezoneOffset();return(n>0?"-":(n*=-1,"+"))+a(n/60|0,"0",2)+a(n%60,"0",2)}function G(t,n){return a(t.getUTCDate(),n,2)}function W(t,n){return a(t.getUTCHours(),n,2)}function Z(t,n){return a(t.getUTCHours()%12||12,n,2)}function $(t,n){return a(1+dt.N.count(r.i(dt._7)(t),t),n,3)}function Q(t,n){return a(t.getUTCMilliseconds(),n,3)}function J(t,n){return Q(t,n)+"000"}function K(t,n){return a(t.getUTCMonth()+1,n,2)}function tt(t,n){return a(t.getUTCMinutes(),n,2)}function nt(t,n){return a(t.getUTCSeconds(),n,2)}function rt(t){var n=t.getUTCDay();return 0===n?7:n}function et(t,n){return a(dt.R.count(r.i(dt._7)(t),t),n,2)}function it(t,n){var e=t.getUTCDay();return t=e>=4||0===e?r.i(dt.Z)(t):dt.Z.ceil(t),a(dt.Z.count(r.i(dt._7)(t),t)+(4===r.i(dt._7)(t).getUTCDay()),n,2)}function ut(t){return t.getUTCDay()}function ot(t,n){return a(dt.T.count(r.i(dt._7)(t),t),n,2)}function at(t,n){return a(t.getUTCFullYear()%100,n,2)}function ct(t,n){return a(t.getUTCFullYear()%1e4,n,4)}function ft(){return"+0000"}function st(){return"%"}function lt(t){return+t}function ht(t){return Math.floor(+t/1e3)}var dt=r(46);n.a=o;var pt={"-":"",_:" ",0:"0"},vt=/^\s*\d+/,gt=/^%/,yt=/[\\^$*+?|[\]().{}]/g},function(t,n,r){"use strict";var e=r(6);n.a=function(t,n){var r,i,u,o=t.__transition,a=!0;if(o){n=null==n?null:n+"";for(u in o)(r=o[u]).name===n?(i=r.state>e.a&&r.states.b||Math.abs(m-y)>s.b)&&(d.splice(h,0,s.d.push(r.i(f.b)(l,_,Math.abs(b-t)s.b?[t,Math.abs(g-t)s.b?[Math.abs(y-i)s.b?[e,Math.abs(g-e)s.b?[Math.abs(y-n)=-a.f)){var y=h*h+d*d,_=p*p+v*v,b=(v*y-d*_)/g,m=(h*_-p*y)/g,x=f.pop()||new e;x.arc=t,x.site=u,x.x=b+s,x.y=(x.cy=m+l)+Math.sqrt(b*b+m*m),t.circle=x;for(var w=null,M=a.g._;M;)if(x.y=n-t.span&&r.timestamp<=n}),i=this.ag.selectAll("line.annotation").data(r).attr("x1",function(n){return t.x(n.timestamp)}).attr("x2",function(n){return t.x(n.timestamp)});i.enter().append("line").classed("annotation",!0).attr("stroke",function(t){return"continued"===t.type?"rgba(0, 255, 0, 0.25)":"rgba(255, 0, 0, 0.25)"}).attr("stroke-width",1).attr("y1",0).attr("y2",this.height).attr("x1",function(n){return t.x(n.timestamp)}).attr("x2",function(n){return t.x(n.timestamp)}),i.exit().remove(),this.paths.forEach(function(r){try{var e=t.datasource.getData(r.port,n-t.span,n,!0);r.path.datum(e).attr("d",t.line)}catch(t){console.log("Error Updating Plot: ",t)}}),this.spaths.forEach(function(r){try{var e=t.datasource.sampleData(r.port,t.width,t.start,n);r.path.datum(e).attr("d",t.sline)}catch(t){console.log("Error Updating Plot: ",t)}});var u=n-this.span;u0){var r=this.points[this.points.length-1];this.points=this.points.filter(function(t){return t.timestamp>=n}),0===this.points.length&&this.points.push(r),this.path.datum(this.points).attr("d",this.line)}}catch(t){console.log("Error Updating Plot: ",t)}window.requestAnimationFrame(this.updateGraph.bind(this))},t}();n.XYGraph=i},function(t,n,r){"use strict";Object.defineProperty(n,"__esModule",{value:!0});var e=function(){function t(t){var n=this;this.data={},this.subscriptions={},t.forEach(function(t){return n.addPort(t)})}return t.prototype.addPort=function(t){this.data[t]=[]},t.prototype.receiveMessage=function(t){var n={timestamp:t.timestamp,value:t.data,raw:t.raw},r=t.port;this.data[r]&&this.data[r].push(n),this.subscriptions[r]&&this.subscriptions[r].forEach(function(t){return t(n)})},t.prototype.getData=function(t,n,r,e){void 0===e&&(e=!0);var i=this.data[t];if(!i)return[];if(i=i.filter(function(t){return t.timestamp>=n&&t.timestamp<=r}),e&&i.length>=1){var u=i[i.length-1];i.push({timestamp:r,value:u.value,raw:u.raw});var o=i[0];i.unshift({timestamp:n,value:o.value,raw:o.raw})}return i},t.prototype.sampleData=function(t,n,r,e){void 0===r&&(r=null),void 0===e&&(e=null);var i=this.data[t];if(!i)return[];if(null===r&&(r=0),null==e&&(e=(new Date).getTime()),i=i.filter(function(t){return t.timestamp>=r&&t.timestamp<=e}),i.length>1.5*n){var u=Math.round(i.length/n);i=i.filter(function(t,n){return n%u==0})}return i},t.prototype.subscribe=function(t,n){this.subscriptions[t]||(this.subscriptions[t]=[]),this.subscriptions[t].push(n)},t}();n.GraphDataSource=e},function(t,n,r){function e(t,n){this._id=t,this._clearFn=n}var i=Function.prototype.apply;n.setTimeout=function(){return new e(i.call(setTimeout,window,arguments),clearTimeout)},n.setInterval=function(){return new e(i.call(setInterval,window,arguments),clearInterval)},n.clearTimeout=n.clearInterval=function(t){t&&t.close()},e.prototype.unref=e.prototype.ref=function(){},e.prototype.close=function(){this._clearFn.call(window,this._id)},n.enroll=function(t,n){clearTimeout(t._idleTimeoutId),t._idleTimeout=n},n.unenroll=function(t){clearTimeout(t._idleTimeoutId),t._idleTimeout=-1},n._unrefActive=n.active=function(t){clearTimeout(t._idleTimeoutId);var n=t._idleTimeout;n>=0&&(t._idleTimeoutId=setTimeout(function(){t._onTimeout&&t._onTimeout()},n))},r(467),n.setImmediate=setImmediate,n.clearImmediate=clearImmediate},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";var e=r(97);n.a=function(t,n,r){var i,u,o,a,c=t.length,f=n.length,s=new Array(c*f);for(null==r&&(r=e.b),i=o=0;it?1:n>=t?0:NaN}},function(t,n,r){"use strict";var e=r(91),i=r(92),u=r(176),o=r(95),a=r(180),c=r(98),f=r(100),s=r(99);n.a=function(){function t(t){var e,u,o=t.length,a=new Array(o);for(e=0;ep;)v.pop(),--g;var y,_=new Array(g+1);for(e=0;e<=g;++e)y=_[e]=[],y.x0=e>0?v[e-1]:d,y.x1=e=r)for(e=r;++ue&&(e=r)}else for(;++u=r)for(e=r;++ue&&(e=r);return e}},function(t,n,r){"use strict";var e=r(21);n.a=function(t,n){var i,u=t.length,o=u,a=-1,c=0;if(null==n)for(;++a=0;)for(e=t[i],n=e.length;--n>=0;)r[--o]=e[n];return r}},function(t,n,r){"use strict";n.a=function(t,n){for(var r=n.length,e=new Array(r);r--;)e[r]=t[n[r]];return e}},function(t,n,r){"use strict";var e=r(17);n.a=function(t,n){if(r=t.length){var r,i,u=0,o=0,a=t[o];for(null==n&&(n=e.a);++uMath.abs(t[1]-nt[1])?I=!0:j=!0),nt=t,O=!0,r.i(b.a)(),e()}function e(){var t;switch(R=nt[0]-tt[0],U=nt[1]-tt[1],B){case x:case m:H&&(R=Math.max(Z-l,Math.min(Q-_,R)),h=l+R,E=_+R),X&&(U=Math.max($-p,Math.min(J-P,U)),y=p+U,D=P+U);break;case w:H<0?(R=Math.max(Z-l,Math.min(Q-l,R)),h=l+R,E=_):H>0&&(R=Math.max(Z-_,Math.min(Q-_,R)),h=l,E=_+R),X<0?(U=Math.max($-p,Math.min(J-p,U)),y=p+U,D=P):X>0&&(U=Math.max($-P,Math.min(J-P,U)),y=p,D=P+U);break;case M:H&&(h=Math.max(Z,Math.min(Q,l-R*H)),E=Math.max(Z,Math.min(Q,_+R*H))),X&&(y=Math.max($,Math.min(J,p-U*X)),D=Math.max($,Math.min(J,P+U*X)))}E0&&(l=h-R),X<0?P=D-U:X>0&&(p=y-U),B=x,it.attr("cursor",A.selection),e());break;default:return}r.i(b.a)()}function s(){switch(v.q.keyCode){case 16:K&&(j=I=K=!1,e());break;case 18:B===M&&(H<0?_=E:H>0&&(l=h),X<0?P=D:X>0&&(p=y),B=w,e());break;case 32:B===x&&(v.q.altKey?(H&&(_=E-R*H,l=h+R*H),X&&(P=D-U*X,p=y+U*X),B=M):(H<0?_=E:H>0&&(l=h),X<0?P=D:X>0&&(p=y),B=w),it.attr("cursor",A[Y]),e());break;default:return}r.i(b.a)()}if(v.q.touches){if(v.q.changedTouches.length=l.length)return null!=c&&n.sort(c),null!=f?f(n):n;for(var o,s,h,d=-1,p=n.length,v=l[e++],g=r.i(a.a)(),y=i();++dl.length)return t;var e,i=h[r-1];return null!=f&&r>=l.length?e=t.entries():(e=[],t.each(function(t,i){e.push({key:i,values:n(t,r)})})),null!=i?e.sort(function(t,n){return i(t.key,n.key)}):e}var c,f,s,l=[],h=[];return s={object:function(n){return t(n,0,e,i)},map:function(n){return t(n,0,u,o)},entries:function(r){return n(t(r,0,u,o),0)},key:function(t){return l.push(t),s},sortKeys:function(t){return h[l.length-1]=t,s},sortValues:function(t){return c=t,s},rollup:function(t){return f=t,s}}}},function(t,n,r){"use strict";function e(){}function i(t,n){var r=new e;if(t instanceof e)t.each(function(t){r.add(t)});else if(t){var i=-1,u=t.length;if(null==n)for(;++iM?Math.pow(t,1/3):t/w+m}function a(t){return t>x?t*t*t:w*(t-m)}function c(t){return 255*(t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055)}function f(t){return(t/=255)<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}function s(t){if(t instanceof h)return new h(t.h,t.c,t.l,t.opacity);t instanceof u||(t=e(t));var n=Math.atan2(t.b,t.a)*v.a;return new h(n<0?n+360:n,Math.sqrt(t.a*t.a+t.b*t.b),t.l,t.opacity)}function l(t,n,r,e){return 1===arguments.length?s(t):new h(t,n,r,null==e?1:e)}function h(t,n,r,e){this.h=+t,this.c=+n,this.l=+r,this.opacity=+e}var d=r(53),p=r(52),v=r(104);n.a=i,n.b=l;var g=18,y=.95047,_=1,b=1.08883,m=4/29,x=6/29,w=3*x*x,M=x*x*x;r.i(d.a)(u,i,r.i(d.b)(p.f,{brighter:function(t){return new u(this.l+g*(null==t?1:t),this.a,this.b,this.opacity)},darker:function(t){return new u(this.l-g*(null==t?1:t),this.a,this.b,this.opacity)},rgb:function(){var t=(this.l+16)/116,n=isNaN(this.a)?t:t+this.a/500,r=isNaN(this.b)?t:t-this.b/200;return t=_*a(t),n=y*a(n),r=b*a(r),new p.d(c(3.2404542*n-1.5371385*t-.4985314*r),c(-.969266*n+1.8760108*t+.041556*r),c(.0556434*n-.2040259*t+1.0572252*r),this.opacity)}})),r.i(d.a)(h,l,r.i(d.b)(p.f,{brighter:function(t){return new h(this.h,this.c,this.l+g*(null==t?1:t),this.opacity)},darker:function(t){return new h(this.h,this.c,this.l-g*(null==t?1:t),this.opacity)},rgb:function(){return e(this).rgb()}}))},function(t,n,r){"use strict";function e(){for(var t,n=0,r=arguments.length,e={};n=0&&(r=t.slice(e+1),t=t.slice(0,e)),t&&!n.hasOwnProperty(t))throw new Error("unknown type: "+t);return{type:t,name:r}})}function o(t,n){for(var r,e=0,i=t.length;e0)for(var r,e,i=new Array(r),u=0;uC}A.mouse("drag")}function p(){r.i(c.h)(c.q.view).on("mousemove.drag mouseup.drag",null),r.i(f.b)(c.q.view,x),r.i(s.a)(),A.mouse("end")}function v(){if(M.apply(this,arguments)){var t,n,e=c.q.changedTouches,i=k.apply(this,arguments),u=e.length;for(t=0;tp+s||iv+s||uf.index){var l=p-a.x-a.vx,d=v-a.y-a.vy,_=l*l+d*d;_t.r&&(t.r=t[n].r)}function f(){if(s){var n,r,e=s.length;for(l=new Array(e),n=0;n=v)){(t.data!==s||t.next)&&(0===o&&(o=r.i(i.a)(),f+=o*o),0===a&&(a=r.i(i.a)(),f+=a*a),f0&&(u=0)}return u>0?t.slice(0,u)+t.slice(r+1):t}},function(t,n,r){"use strict";n.a=function(t,n){return function(r,e){for(var i=r.length,u=[],o=0,a=t[0],c=0;i>0&&a>0&&(c+a+1>e&&(a=Math.max(1,e-c)),u.push(r.substring(i-=a,i+a)),!((c+=a+1)>e));)a=t[o=(o+1)%t.length];return u.reverse().join(n)}}},function(t,n,r){"use strict";n.a=function(t){return function(n){return n.replace(/[0-9]/g,function(n){return t[+n]})}}},function(t,n,r){"use strict";var e=r(59);n.a=function(t,n){var i=r.i(e.a)(t,n);if(!i)return t+"";var u=i[0],o=i[1];return o<0?"0."+new Array(-o).join("0")+u:u.length>o+1?u.slice(0,o+1)+"."+u.slice(o+1):u+new Array(o-u.length+2).join("0")}},function(t,n,r){"use strict";n.a=function(t){return t}},function(t,n,r){"use strict";var e=r(33);n.a=function(t){return Math.max(0,-r.i(e.a)(Math.abs(t)))}},function(t,n,r){"use strict";var e=r(33);n.a=function(t,n){return Math.max(0,3*Math.max(-8,Math.min(8,Math.floor(r.i(e.a)(n)/3)))-r.i(e.a)(Math.abs(t)))}},function(t,n,r){"use strict";var e=r(33);n.a=function(t,n){return t=Math.abs(t),n=Math.abs(n)-t,Math.max(0,r.i(e.a)(n)-r.i(e.a)(t))+1}},function(t,n,r){"use strict";var e=r(113);r.d(n,"a",function(){return e.a});var i=r(247);r.d(n,"b",function(){return i.a});var u=r(248);r.d(n,"c",function(){return u.a});var o=r(114);r.d(n,"d",function(){return o.a});var a=r(115);r.d(n,"e",function(){return a.a});var c=r(117);r.d(n,"f",function(){return c.a});var f=r(249);r.d(n,"g",function(){return f.a});var s=r(34);r.d(n,"h",function(){return s.a});var l=r(252);r.d(n,"i",function(){return l.a});var h=r(121);r.d(n,"j",function(){return h.a});var d=r(253);r.d(n,"k",function(){return d.a}),r.d(n,"l",function(){return d.b});var p=r(254);r.d(n,"m",function(){return p.a});var v=r(122);r.d(n,"n",function(){return v.a});var g=r(258);r.d(n,"o",function(){return g.a});var y=r(126);r.d(n,"p",function(){return y.a});var _=r(261);r.d(n,"q",function(){return _.a});var b=r(262);r.d(n,"r",function(){return b.a}),r.d(n,"s",function(){return b.b});var m=r(263);r.d(n,"t",function(){return m.a}),r.d(n,"u",function(){return m.b});var x=r(264);r.d(n,"v",function(){return x.a}),r.d(n,"w",function(){return x.b});var w=r(62);r.d(n,"x",function(){return w.a}),r.d(n,"y",function(){return w.b});var M=r(265);r.d(n,"z",function(){return M.a}),r.d(n,"A",function(){return M.b});var k=r(127);r.d(n,"B",function(){return k.a}),r.d(n,"C",function(){return k.b});var T=r(267);r.d(n,"D",function(){return T.a}),r.d(n,"E",function(){return T.b});var E=r(268);r.d(n,"F",function(){return E.a});var A=r(8);r.d(n,"G",function(){return A.a}),r.d(n,"H",function(){return A.b});var N=r(64);r.d(n,"I",function(){return N.a}),r.d(n,"J",function(){return N.b});var S=r(269);r.d(n,"K",function(){return S.a}),r.d(n,"L",function(){return S.b});var C=r(270);r.d(n,"M",function(){return C.a}),r.d(n,"N",function(){return C.b});var q=r(272);r.d(n,"O",function(){return q.a}),r.d(n,"P",function(){return q.b});var z=r(273);r.d(n,"Q",function(){return z.a}),r.d(n,"R",function(){return z.b});var P=r(35);r.d(n,"S",function(){return P.a});var L=r(13);r.d(n,"T",function(){return L.a});var D=r(36);r.d(n,"U",function(){return D.a})},function(t,n,r){"use strict";function e(t,n){x.push(w=[d=t,v=t]),ng&&(g=n)}function i(t,n){var e=r.i(T.a)([t*E.g,n*E.g]);if(m){var i=r.i(T.b)(m,e),u=[i[1],-i[0],0],o=r.i(T.b)(u,i);r.i(T.c)(o),o=r.i(T.g)(o);var a,c=t-y,f=c>0?1:-1,l=o[0]*E.h*f,h=r.i(E.p)(c)>180;h^(f*yg&&(g=a):(l=(l+360)%360-180,h^(f*yg&&(g=n))),h?ts(d,v)&&(v=t):s(t,v)>s(d,v)&&(d=t):v>=d?(tv&&(v=t)):t>y?s(d,t)>s(d,v)&&(v=t):s(t,v)>s(d,v)&&(d=t)}else x.push(w=[d=t,v=t]);ng&&(g=n),m=e,y=t}function u(){S.point=i}function o(){w[0]=d,w[1]=v,S.point=e,m=null}function a(t,n){if(m){var e=t-y;N.add(r.i(E.p)(e)>180?e+(e>0?360:-360):e)}else _=t,b=n;k.b.point(t,n),i(t,n)}function c(){k.b.lineStart()}function f(){a(_,b),k.b.lineEnd(),r.i(E.p)(N)>E.o&&(d=-(v=180)),w[0]=d,w[1]=v,m=null}function s(t,n){return(n-=t)<0?n+360:n}function l(t,n){return t[0]-n[0]}function h(t,n){return t[0]<=t[1]?t[0]<=n&&n<=t[1]:nE.o?g=90:N<-E.o&&(p=-90),w[0]=d,w[1]=v}};n.a=function(t){var n,e,i,u,o,a,c;if(g=v=-(d=p=1/0),x=[],r.i(A.a)(t,S),e=x.length){for(x.sort(l),n=1,i=x[0],o=[i];ns(i[0],i[1])&&(i[1]=u[1]),s(u[0],i[1])>s(i[0],i[1])&&(i[0]=u[0])):o.push(i=u);for(a=-1/0,e=o.length-1,n=0,i=o[e];n<=e;i=u,++n)u=o[n],(c=s(i[1],u[0]))>a&&(a=c,d=u[0],v=i[1])}return x=w=null,d===1/0||p===1/0?[[NaN,NaN],[NaN,NaN]]:[[d,p],[v,g]]}},function(t,n,r){"use strict";function e(t,n){t*=S.g,n*=S.g;var e=r.i(S.c)(n);i(e*r.i(S.c)(t),e*r.i(S.d)(t),r.i(S.d)(n))}function i(t,n,r){++d,v+=(t-v)/d,g+=(n-g)/d,y+=(r-y)/d}function u(){z.point=o}function o(t,n){t*=S.g,n*=S.g;var e=r.i(S.c)(n);E=e*r.i(S.c)(t),A=e*r.i(S.d)(t),N=r.i(S.d)(n),z.point=a,i(E,A,N)}function a(t,n){t*=S.g,n*=S.g;var e=r.i(S.c)(n),u=e*r.i(S.c)(t),o=e*r.i(S.d)(t),a=r.i(S.d)(n),c=r.i(S.e)(r.i(S.n)((c=A*a-N*o)*c+(c=N*u-E*a)*c+(c=E*o-A*u)*c),E*u+A*o+N*a);p+=c,_+=c*(E+(E=u)),b+=c*(A+(A=o)),m+=c*(N+(N=a)),i(E,A,N)}function c(){z.point=e}function f(){z.point=l}function s(){h(k,T),z.point=e}function l(t,n){k=t,T=n,t*=S.g,n*=S.g,z.point=h;var e=r.i(S.c)(n);E=e*r.i(S.c)(t),A=e*r.i(S.d)(t),N=r.i(S.d)(n),i(E,A,N)}function h(t,n){t*=S.g,n*=S.g;var e=r.i(S.c)(n),u=e*r.i(S.c)(t),o=e*r.i(S.d)(t),a=r.i(S.d)(n),c=A*a-N*o,f=N*u-E*a,s=E*o-A*u,l=r.i(S.n)(c*c+f*f+s*s),h=r.i(S.f)(l),d=l&&-h/l;x+=d*c,w+=d*f,M+=d*s,p+=h,_+=h*(E+(E=u)),b+=h*(A+(A=o)),m+=h*(N+(N=a)),i(E,A,N)}var d,p,v,g,y,_,b,m,x,w,M,k,T,E,A,N,S=r(0),C=r(10),q=r(13),z={sphere:C.a,point:e,lineStart:u,lineEnd:c,polygonStart:function(){z.lineStart=f,z.lineEnd=s},polygonEnd:function(){z.lineStart=u,z.lineEnd=c}};n.a=function(t){d=p=v=g=y=_=b=m=x=w=M=0,r.i(q.a)(t,z);var n=x,e=w,i=M,u=n*n+e*e+i*i;return u0)){if(o/=d,d<0){if(o0){if(o>h)return;o>l&&(l=o)}if(o=i-a,d||!(o<0)){if(o/=d,d<0){if(o>h)return;o>l&&(l=o)}else if(d>0){if(o0)){if(o/=p,p<0){if(o0){if(o>h)return;o>l&&(l=o)}if(o=u-c,p||!(o<0)){if(o/=p,p<0){if(o>h)return;o>l&&(l=o)}else if(p>0){if(o0&&(t[0]=a+l*d,t[1]=c+l*p),h<1&&(n[0]=a+h*d,n[1]=c+h*p),!0}}}}}},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(t,n){return!(!t||!d.hasOwnProperty(t.type))&&d[t.type](t,n)}function i(t,n){return 0===r.i(s.a)(t,n)}function u(t,n){var e=r.i(s.a)(t[0],t[1]);return r.i(s.a)(t[0],n)+r.i(s.a)(n,t[1])<=e+l.o}function o(t,n){return!!r.i(f.a)(t.map(a),c(n))}function a(t){return t=t.map(c),t.pop(),t}function c(t){return[t[0]*l.g,t[1]*l.g]}var f=r(125),s=r(121),l=r(0),h={Feature:function(t,n){return e(t.geometry,n)},FeatureCollection:function(t,n){for(var r=t.features,i=-1,u=r.length;++ic.o}).map(v)).concat(r.i(a.v)(r.i(c.u)(h/m)*m,l,m).filter(function(t){return r.i(c.p)(t%w)>c.o}).map(g))}var u,o,f,s,l,h,d,p,v,g,y,_,b=10,m=b,x=90,w=360,M=2.5;return t.lines=function(){return n().map(function(t){return{type:"LineString",coordinates:t}})},t.outline=function(){return{type:"Polygon",coordinates:[y(s).concat(_(d).slice(1),y(f).reverse().slice(1),_(p).reverse().slice(1))]}},t.extent=function(n){return arguments.length?t.extentMajor(n).extentMinor(n):t.extentMinor()},t.extentMajor=function(n){return arguments.length?(s=+n[0][0],f=+n[1][0],p=+n[0][1],d=+n[1][1],s>f&&(n=s,s=f,f=n),p>d&&(n=p,p=d,d=n),t.precision(M)):[[s,p],[f,d]]},t.extentMinor=function(n){return arguments.length?(o=+n[0][0],u=+n[1][0],h=+n[0][1],l=+n[1][1],o>u&&(n=o,o=u,u=n),h>l&&(n=h,h=l,l=n),t.precision(M)):[[o,h],[u,l]]},t.step=function(n){return arguments.length?t.stepMajor(n).stepMinor(n):t.stepMinor()},t.stepMajor=function(n){return arguments.length?(x=+n[0],w=+n[1],t):[x,w]},t.stepMinor=function(n){return arguments.length?(b=+n[0],m=+n[1],t):[b,m]},t.precision=function(n){return arguments.length?(M=+n,v=e(h,l,90),g=i(o,u,M),y=e(p,d,90),_=i(s,f,M),t):M},t.extentMajor([[-180,-90+c.o],[180,90-c.o]]).extentMinor([[-180,-80-c.o],[180,80+c.o]])}function o(){return u()()}var a=r(3),c=r(0);n.a=u,n.b=o},function(t,n,r){"use strict";var e=r(0);n.a=function(t,n){var i=t[0]*e.g,u=t[1]*e.g,o=n[0]*e.g,a=n[1]*e.g,c=r.i(e.c)(u),f=r.i(e.d)(u),s=r.i(e.c)(a),l=r.i(e.d)(a),h=c*r.i(e.c)(i),d=c*r.i(e.d)(i),p=s*r.i(e.c)(o),v=s*r.i(e.d)(o),g=2*r.i(e.f)(r.i(e.n)(r.i(e.t)(a-u)+c*s*r.i(e.t)(o-i))),y=r.i(e.d)(g),_=g?function(t){var n=r.i(e.d)(t*=g)/y,i=r.i(e.d)(g-t)/y,u=i*h+n*p,o=i*d+n*v,a=i*f+n*l;return[r.i(e.e)(o,u)*e.h,r.i(e.e)(a,r.i(e.n)(u*u+o*o))*e.h]}:function(){return[i*e.h,u*e.h]};return _.distance=g,_}},function(t,n,r){"use strict";function e(){g.point=i}function i(t,n){g.point=u,a=f=t,c=s=n}function u(t,n){v.add(s*t-f*n),f=t,s=n}function o(){u(a,c)}var a,c,f,s,l=r(19),h=r(0),d=r(10),p=r.i(l.a)(),v=r.i(l.a)(),g={point:d.a,lineStart:d.a,lineEnd:d.a,polygonStart:function(){g.lineStart=e,g.lineEnd=o},polygonEnd:function(){g.lineStart=g.lineEnd=g.point=d.a,p.add(r.i(h.p)(v)),v.reset()},result:function(){var t=p/2;return p.reset(),t}};n.a=g},function(t,n,r){"use strict";function e(t,n){y+=t,_+=n,++b}function i(){E.point=u}function u(t,n){E.point=o,e(p=t,v=n)}function o(t,n){var i=t-p,u=n-v,o=r.i(g.n)(i*i+u*u);m+=o*(p+t)/2,x+=o*(v+n)/2,w+=o,e(p=t,v=n)}function a(){E.point=e}function c(){E.point=s}function f(){l(h,d)}function s(t,n){E.point=l,e(h=p=t,d=v=n)}function l(t,n){var i=t-p,u=n-v,o=r.i(g.n)(i*i+u*u);m+=o*(p+t)/2,x+=o*(v+n)/2,w+=o,o=v*t-p*n,M+=o*(p+t),k+=o*(v+n),T+=3*o,e(p=t,v=n)}var h,d,p,v,g=r(0),y=0,_=0,b=0,m=0,x=0,w=0,M=0,k=0,T=0,E={point:e,lineStart:i,lineEnd:a,polygonStart:function(){E.lineStart=c,E.lineEnd=f},polygonEnd:function(){E.point=e,E.lineStart=i,E.lineEnd=a},result:function(){var t=T?[M/T,k/T]:w?[m/w,x/w]:b?[y/b,_/b]:[NaN,NaN];return y=_=b=m=x=w=M=k=T=0,t}};n.a=E},function(t,n,r){"use strict";function e(t){this._context=t}var i=r(0),u=r(10);n.a=e,e.prototype={_radius:4.5,pointRadius:function(t){return this._radius=t,this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._context.closePath(),this._point=NaN},point:function(t,n){switch(this._point){case 0:this._context.moveTo(t,n),this._point=1;break;case 1:this._context.lineTo(t,n);break;default:this._context.moveTo(t+this._radius,n),this._context.arc(t,n,this._radius,0,i.b)}},result:u.a}},function(t,n,r){"use strict";var e=r(60),i=r(13),u=r(255),o=r(123),a=r(256),c=r(257),f=r(259),s=r(260);n.a=function(t,n){function l(t){return t&&("function"==typeof p&&d.pointRadius(+p.apply(this,arguments)),r.i(i.a)(t,h(d))),d.result()}var h,d,p=4.5;return l.area=function(t){return r.i(i.a)(t,h(u.a)),u.a.result()},l.measure=function(t){return r.i(i.a)(t,h(f.a)),f.a.result()},l.bounds=function(t){return r.i(i.a)(t,h(o.a)),o.a.result()},l.centroid=function(t){return r.i(i.a)(t,h(a.a)),a.a.result()},l.projection=function(n){return arguments.length?(h=null==n?(t=null,e.a):(t=n).stream,l):t},l.context=function(t){return arguments.length?(d=null==t?(n=null,new s.a):new c.a(n=t),"function"!=typeof p&&d.pointRadius(p),l):n},l.pointRadius=function(t){return arguments.length?(p="function"==typeof t?t:(d.pointRadius(+t),+t),l):p},l.projection(t).context(n)}},function(t,n,r){"use strict";function e(t,n){p.point=i,o=c=t,a=f=n}function i(t,n){c-=t,f-=n,d.add(r.i(l.n)(c*c+f*f)),c=t,f=n}var u,o,a,c,f,s=r(19),l=r(0),h=r(10),d=r.i(s.a)(),p={point:h.a,lineStart:function(){p.point=e},lineEnd:function(){u&&i(o,a),p.point=h.a},polygonStart:function(){u=!0},polygonEnd:function(){u=null},result:function(){var t=+d;return d.reset(),t}};n.a=p},function(t,n,r){"use strict";function e(){this._string=[]}function i(t){return"m0,"+t+"a"+t+","+t+" 0 1,1 0,"+-2*t+"a"+t+","+t+" 0 1,1 0,"+2*t+"z"}n.a=e,e.prototype={_radius:4.5,_circle:i(4.5),pointRadius:function(t){return(t=+t)!==this._radius&&(this._radius=t,this._circle=null),this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._string.push("Z"),this._point=NaN},point:function(t,n){switch(this._point){case 0:this._string.push("M",t,",",n),this._point=1;break;case 1:this._string.push("L",t,",",n);break;default:null==this._circle&&(this._circle=i(this._radius)),this._string.push("M",t,",",n,this._circle)}},result:function(){if(this._string.length){var t=this._string.join("");return this._string=[],t}return null}}},function(t,n,r){"use strict";function e(t){var n=t.length;return{point:function(r,e){for(var i=-1;++i=.12&&i<.234&&e>=-.425&&e<-.214?v:i>=.166&&i<.234&&e>=-.214&&e<-.115?g:p).invert(t)},t.stream=function(t){return c&&f===t?c:c=e([p.stream(f=t),v.stream(t),g.stream(t)])},t.precision=function(t){return arguments.length?(p.precision(t),v.precision(t),g.precision(t),n()):p.precision()},t.scale=function(n){return arguments.length?(p.scale(n),v.scale(.35*n),g.scale(n),t.translate(p.translate())):p.scale()},t.translate=function(t){if(!arguments.length)return p.translate();var r=p.scale(),e=+t[0],u=+t[1];return s=p.translate(t).clipExtent([[e-.455*r,u-.238*r],[e+.455*r,u+.238*r]]).stream(y),l=v.translate([e-.307*r,u+.201*r]).clipExtent([[e-.425*r+i.o,u+.12*r+i.o],[e-.214*r-i.o,u+.234*r-i.o]]).stream(y),h=g.translate([e-.205*r,u+.212*r]).clipExtent([[e-.214*r+i.o,u+.166*r+i.o],[e-.115*r-i.o,u+.234*r-i.o]]).stream(y),n()},t.fitExtent=function(n,e){return r.i(a.a)(t,n,e)},t.fitSize=function(n,e){return r.i(a.b)(t,n,e)},t.fitWidth=function(n,e){return r.i(a.c)(t,n,e)},t.fitHeight=function(n,e){return r.i(a.d)(t,n,e)},t.scale(1070)}},function(t,n,r){"use strict";var e=r(0),i=r(24),u=r(8);r.d(n,"b",function(){return o});var o=r.i(i.b)(function(t){return r.i(e.n)(2/(1+t))});o.invert=r.i(i.a)(function(t){return 2*r.i(e.f)(t/2)}),n.a=function(){return r.i(u.a)(o).scale(124.75).clipAngle(179.999)}},function(t,n,r){"use strict";var e=r(0),i=r(24),u=r(8);r.d(n,"b",function(){return o});var o=r.i(i.b)(function(t){return(t=r.i(e.s)(t))&&t/r.i(e.d)(t)});o.invert=r.i(i.a)(function(t){return t}),n.a=function(){return r.i(u.a)(o).scale(79.4188).clipAngle(179.999)}},function(t,n,r){"use strict";function e(t){return r.i(u.j)((u.k+t)/2)}function i(t,n){function i(t,n){f>0?n<-u.k+u.o&&(n=-u.k+u.o):n>u.k-u.o&&(n=u.k-u.o);var i=f/r.i(u.r)(e(n),c);return[i*r.i(u.d)(c*t),f-i*r.i(u.c)(c*t)]}var o=r.i(u.c)(t),c=t===n?r.i(u.d)(t):r.i(u.i)(o/r.i(u.c)(n))/r.i(u.i)(e(n)/e(t)),f=o*r.i(u.r)(e(t),c)/c;return c?(i.invert=function(t,n){var e=f-n,i=r.i(u.q)(c)*r.i(u.n)(t*t+e*e);return[r.i(u.e)(t,r.i(u.p)(e))/c*r.i(u.q)(e),2*r.i(u.l)(r.i(u.r)(f/i,1/c))-u.k]},i):a.b}var u=r(0),o=r(61),a=r(64);n.b=i,n.a=function(){return r.i(o.a)(i).scale(109.5).parallels([30,30])}},function(t,n,r){"use strict";function e(t,n){function e(t,n){var e=c-n,u=a*t;return[e*r.i(i.d)(u),c-e*r.i(i.c)(u)]}var u=r.i(i.c)(t),a=t===n?r.i(i.d)(t):(u-r.i(i.c)(n))/(n-t),c=u/a+t;return r.i(i.p)(a)u.o&&--o>0);return[t/(.8707+(a=i*i)*(a*(a*a*a*(.003971-.001529*a)-.013791)-.131979)),i]},n.a=function(){return r.i(i.a)(e).scale(175.295)}},function(t,n,r){"use strict";function e(t,n){return[r.i(i.c)(n)*r.i(i.d)(t),r.i(i.d)(n)]}var i=r(0),u=r(24),o=r(8);n.b=e,e.invert=r.i(u.a)(i.f),n.a=function(){return r.i(o.a)(e).scale(249.5).clipAngle(90+i.o)}},function(t,n,r){"use strict";function e(t){return r.i(a.b)({point:function(n,r){n=t(n,r),this.stream.point(n[0],n[1])}})}function i(t,n){function e(i,u,a,c,s,l,h,d,p,v,g,y,_,b){var m=h-i,x=d-u,w=m*m+x*x;if(w>4*n&&_--){var M=c+v,k=s+g,T=l+y,E=r.i(o.n)(M*M+k*k+T*T),A=r.i(o.f)(T/=E),N=r.i(o.p)(r.i(o.p)(T)-1)n||r.i(o.p)((m*z+x*P)/w-.5)>.3||c*v+s*g+l*y2?t[2]+90:90]):(t=i(),[t[0],t[1],t[2]-90])},i([0,0,90]).scale(159.155)}},function(t,n,r){"use strict";var e=r(276);r.d(n,"a",function(){return e.a});var i=r(66);r.d(n,"b",function(){return i.a});var u=r(288);r.d(n,"c",function(){return u.a});var o=r(130);r.d(n,"d",function(){return o.a});var a=r(129);r.d(n,"e",function(){return a.a});var c=r(289);r.d(n,"f",function(){return c.a});var f=r(290);r.d(n,"g",function(){return f.a});var s=r(291);r.d(n,"h",function(){return s.a});var l=r(293);r.d(n,"i",function(){return l.a});var h=r(292);r.d(n,"j",function(){return h.a});var d=r(25);r.d(n,"k",function(){return d.a});var p=r(37);r.d(n,"l",function(){return p.a});var v=r(295);r.d(n,"m",function(){return v.a});var g=r(67);r.d(n,"n",function(){return g.a});var y=r(294);r.d(n,"o",function(){return y.a})},function(t,n,r){"use strict";function e(t){for(var n,r,e=t.length;e;)r=Math.random()*e--|0,n=t[e],t[e]=t[r],t[r]=n;return t}r.d(n,"b",function(){return i}),n.a=e;var i=Array.prototype.slice},function(t,n,r){"use strict";function e(t,n){return t.parent===n.parent?1:2}function i(t){return t.reduce(u,0)/t.length}function u(t,n){return t+n.x}function o(t){return 1+t.reduce(a,0)}function a(t,n){return Math.max(t,n.y)}function c(t){for(var n;n=t.children;)t=n[0];return t}function f(t){for(var n;n=t.children;)t=n[n.length-1];return t}n.a=function(){function t(t){var e,s=0;t.eachAfter(function(t){var r=t.children;r?(t.x=i(r),t.y=o(r)):(t.x=e?s+=n(t,e):0,t.y=0,e=t)});var l=c(t),h=f(t),d=l.x-n(l,h)/2,p=h.x+n(h,l)/2;return t.eachAfter(a?function(n){n.x=(n.x-t.x)*r,n.y=(t.y-n.y)*u}:function(n){n.x=(n.x-d)/(p-d)*r,n.y=(1-(t.y?n.y/t.y:1))*u})}var n=e,r=1,u=1,a=!1;return t.separation=function(r){return arguments.length?(n=r,t):n},t.size=function(n){return arguments.length?(a=!1,r=+n[0],u=+n[1],t):a?null:[r,u]},t.nodeSize=function(n){return arguments.length?(a=!0,r=+n[0],u=+n[1],t):a?[r,u]:null},t}},function(t,n,r){"use strict";n.a=function(){for(var t=this,n=[t];t=t.parent;)n.push(t);return n}},function(t,n,r){"use strict";function e(t){var n=0,r=t.children,e=r&&r.length;if(e)for(;--e>=0;)n+=r[e].value;else n=1;t.value=n}n.a=function(){return this.eachAfter(e)}},function(t,n,r){"use strict";n.a=function(){var t=[];return this.each(function(n){t.push(n)}),t}},function(t,n,r){"use strict";n.a=function(t){var n,r,e,i,u=this,o=[u];do{for(n=o.reverse(),o=[];u=n.pop();)if(t(u),r=u.children)for(e=0,i=r.length;e=0;--r)i.push(n[r]);return this}},function(t,n,r){"use strict";n.a=function(){var t=[];return this.eachBefore(function(n){n.children||t.push(n)}),t}},function(t,n,r){"use strict";n.a=function(){var t=this,n=[];return t.each(function(r){r!==t&&n.push({source:r.parent,target:r})}),n}},function(t,n,r){"use strict";function e(t,n){if(t===n)return t;var r=t.ancestors(),e=n.ancestors(),i=null;for(t=r.pop(),n=e.pop();t===n;)i=t,t=r.pop(),n=e.pop();return i}n.a=function(t){for(var n=this,r=e(n,t),i=[n];n!==r;)n=n.parent,i.push(n);for(var u=i.length;t!==r;)i.splice(u,0,t),t=t.parent;return i}},function(t,n,r){"use strict";n.a=function(t){return this.eachBefore(function(n){n.children&&n.children.sort(t)})}},function(t,n,r){"use strict";n.a=function(t){return this.eachAfter(function(n){for(var r=+t(n.data)||0,e=n.children,i=e&&e.length;--i>=0;)r+=e[i].value;n.value=r})}},function(t,n,r){"use strict";function e(t){return Math.sqrt(t.value)}function i(t){return function(n){n.children||(n.r=Math.max(0,+t(n)||0))}}function u(t,n){return function(e){if(i=e.children){var i,u,o,c=i.length,f=t(e)*n||0;if(f)for(u=0;u0)throw new Error("cycle");return i}var n=e,s=i;return t.id=function(e){return arguments.length?(n=r.i(u.a)(e),t):n},t.parentId=function(n){return arguments.length?(s=r.i(u.a)(n),t):s},t}},function(t,n,r){"use strict";function e(t,n){return t.parent===n.parent?1:2}function i(t){var n=t.children;return n?n[0]:t.t}function u(t){var n=t.children;return n?n[n.length-1]:t.t}function o(t,n,r){var e=r/(n.i-t.i);n.c-=e,n.s+=r,t.c+=e,n.z+=r,n.m+=r}function a(t){for(var n,r=0,e=0,i=t.children,u=i.length;--u>=0;)n=i[u],n.z+=r,n.m+=r,r+=n.s+(e+=n.c)}function c(t,n,r){return t.a.parent===n.parent?t.a:r}function f(t,n){this._=t,this.parent=null,this.children=null,this.A=null,this.a=this,this.z=0,this.m=0,this.c=0,this.s=0,this.t=null,this.i=n}function s(t){for(var n,r,e,i,u,o=new f(t,0),a=[o];n=a.pop();)if(e=n._.children)for(n.children=new Array(u=e.length),i=u-1;i>=0;--i)a.push(r=n.children[i]=new f(e[i],i)),r.parent=n;return(o.parent=new f(null,0)).children=[o],o}var l=r(66);f.prototype=Object.create(l.b.prototype),n.a=function(){function t(t){var e=s(t);if(e.eachAfter(n),e.parent.m=-e.z,e.eachBefore(r),v)t.eachBefore(l);else{var i=t,u=t,o=t;t.eachBefore(function(t){t.xu.x&&(u=t),t.depth>o.depth&&(o=t)});var a=i===u?1:h(i,u)/2,c=a-i.x,f=d/(u.x+a+c),g=p/(o.depth||1);t.eachBefore(function(t){t.x=(t.x+c)*f,t.y=t.depth*g})}return t}function n(t){var n=t.children,r=t.parent.children,e=t.i?r[t.i-1]:null;if(n){a(t);var i=(n[0].z+n[n.length-1].z)/2;e?(t.z=e.z+h(t._,e._),t.m=t.z-i):t.z=i}else e&&(t.z=e.z+h(t._,e._));t.parent.A=f(t,e,t.parent.A||r[0])}function r(t){t._.x=t.z+t.parent.m,t.m+=t.parent.m}function f(t,n,r){if(n){for(var e,a=t,f=t,s=n,l=a.parent.children[0],d=a.m,p=f.m,v=s.m,g=l.m;s=u(s),a=i(a),s&&a;)l=i(l),f=u(f),f.a=t,e=s.z+v-a.z-d+h(s._,a._),e>0&&(o(c(s,t,r),t,e),d+=e,p+=e),v+=s.m,d+=a.m,g+=l.m,p+=f.m;s&&!u(f)&&(f.t=s,f.m+=v-p),a&&!i(l)&&(l.t=a,l.m+=d-g,r=t)}return r}function l(t){t.x*=d,t.y=t.depth*p}var h=e,d=1,p=1,v=null;return t.separation=function(n){return arguments.length?(h=n,t):h},t.size=function(n){return arguments.length?(v=!1,d=+n[0],p=+n[1],t):v?null:[d,p]},t.nodeSize=function(n){return arguments.length?(v=!0,d=+n[0],p=+n[1],t):v?[d,p]:null},t}},function(t,n,r){"use strict";n.a=function(t,n,r,e,i){function u(t,n,r,e,i,o,a){if(t>=n-1){var f=c[t];return f.x0=e,f.y0=i,f.x1=o,f.y1=a,void 0}for(var l=s[t],h=r/2+l,d=t+1,p=n-1;d>>1;s[v]a-i){var _=(e*y+o*g)/r;u(t,d,g,e,i,_,a),u(d,n,y,_,i,o,a)}else{var b=(i*y+a*g)/r;u(t,d,g,e,i,o,b),u(d,n,y,e,b,o,a)}}var o,a,c=t.children,f=c.length,s=new Array(f+1);for(s[0]=a=o=0;o1?n:1)},o}(u.c)},function(t,n,r){"use strict";var e=r(25),i=r(37);n.a=function(t,n,r,u,o){(1&t.depth?i.a:e.a)(t,n,r,u,o)}},function(t,n,r){"use strict";function e(t){return function n(e){function o(n,o){var a=t((n=r.i(i.f)(n)).h,(o=r.i(i.f)(o)).h),c=r.i(u.a)(n.s,o.s),f=r.i(u.a)(n.l,o.l),s=r.i(u.a)(n.opacity,o.opacity);return function(t){return n.h=a(t),n.s=c(t),n.l=f(Math.pow(t,e)),n.opacity=s(t),n+""}}return e=+e,o.gamma=n,o}(1)}var i=r(7),u=r(26);r.d(n,"b",function(){return o}),n.a=e(u.b);var o=e(u.a)},function(t,n,r){"use strict";function e(t){return function(n,e){var o=t((n=r.i(i.e)(n)).h,(e=r.i(i.e)(e)).h),a=r.i(u.a)(n.c,e.c),c=r.i(u.a)(n.l,e.l),f=r.i(u.a)(n.opacity,e.opacity);return function(t){return n.h=o(t),n.c=a(t),n.l=c(t),n.opacity=f(t),n+""}}}var i=r(7),u=r(26);r.d(n,"b",function(){return o}),n.a=e(u.b);var o=e(u.a)},function(t,n,r){"use strict";function e(t){return function(n,e){var o=t((n=r.i(i.c)(n)).h,(e=r.i(i.c)(e)).h),a=r.i(u.a)(n.s,e.s),c=r.i(u.a)(n.l,e.l),f=r.i(u.a)(n.opacity,e.opacity);return function(t){return n.h=o(t),n.s=a(t),n.l=c(t),n.opacity=f(t),n+""}}}var i=r(7),u=r(26);r.d(n,"b",function(){return o}),n.a=e(u.b);var o=e(u.a)},function(t,n,r){"use strict";function e(t,n){var e=r.i(u.a)((t=r.i(i.d)(t)).l,(n=r.i(i.d)(n)).l),o=r.i(u.a)(t.a,n.a),a=r.i(u.a)(t.b,n.b),c=r.i(u.a)(t.opacity,n.opacity);return function(n){return t.l=e(n),t.a=o(n),t.b=a(n),t.opacity=c(n),t+""}}var i=r(7),u=r(26);n.a=e},function(t,n,r){"use strict";n.a=function(t,n){for(var r=new Array(n),e=0;e180?n+=360:n-t>180&&(t+=360),a.push({i:e.push(o(e)+"rotate(",null,u)-2,x:r.i(i.a)(t,n)})):n&&e.push(o(e)+"rotate("+n+u)}function f(t,n,e,a){t!==n?a.push({i:e.push(o(e)+"skewX(",null,u)-2,x:r.i(i.a)(t,n)}):n&&e.push(o(e)+"skewX("+n+u)}function s(t,n,e,u,a,c){if(t!==e||n!==u){var f=a.push(o(a)+"scale(",null,",",null,")");c.push({i:f-4,x:r.i(i.a)(t,e)},{i:f-2,x:r.i(i.a)(n,u)})}else 1===e&&1===u||a.push(o(a)+"scale("+e+","+u+")")}return function(n,r){var e=[],i=[];return n=t(n),r=t(r),a(n.translateX,n.translateY,r.translateX,r.translateY,e,i),c(n.rotate,r.rotate,e,i),f(n.skewX,r.skewX,e,i),s(n.scaleX,n.scaleY,r.scaleX,r.scaleY,e,i),n=r=null,function(t){for(var n,r=-1,u=i.length;++ra)if(Math.abs(h*f-s*l)>a&&i){var p=r-o,v=e-c,g=f*f+s*s,y=p*p+v*v,_=Math.sqrt(g),b=Math.sqrt(d),m=i*Math.tan((u-Math.acos((g+d-y)/(2*_*b)))/2),x=m/b,w=m/_;Math.abs(x-1)>a&&(this._+="L"+(t+x*l)+","+(n+x*h)),this._+="A"+i+","+i+",0,0,"+ +(h*p>l*v)+","+(this._x1=t+w*f)+","+(this._y1=n+w*s)}else this._+="L"+(this._x1=t)+","+(this._y1=n);else;},arc:function(t,n,r,e,i,f){t=+t,n=+n,r=+r;var s=r*Math.cos(e),l=r*Math.sin(e),h=t+s,d=n+l,p=1^f,v=f?e-i:i-e;if(r<0)throw new Error("negative radius: "+r);null===this._x1?this._+="M"+h+","+d:(Math.abs(this._x1-h)>a||Math.abs(this._y1-d)>a)&&(this._+="L"+h+","+d),r&&(v<0&&(v=v%o+o),v>c?this._+="A"+r+","+r+",0,1,"+p+","+(t-s)+","+(n-l)+"A"+r+","+r+",0,1,"+p+","+(this._x1=h)+","+(this._y1=d):v>a&&(this._+="A"+r+","+r+",0,"+ +(v>=u)+","+p+","+(this._x1=t+r*Math.cos(i))+","+(this._y1=n+r*Math.sin(i))))},rect:function(t,n,r,e){this._+="M"+(this._x0=this._x1=+t)+","+(this._y0=this._y1=+n)+"h"+ +r+"v"+ +e+"h"+-r+"Z"},toString:function(){return this._}},n.a=i},function(t,n,r){"use strict";var e=r(308);r.d(n,"a",function(){return e.a});var i=r(309);r.d(n,"b",function(){return i.a});var u=r(312);r.d(n,"c",function(){return u.a});var o=r(310);r.d(n,"d",function(){return o.a});var a=r(313);r.d(n,"e",function(){return a.a})},function(t,n,r){"use strict";n.a=function(t){for(var n,r=-1,e=t.length,i=t[e-1],u=0;++ra!=f>a&&o<(c-r)*(a-e)/(f-e)+r&&(s=!s),c=r,f=e;return s}},function(t,n,r){"use strict";n.a=function(t,n,r){return(n[0]-t[0])*(r[1]-t[1])-(n[1]-t[1])*(r[0]-t[0])}},function(t,n,r){"use strict";function e(t,n){return t[0]-n[0]||t[1]-n[1]}function i(t){for(var n=t.length,e=[0,1],i=2,o=2;o1&&r.i(u.a)(t[e[i-2]],t[e[i-1]],t[o])<=0;)--i;e[i++]=o}return e.slice(0,i)}var u=r(311);n.a=function(t){if((r=t.length)<3)return null;var n,r,u=new Array(r),o=new Array(r);for(n=0;n=0;--n)l.push(t[u[a[n]][2]]);for(n=+f;n=(u=(v+y)/2))?v=u:y=u,(s=r>=(o=(g+_)/2))?g=o:_=o,i=d,!(d=d[l=s<<1|f]))return i[l]=p,t;if(a=+t._x.call(null,d.data),c=+t._y.call(null,d.data),n===a&&r===c)return p.next=d,i?i[l]=p:t._root=p,t;do{i=i?i[l]=new Array(4):t._root=new Array(4),(f=n>=(u=(v+y)/2))?v=u:y=u,(s=r>=(o=(g+_)/2))?g=o:_=o}while((l=s<<1|f)==(h=(c>=o)<<1|a>=u));return i[h]=d,i[l]=p,t}function i(t){var n,r,i,u,o=t.length,a=new Array(o),c=new Array(o),f=1/0,s=1/0,l=-1/0,h=-1/0;for(r=0;rl&&(l=i),uh&&(h=u));for(lt||t>i||e>n||n>u))return this;var o,a,c=i-r,f=this._root;switch(a=(n<(e+u)/2)<<1|t<(r+i)/2){case 0:do{o=new Array(4),o[a]=f,f=o}while(c*=2,i=r+c,u=e+c,t>i||n>u);break;case 1:do{o=new Array(4),o[a]=f,f=o}while(c*=2,r=i-c,u=e+c,r>t||n>u);break;case 2:do{o=new Array(4),o[a]=f,f=o}while(c*=2,i=r+c,e=u-c,t>i||e>n);break;case 3:do{o=new Array(4),o[a]=f,f=o}while(c*=2,r=i-c,e=u-c,r>t||e>n)}this._root&&this._root.length&&(this._root=f)}return this._x0=r,this._y0=e,this._x1=i,this._y1=u,this}},function(t,n,r){"use strict";n.a=function(){var t=[];return this.visit(function(n){if(!n.length)do{t.push(n.data)}while(n=n.next)}),t}},function(t,n,r){"use strict";n.a=function(t){return arguments.length?this.cover(+t[0][0],+t[0][1]).cover(+t[1][0],+t[1][1]):isNaN(this._x0)?void 0:[[this._x0,this._y0],[this._x1,this._y1]]}},function(t,n,r){"use strict";var e=r(71);n.a=function(t,n,r){var i,u,o,a,c,f,s,l=this._x0,h=this._y0,d=this._x1,p=this._y1,v=[],g=this._root;for(g&&v.push(new e.a(g,l,h,d,p)),null==r?r=1/0:(l=t-r,h=n-r,d=t+r,p=n+r,r*=r);f=v.pop();)if(!(!(g=f.node)||(u=f.x0)>d||(o=f.y0)>p||(a=f.x1)=_)<<1|t>=y)&&(f=v[v.length-1],v[v.length-1]=v[v.length-1-s],v[v.length-1-s]=f)}else{var b=t-+this._x.call(null,g.data),m=n-+this._y.call(null,g.data),x=b*b+m*m;if(x=(a=(p+g)/2))?p=a:g=a,(s=o>=(c=(v+y)/2))?v=c:y=c,n=d,!(d=d[l=s<<1|f]))return this;if(!d.length)break;(n[l+1&3]||n[l+2&3]||n[l+3&3])&&(r=n,h=l)}for(;d.data!==t;)if(e=d,!(d=d.next))return this;return(i=d.next)&&delete d.next,e?(i?e.next=i:delete e.next,this):n?(i?n[l]=i:delete n[l],(d=n[0]||n[1]||n[2]||n[3])&&d===(n[3]||n[2]||n[1]||n[0])&&!d.length&&(r?r[h]=d:this._root=d),this):(this._root=i,this)}},function(t,n,r){"use strict";n.a=function(){return this._root}},function(t,n,r){"use strict";n.a=function(){var t=0;return this.visit(function(n){if(!n.length)do{++t}while(n=n.next)}),t}},function(t,n,r){"use strict";var e=r(71);n.a=function(t){var n,r,i,u,o,a,c=[],f=this._root;for(f&&c.push(new e.a(f,this._x0,this._y0,this._x1,this._y1));n=c.pop();)if(!t(f=n.node,i=n.x0,u=n.y0,o=n.x1,a=n.y1)&&f.length){var s=(i+o)/2,l=(u+a)/2;(r=f[3])&&c.push(new e.a(r,s,l,o,a)),(r=f[2])&&c.push(new e.a(r,i,l,s,a)),(r=f[1])&&c.push(new e.a(r,s,u,o,l)),(r=f[0])&&c.push(new e.a(r,i,u,s,l))}return this}},function(t,n,r){"use strict";var e=r(71);n.a=function(t){var n,r=[],i=[];for(this._root&&r.push(new e.a(this._root,this._x0,this._y0,this._x1,this._y1));n=r.pop();){var u=n.node;if(u.length){var o,a=n.x0,c=n.y0,f=n.x1,s=n.y1,l=(a+f)/2,h=(c+s)/2;(o=u[0])&&r.push(new e.a(o,a,c,l,h)),(o=u[1])&&r.push(new e.a(o,l,c,f,h)),(o=u[2])&&r.push(new e.a(o,a,h,l,s)),(o=u[3])&&r.push(new e.a(o,l,h,f,s))}i.push(n)}for(;n=i.pop();)t(n.node,n.x0,n.y0,n.x1,n.y1);return this}},function(t,n,r){"use strict";function e(t){return t[0]}n.a=e,n.b=function(t){return arguments.length?(this._x=t,this):this._x}},function(t,n,r){"use strict";function e(t){return t[1]}n.a=e,n.b=function(t){return arguments.length?(this._y=t,this):this._y}},function(t,n,r){"use strict";var e=r(329);r.d(n,"a",function(){return e.a})},function(t,n,r){"use strict";r.d(n,"a",function(){return e});var e=[].slice},function(t,n,r){"use strict";function e(t){this._size=t,this._call=this._error=null,this._tasks=[],this._data=[],this._waiting=this._active=this._ended=this._start=0}function i(t){if(!t._start)try{u(t)}catch(n){if(t._tasks[t._ended+t._active-1])a(t,n);else if(!t._data)throw n}}function u(t){for(;t._start=t._waiting&&t._active=0;)if((r=t._tasks[e])&&(t._tasks[e]=null,r.abort))try{r.abort()}catch(n){}t._active=NaN,c(t)}function c(t){if(!t._active&&t._call){var n=t._data;t._data=void 0,t._call(t._error,n)}}function f(t){if(null==t)t=1/0;else if(!((t=+t)>=1))throw new Error("invalid concurrency");return new e(t)}var s=r(328);n.a=f;var l={};e.prototype=f.prototype={constructor:e,defer:function(t){if("function"!=typeof t)throw new Error("invalid callback");if(this._call)throw new Error("defer after await");if(null!=this._error)return this;var n=s.a.call(arguments,1);return n.push(t),++this._waiting,this._tasks.push(n),i(this),this},abort:function(){return null==this._error&&a(this,new Error("abort")),this},await:function(t){if("function"!=typeof t)throw new Error("invalid callback");if(this._call)throw new Error("multiple await");return this._call=function(n,r){t.apply(null,[n].concat(r))},c(this),this},awaitAll:function(t){if("function"!=typeof t)throw new Error("invalid callback");if(this._call)throw new Error("multiple await");return this._call=t,c(this),this}}},function(t,n,r){"use strict";var e=r(334);r.d(n,"a",function(){return e.a});var i=r(140);r.d(n,"b",function(){return i.a});var u=r(333);r.d(n,"c",function(){return u.a});var o=r(331);r.d(n,"d",function(){return o.a});var a=r(139);r.d(n,"e",function(){return a.a});var c=r(332);r.d(n,"f",function(){return c.a})},function(t,n,r){"use strict";var e=r(20),i=r(139);n.a=function t(n){function r(t){var r=i.a.source(n)(t);return function(){return r()/t}}return r.source=t,r}(e.a)},function(t,n,r){"use strict";var e=r(20);n.a=function t(n){function r(t){return function(){return-Math.log(1-n())/t}}return r.source=t,r}(e.a)},function(t,n,r){"use strict";var e=r(20),i=r(140);n.a=function t(n){function r(){var t=i.a.source(n).apply(this,arguments);return function(){return Math.exp(t())}}return r.source=t,r}(e.a)},function(t,n,r){"use strict";var e=r(20);n.a=function t(n){function r(t,r){return t=null==t?0:+t,r=null==r?1:+r,1===arguments.length?(r=t,t=0):r-=t,function(){return n()*r+t}}return r.source=t,r}(e.a)},function(t,n,r){"use strict";var e=r(72);r.d(n,"a",function(){return e.a});var i=r(337);r.d(n,"b",function(){return i.a});var u=r(338);r.d(n,"c",function(){return u.a});var o=r(339);r.d(n,"d",function(){return o.a});var a=r(341);r.d(n,"e",function(){return a.a});var c=r(336);r.d(n,"f",function(){return c.a});var f=r(340);r.d(n,"g",function(){return f.a})},function(t,n,r){"use strict";var e=r(55),i=r(141);n.a=r.i(i.a)("text/csv",e.b)},function(t,n,r){"use strict";var e=r(39);n.a=r.i(e.a)("text/html",function(t){return document.createRange().createContextualFragment(t.responseText)})},function(t,n,r){"use strict";var e=r(39);n.a=r.i(e.a)("application/json",function(t){return JSON.parse(t.responseText)})},function(t,n,r){"use strict";var e=r(39);n.a=r.i(e.a)("text/plain",function(t){return t.responseText})},function(t,n,r){"use strict";var e=r(55),i=r(141);n.a=r.i(i.a)("text/tab-separated-values",e.f)},function(t,n,r){"use strict";var e=r(39);n.a=r.i(e.a)("application/xml",function(t){var n=t.responseXML;if(!n)throw new Error("parse error");return n})},function(t,n,r){"use strict";var e=r(343);r.d(n,"a",function(){return e.a}),r.d(n,"b",function(){return e.b});var i=r(349);r.d(n,"c",function(){return i.a});var u=r(28);r.d(n,"d",function(){return u.a});var o=r(350);r.d(n,"e",function(){return o.a});var a=r(144);r.d(n,"f",function(){return a.a}),r.d(n,"g",function(){return a.b});var c=r(351);r.d(n,"h",function(){return c.a}),r.d(n,"i",function(){return c.b});var f=r(352);r.d(n,"j",function(){return f.a});var s=r(353);r.d(n,"k",function(){return s.a});var l=r(356);r.d(n,"l",function(){return l.a});var h=r(145);r.d(n,"m",function(){return h.a});var d=r(358);r.d(n,"n",function(){return d.a});var p=r(344);r.d(n,"o",function(){return p.a});var v=r(346);r.d(n,"p",function(){return v.a});var g=r(347);r.d(n,"q",function(){return g.a});var y=r(345);r.d(n,"r",function(){return y.a});var _=r(348);r.d(n,"s",function(){return _.a});var b=r(354);r.d(n,"t",function(){return b.a}),r.d(n,"u",function(){return b.b}),r.d(n,"v",function(){return b.c});var m=r(359);r.d(n,"w",function(){return m.a}),r.d(n,"x",function(){return m.b}),r.d(n,"y",function(){return m.c}),r.d(n,"z",function(){return m.d});var x=r(355);r.d(n,"A",function(){return x.a})},function(t,n,r){"use strict";function e(){function t(){var t=c().length,e=s[1]0){for(;lo)break;y.push(f)}}else for(;l=1;--c)if(!((f=a*c)o)break;y.push(f)}}else y=r.i(s.z)(l,d,Math.min(d-l,p)).map(g);return n?y.reverse():y},n.tickFormat=function(t,e){if(null==e&&(e=10===h?".0e":","),"function"!=typeof e&&(e=r.i(l.b)(e)),t===1/0)return e;null==t&&(t=10);var i=Math.max(1,h*t/n.ticks().length);return function(t){var n=t/g(Math.round(v(t)));return n*h0?c[n-1]:o[0],n=f?[s[f-1],c]:[s[n-1],s[n]]},t.copy=function(){return e().domain([a,c]).range(l)},r.i(o.b)(t)}var i=r(3),u=r(15),o=r(28);n.a=e},function(t,n,r){"use strict";var e=r(7),i=r(4);r.d(n,"b",function(){return u}),r.d(n,"c",function(){return o});var u=r.i(i.v)(r.i(e.f)(-100,.75,.35),r.i(e.f)(80,1.5,.8)),o=r.i(i.v)(r.i(e.f)(260,.75,.35),r.i(e.f)(80,1.5,.8)),a=r.i(e.f)();n.a=function(t){(t<0||t>1)&&(t-=Math.floor(t));var n=Math.abs(t-.5);return a.h=360*t-100,a.s=1.5-1.5*n,a.l=.8-.9*n,a+""}},function(t,n,r){"use strict";function e(t){function n(n){var r=(n-u)/(o-u);return t(a?Math.max(0,Math.min(1,r)):r)}var u=0,o=1,a=!1;return n.domain=function(t){return arguments.length?(u=+t[0],o=+t[1],n):[u,o]},n.clamp=function(t){return arguments.length?(a=!!t,n):a},n.interpolator=function(r){return arguments.length?(t=r,n):t},n.copy=function(){return e(t).domain([u,o]).clamp(a)},r.i(i.b)(n)}var i=r(28);n.a=e},function(t,n,r){"use strict";function e(){function t(t){if(t<=t)return o[r.i(i.a)(n,t,0,a)]}var n=[.5],o=[0,1],a=1;return t.domain=function(r){return arguments.length?(n=u.b.call(r),a=Math.min(n.length,o.length-1),t):n.slice()},t.range=function(r){return arguments.length?(o=u.b.call(r),a=Math.min(n.length,o.length-1),t):o.slice()},t.invertExtent=function(t){var r=o.indexOf(t);return[n[r-1],n[r]]},t.copy=function(){return e().domain(n).range(o)},t}var i=r(3),u=r(15);n.a=e},function(t,n,r){"use strict";var e=r(3),i=r(58);n.a=function(t,n,u){var o,a=t[0],c=t[t.length-1],f=r.i(e.B)(a,c,null==n?10:n);switch(u=r.i(i.e)(null==u?",f":u),u.type){case"s":var s=Math.max(Math.abs(a),Math.abs(c));return null!=u.precision||isNaN(o=r.i(i.g)(f,s))||(u.precision=o),r.i(i.c)(u,s);case"":case"e":case"g":case"p":case"r":null!=u.precision||isNaN(o=r.i(i.h)(f,Math.max(Math.abs(a),Math.abs(c))))||(u.precision=o-("e"===u.type));break;case"f":case"%":null!=u.precision||isNaN(o=r.i(i.f)(f))||(u.precision=o-2*("%"===u.type))}return r.i(i.b)(u)}},function(t,n,r){"use strict";var e=r(145),i=r(85),u=r(46);n.a=function(){return r.i(e.b)(u._7,u._5,u.P,u.N,u.L,u.J,u.h,u.d,i.d).domain([Date.UTC(2e3,0,1),Date.UTC(2e3,0,2)])}},function(t,n,r){"use strict";function e(t){var n=t.length;return function(r){return t[Math.max(0,Math.min(n-1,Math.floor(r*n)))]}}var i=r(27);r.d(n,"b",function(){return u}),r.d(n,"c",function(){return o}),r.d(n,"d",function(){return a}),n.a=e(r.i(i.a)("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725"));var u=e(r.i(i.a)("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf")),o=e(r.i(i.a)("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4")),a=e(r.i(i.a)("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921"))},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(){return new i}function i(){this._="@"+(++u).toString(36)}n.a=e;var u=0;i.prototype=e.prototype={constructor:i,get:function(t){for(var n=this._;!(n in t);)if(!(t=t.parentNode))return;return t[n]},set:function(t,n){return t[this._]=n},remove:function(t){return this._ in t&&delete t[this._]},toString:function(){return this._}}},function(t,n,r){"use strict";var e=r(79),i=r(41);n.a=function(t){var n=r.i(e.a)();return n.changedTouches&&(n=n.changedTouches[0]),r.i(i.a)(t,n)}},function(t,n,r){"use strict";var e=r(5);n.a=function(t){return"string"==typeof t?new e.b([[document.querySelector(t)]],[document.documentElement]):new e.b([[t]],e.c)}},function(t,n,r){"use strict";var e=r(5);n.a=function(t){return"string"==typeof t?new e.b([document.querySelectorAll(t)],[document.documentElement]):new e.b([null==t?[]:t],e.c)}},function(t,n,r){"use strict";var e=r(74);n.a=function(t){var n="function"==typeof t?t:r.i(e.a)(t);return this.select(function(){return this.appendChild(n.apply(this,arguments))})}},function(t,n,r){"use strict";function e(t){return function(){this.removeAttribute(t)}}function i(t){return function(){this.removeAttributeNS(t.space,t.local)}}function u(t,n){return function(){this.setAttribute(t,n)}}function o(t,n){return function(){this.setAttributeNS(t.space,t.local,n)}}function a(t,n){return function(){var r=n.apply(this,arguments);null==r?this.removeAttribute(t):this.setAttribute(t,r)}}function c(t,n){return function(){var r=n.apply(this,arguments);null==r?this.removeAttributeNS(t.space,t.local):this.setAttributeNS(t.space,t.local,r)}}var f=r(75);n.a=function(t,n){var s=r.i(f.a)(t);if(arguments.length<2){var l=this.node();return s.local?l.getAttributeNS(s.space,s.local):l.getAttribute(s)}return this.each((null==n?s.local?i:e:"function"==typeof n?s.local?c:a:s.local?o:u)(s,n))}},function(t,n,r){"use strict";n.a=function(){var t=arguments[0];return arguments[0]=this,t.apply(null,arguments),this}},function(t,n,r){"use strict";function e(t){return t.trim().split(/^|\s+/)}function i(t){return t.classList||new u(t)}function u(t){this._node=t,this._names=e(t.getAttribute("class")||"")}function o(t,n){for(var r=i(t),e=-1,u=n.length;++e=0&&(this._names.splice(n,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(t){return this._names.indexOf(t)>=0}},n.a=function(t,n){var r=e(t+"");if(arguments.length<2){for(var u=i(this.node()),o=-1,a=r.length;++o=T&&(T=k+1);!(M=x[T])&&++T=0;)(e=i[u])&&(o&&o!==e.nextSibling&&o.parentNode.insertBefore(e,o),o=e);return this}},function(t,n,r){"use strict";function e(t){return function(){delete this[t]}}function i(t,n){return function(){this[t]=n}}function u(t,n){return function(){var r=n.apply(this,arguments);null==r?delete this[t]:this[t]=r}}n.a=function(t,n){return arguments.length>1?this.each((null==n?e:"function"==typeof n?u:i)(t,n)):this.node()[t]}},function(t,n,r){"use strict";function e(){this.nextSibling&&this.parentNode.appendChild(this)}n.a=function(){return this.each(e)}},function(t,n,r){"use strict";function e(){var t=this.parentNode;t&&t.removeChild(this)}n.a=function(){return this.each(e)}},function(t,n,r){"use strict";var e=r(5),i=r(78);n.a=function(t){"function"!=typeof t&&(t=r.i(i.a)(t));for(var n=this._groups,u=n.length,o=new Array(u),a=0;an?1:t>=n?0:NaN}var i=r(5);n.a=function(t){function n(n,r){return n&&r?t(n.__data__,r.__data__):!n-!r}t||(t=e);for(var r=this._groups,u=r.length,o=new Array(u),a=0;az*z+P*P&&(E=N,A=S),{cx:E,cy:A,x01:-l,y01:-d,x11:E*(u/M-1),y11:A*(u/M-1)}}var s=r(14),l=r(16),h=r(29);n.a=function(){function t(){var t,e,i=+n.apply(this,arguments),u=+d.apply(this,arguments),o=g.apply(this,arguments)-h.f,a=y.apply(this,arguments)-h.f,l=r.i(h.g)(a-o),m=a>o;if(b||(b=t=r.i(s.a)()),uh.a)if(l>h.c-h.a)b.moveTo(u*r.i(h.h)(o),u*r.i(h.i)(o)),b.arc(0,0,u,o,a,!m),i>h.a&&(b.moveTo(i*r.i(h.h)(a),i*r.i(h.i)(a)),b.arc(0,0,i,a,o,m));else{var x,w,M=o,k=a,T=o,E=a,A=l,N=l,S=_.apply(this,arguments)/2,C=S>h.a&&(v?+v.apply(this,arguments):r.i(h.d)(i*i+u*u)),q=r.i(h.j)(r.i(h.g)(u-i)/2,+p.apply(this,arguments)),z=q,P=q;if(C>h.a){var L=r.i(h.k)(C/i*r.i(h.i)(S)),D=r.i(h.k)(C/u*r.i(h.i)(S));(A-=2*L)>h.a?(L*=m?1:-1,T+=L,E-=L):(A=0,T=E=(o+a)/2),(N-=2*D)>h.a?(D*=m?1:-1,M+=D,k-=D):(N=0,M=k=(o+a)/2)}var R=u*r.i(h.h)(M),U=u*r.i(h.i)(M),O=i*r.i(h.h)(E),j=i*r.i(h.i)(E);if(q>h.a){var I=u*r.i(h.h)(k),F=u*r.i(h.i)(k),Y=i*r.i(h.h)(T),B=i*r.i(h.i)(T);if(lh.a?c(R,U,Y,B,I,F,O,j):[O,j],X=R-H[0],V=U-H[1],G=I-H[0],W=F-H[1],Z=1/r.i(h.i)(r.i(h.l)((X*G+V*W)/(r.i(h.d)(X*X+V*V)*r.i(h.d)(G*G+W*W)))/2),$=r.i(h.d)(H[0]*H[0]+H[1]*H[1]);z=r.i(h.j)(q,(i-$)/(Z-1)),P=r.i(h.j)(q,(u-$)/(Z+1))}}N>h.a?P>h.a?(x=f(Y,B,R,U,u,P,m),w=f(I,F,O,j,u,P,m),b.moveTo(x.cx+x.x01,x.cy+x.y01),Ph.a&&A>h.a?z>h.a?(x=f(O,j,I,F,i,-z,m),w=f(R,U,Y,B,i,-z,m),b.lineTo(x.cx+x.x01,x.cy+x.y01),z0)for(var e,i=t[0],u=n[0],o=t[r]-i,a=n[r]-u,c=-1;++c<=r;)e=c/r,this._basis.point(this._beta*t[c]+(1-this._beta)*(i+e*o),this._beta*n[c]+(1-this._beta)*(u+e*a));this._x=this._y=null,this._basis.lineEnd()},point:function(t,n){this._x.push(+t),this._y.push(+n)}},n.a=function t(n){function r(t){return 1===n?new i.b(t):new e(t,n)}return r.beta=function(n){return t(+n)},r}(.85)},function(t,n,r){"use strict";function e(t,n){this._context=t,this._alpha=n}var i=r(153),u=r(45),o=r(81);e.prototype={areaStart:u.a,areaEnd:u.a,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x3,this._y3),this._context.closePath();break;case 2:this._context.lineTo(this._x3,this._y3),this._context.closePath();break;case 3:this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5)}},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,i=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+i*i,this._alpha))}switch(this._point){case 0:this._point=1,this._x3=t,this._y3=n;break;case 1:this._point=2,this._context.moveTo(this._x4=t,this._y4=n);break;case 2:this._point=3,this._x5=t,this._y5=n;break;default:r.i(o.b)(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return n?new e(t,n):new i.b(t,0)}return r.alpha=function(n){return t(+n)},r}(.5)},function(t,n,r){"use strict";function e(t,n){this._context=t,this._alpha=n}var i=r(154),u=r(81);e.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,i=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+i*i,this._alpha))}switch(this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:r.i(u.b)(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return n?new e(t,n):new i.b(t,0)}return r.alpha=function(n){return t(+n)},r}(.5)},function(t,n,r){"use strict";function e(t){this._context=t}var i=r(45);e.prototype={areaStart:i.a,areaEnd:i.a,lineStart:function(){this._point=0},lineEnd:function(){this._point&&this._context.closePath()},point:function(t,n){t=+t,n=+n,this._point?this._context.lineTo(t,n):(this._point=1,this._context.moveTo(t,n))}},n.a=function(t){return new e(t)}},function(t,n,r){"use strict";function e(t){return t<0?-1:1}function i(t,n,r){var i=t._x1-t._x0,u=n-t._x1,o=(t._y1-t._y0)/(i||u<0&&-0),a=(r-t._y1)/(u||i<0&&-0),c=(o*u+a*i)/(i+u);return(e(o)+e(a))*Math.min(Math.abs(o),Math.abs(a),.5*Math.abs(c))||0}function u(t,n){var r=t._x1-t._x0;return r?(3*(t._y1-t._y0)/r-n)/2:n}function o(t,n,r){var e=t._x0,i=t._y0,u=t._x1,o=t._y1,a=(u-e)/3;t._context.bezierCurveTo(e+a,i+a*n,u-a,o-a*r,u,o)}function a(t){this._context=t}function c(t){this._context=new f(t)}function f(t){this._context=t}function s(t){return new a(t)}function l(t){return new c(t)}n.a=s,n.b=l,a.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=this._t0=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x1,this._y1);break;case 3:o(this,this._t0,u(this,this._t0))}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){var r=NaN;if(t=+t,n=+n,t!==this._x1||n!==this._y1){switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3,o(this,u(this,r=i(this,t,n)),r);break;default:o(this,this._t0,r=i(this,t,n))}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n,this._t0=r}}},(c.prototype=Object.create(a.prototype)).point=function(t,n){a.prototype.point.call(this,n,t)},f.prototype={moveTo:function(t,n){this._context.moveTo(n,t)},closePath:function(){this._context.closePath()},lineTo:function(t,n){this._context.lineTo(n,t)},bezierCurveTo:function(t,n,r,e,i,u){this._context.bezierCurveTo(n,t,e,r,u,i)}}},function(t,n,r){"use strict";function e(t){this._context=t}function i(t){var n,r,e=t.length-1,i=new Array(e),u=new Array(e),o=new Array(e);for(i[0]=0,u[0]=2,o[0]=t[0]+2*t[1],n=1;n=0;--n)i[n]=(o[n]-i[n+1])/u[n];for(u[e-1]=(t[e]+i[e-1])/2,n=0;n=0&&(this._t=1-this._t,this._line=1-this._line)},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;default:if(this._t<=0)this._context.lineTo(this._x,n),this._context.lineTo(t,n);else{var r=this._x*(1-this._t)+t*this._t;this._context.lineTo(r,this._y),this._context.lineTo(r,n)}}this._x=t,this._y=n}},n.a=function(t){return new e(t,.5)}},function(t,n,r){"use strict";n.a=function(t,n){return nt?1:n>=t?0:NaN}},function(t,n,r){"use strict";n.a=function(t){return t}},function(t,n,r){"use strict";function e(t){return t.source}function i(t){return t.target}function u(t){function n(){var n,e=d.a.call(arguments),i=u.apply(this,e),s=o.apply(this,e);if(f||(f=n=r.i(h.a)()),t(f,+a.apply(this,(e[0]=i,e)),+c.apply(this,e),+a.apply(this,(e[0]=s,e)),+c.apply(this,e)),n)return f=null,n+""||null}var u=e,o=i,a=v.a,c=v.b,f=null;return n.source=function(t){return arguments.length?(u=t,n):u},n.target=function(t){return arguments.length?(o=t,n):o},n.x=function(t){return arguments.length?(a="function"==typeof t?t:r.i(p.a)(+t),n):a},n.y=function(t){return arguments.length?(c="function"==typeof t?t:r.i(p.a)(+t),n):c},n.context=function(t){return arguments.length?(f=null==t?null:t,n):f},n}function o(t,n,r,e,i){t.moveTo(n,r),t.bezierCurveTo(n=(n+e)/2,r,n,i,e,i)}function a(t,n,r,e,i){t.moveTo(n,r),t.bezierCurveTo(n,r=(r+i)/2,e,r,e,i)}function c(t,n,e,i,u){var o=r.i(g.a)(n,e),a=r.i(g.a)(n,e=(e+u)/2),c=r.i(g.a)(i,e),f=r.i(g.a)(i,u);t.moveTo(o[0],o[1]),t.bezierCurveTo(a[0],a[1],c[0],c[1],f[0],f[1])}function f(){return u(o)}function s(){return u(a)}function l(){var t=u(c);return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t}var h=r(14),d=r(152),p=r(16),v=r(84),g=r(157);n.a=f,n.b=s,n.c=l},function(t,n,r){"use strict";n.a=function(t,n){if((a=t.length)>1)for(var r,e,i,u,o,a,c=0,f=t[n[0]].length;c=0?(e[0]=u,e[1]=u+=i):i<0?(e[1]=o,e[0]=o+=i):e[0]=u}},function(t,n,r){"use strict";var e=r(30);n.a=function(t,n){if((u=t.length)>0){for(var i,u,o,a=0,c=t[0].length;a0){for(var i,u=0,o=t[n[0]],a=o.length;u0&&(u=(i=t[n[0]]).length)>0){for(var i,u,o,a=0,c=1;c0&&(p+=h);for(null!=a?v.sort(function(t,n){return a(g[t],g[n])}):null!=c&&v.sort(function(n,r){return c(t[n],t[r])}),r=0,i=p?(_-d*m)/p:0;r0?h*i:0)+m,g[e]={data:t[e],index:r,value:h,startAngle:y,endAngle:u,padAngle:b};return g}var n=u.a,a=i.a,c=null,f=r.i(e.a)(0),s=r.i(e.a)(o.c),l=r.i(e.a)(0);return t.value=function(i){return arguments.length?(n="function"==typeof i?i:r.i(e.a)(+i),t):n},t.sortValues=function(n){return arguments.length?(a=n,c=null,t):a},t.sort=function(n){return arguments.length?(c=n,a=null,t):c},t.startAngle=function(n){return arguments.length?(f="function"==typeof n?n:r.i(e.a)(+n),t):f},t.endAngle=function(n){return arguments.length?(s="function"==typeof n?n:r.i(e.a)(+n),t):s},t.padAngle=function(n){return arguments.length?(l="function"==typeof n?n:r.i(e.a)(+n),t):l},t}},function(t,n,r){"use strict";function e(t,n){return t[n]}var i=r(152),u=r(16),o=r(30),a=r(31);n.a=function(){function t(t){var r,e,i=n.apply(this,arguments),u=t.length,o=i.length,a=new Array(o);for(r=0;r0?t>1?r.i(e.a)(function(n){n.setTime(Math.floor(n/t)*t)},function(n,r){n.setTime(+n+r*t)},function(n,r){return(r-n)/t}):i:null},n.a=i;var u=i.range},function(t,n,r){"use strict";var e=r(2),i=r(9);r.d(n,"b",function(){return o});var u=r.i(e.a)(function(t){t.setTime(Math.floor(t/i.d)*i.d)},function(t,n){t.setTime(+t+n*i.d)},function(t,n){return(n-t)/i.d},function(t){return t.getMinutes()});n.a=u;var o=u.range},function(t,n,r){"use strict";var e=r(2);r.d(n,"b",function(){return u});var i=r.i(e.a)(function(t){t.setDate(1),t.setHours(0,0,0,0)},function(t,n){t.setMonth(t.getMonth()+n)},function(t,n){return n.getMonth()-t.getMonth()+12*(n.getFullYear()-t.getFullYear())},function(t){return t.getMonth()});n.a=i;var u=i.range},function(t,n,r){"use strict";var e=r(2),i=r(9);r.d(n,"b",function(){return o});var u=r.i(e.a)(function(t){t.setTime(Math.floor(t/i.e)*i.e)},function(t,n){t.setTime(+t+n*i.e)},function(t,n){return(n-t)/i.e},function(t){return t.getUTCSeconds()});n.a=u;var o=u.range},function(t,n,r){"use strict";var e=r(2),i=r(9);r.d(n,"b",function(){return o});var u=r.i(e.a)(function(t){t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+n)},function(t,n){return(n-t)/i.b},function(t){return t.getUTCDate()-1});n.a=u;var o=u.range},function(t,n,r){"use strict";var e=r(2),i=r(9);r.d(n,"b",function(){return o});var u=r.i(e.a)(function(t){t.setUTCMinutes(0,0,0)},function(t,n){t.setTime(+t+n*i.c)},function(t,n){return(n-t)/i.c},function(t){return t.getUTCHours()});n.a=u;var o=u.range},function(t,n,r){"use strict";var e=r(2),i=r(9);r.d(n,"b",function(){return o});var u=r.i(e.a)(function(t){t.setUTCSeconds(0,0)},function(t,n){t.setTime(+t+n*i.d)},function(t,n){return(n-t)/i.d},function(t){return t.getUTCMinutes()});n.a=u;var o=u.range},function(t,n,r){"use strict";var e=r(2);r.d(n,"b",function(){return u});var i=r.i(e.a)(function(t){t.setUTCDate(1),t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCMonth(t.getUTCMonth()+n)},function(t,n){return n.getUTCMonth()-t.getUTCMonth()+12*(n.getUTCFullYear()-t.getUTCFullYear())},function(t){return t.getUTCMonth()});n.a=i;var u=i.range},function(t,n,r){"use strict";function e(t){return r.i(i.a)(function(n){n.setUTCDate(n.getUTCDate()-(n.getUTCDay()+7-t)%7),n.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+7*n)},function(t,n){return(n-t)/u.a})}var i=r(2),u=r(9);r.d(n,"a",function(){return o}),r.d(n,"c",function(){return a}),r.d(n,"e",function(){return c}),r.d(n,"g",function(){return f}),r.d(n,"i",function(){return s}),r.d(n,"k",function(){return l}),r.d(n,"m",function(){return h}),r.d(n,"b",function(){return d}),r.d(n,"d",function(){return p}),r.d(n,"f",function(){return v}),r.d(n,"h",function(){return g}),r.d(n,"j",function(){return y}),r.d(n,"l",function(){return _}),r.d(n,"n",function(){return b});var o=e(0),a=e(1),c=e(2),f=e(3),s=e(4),l=e(5),h=e(6),d=o.range,p=a.range,v=c.range,g=f.range,y=s.range,_=l.range,b=h.range},function(t,n,r){"use strict";var e=r(2);r.d(n,"b",function(){return u});var i=r.i(e.a)(function(t){t.setUTCMonth(0,1),t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCFullYear(t.getUTCFullYear()+n)},function(t,n){return n.getUTCFullYear()-t.getUTCFullYear()},function(t){return t.getUTCFullYear()});i.every=function(t){return isFinite(t=Math.floor(t))&&t>0?r.i(e.a)(function(n){n.setUTCFullYear(Math.floor(n.getUTCFullYear()/t)*t),n.setUTCMonth(0,1),n.setUTCHours(0,0,0,0)},function(n,r){n.setUTCFullYear(n.getUTCFullYear()+r*t)}):null},n.a=i;var u=i.range},function(t,n,r){"use strict";function e(t){return r.i(i.a)(function(n){n.setDate(n.getDate()-(n.getDay()+7-t)%7),n.setHours(0,0,0,0)},function(t,n){t.setDate(t.getDate()+7*n)},function(t,n){return(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*u.d)/u.a})}var i=r(2),u=r(9);r.d(n,"a",function(){return o}),r.d(n,"c",function(){return a}),r.d(n,"e",function(){return c}),r.d(n,"g",function(){return f}),r.d(n,"i",function(){return s}),r.d(n,"k",function(){return l}),r.d(n,"m",function(){return h}),r.d(n,"b",function(){return d}),r.d(n,"d",function(){return p}),r.d(n,"f",function(){return v}),r.d(n,"h",function(){return g}),r.d(n,"j",function(){return y}),r.d(n,"l",function(){return _}),r.d(n,"n",function(){return b});var o=e(0),a=e(1),c=e(2),f=e(3),s=e(4),l=e(5),h=e(6),d=o.range,p=a.range,v=c.range,g=f.range,y=s.range,_=l.range,b=h.range},function(t,n,r){"use strict";var e=r(2);r.d(n,"b",function(){return u});var i=r.i(e.a)(function(t){t.setMonth(0,1),t.setHours(0,0,0,0)},function(t,n){t.setFullYear(t.getFullYear()+n)},function(t,n){return n.getFullYear()-t.getFullYear()},function(t){return t.getFullYear()});i.every=function(t){return isFinite(t=Math.floor(t))&&t>0?r.i(e.a)(function(n){n.setFullYear(Math.floor(n.getFullYear()/t)*t),n.setMonth(0,1),n.setHours(0,0,0,0)},function(n,r){n.setFullYear(n.getFullYear()+r*t)}):null},n.a=i;var u=i.range},function(t,n,r){"use strict";var e=r(87);n.a=function(t,n,i){var u=new e.d,o=n;return null==n?(u.restart(t,n,i),u):(n=+n,i=null==i?r.i(e.a)():+i,u.restart(function r(e){e+=o,u.restart(r,o+=n,i),t(e)},n,i),u)}},function(t,n,r){"use strict";var e=r(87);n.a=function(t,n,r){var i=new e.d;return n=null==n?0:+n,i.restart(function(r){i.stop(),t(r+n)},n,r),i}},function(t,n,r){"use strict";var e=r(11),i=r(6),u=[null];n.a=function(t,n){var r,o,a=t.__transition;if(a){n=null==n?null:n+"";for(o in a)if((r=a[o]).state>i.d&&r.name===n)return new e.b([[t]],u,n,+o)}return null}},function(t,n,r){"use strict";var e=r(1),i=r(437),u=r(438);e.j.prototype.interrupt=i.a,e.j.prototype.transition=u.a},function(t,n,r){"use strict";var e=r(167);n.a=function(t){return this.each(function(){r.i(e.a)(this,t)})}},function(t,n,r){"use strict";function e(t,n){for(var e;!(e=t.__transition)||!(e=e[n]);)if(!(t=t.parentNode))return c.time=r.i(a.a)(),c;return e}var i=r(11),u=r(6),o=r(107),a=r(47),c={time:null,delay:0,duration:250,ease:o.i};n.a=function(t){var n,o;t instanceof i.b?(n=t._id,t=t._name):(n=r.i(i.c)(),(o=c).time=r.i(a.a)(),t=null==t?null:t+"");for(var f=this._groups,s=f.length,l=0;l=0&&(t=t.slice(0,n)),!t||"start"===t})}function i(t,n,r){var i,o,a=e(n)?u.g:u.e;return function(){var e=a(this,t),u=e.on;u!==i&&(o=(i=u).copy()).on(n,r),e.on=o}}var u=r(6);n.a=function(t,n){var e=this._id;return arguments.length<2?r.i(u.f)(this.node(),e).on.on(t):this.each(i(e,t,n))}},function(t,n,r){"use strict";function e(t){return function(){var n=this.parentNode;for(var r in this.__transition)if(+r!==t)return;n&&n.removeChild(this)}}n.a=function(){return this.on("end.remove",e(this._id))}},function(t,n,r){"use strict";var e=r(1),i=r(11),u=r(6);n.a=function(t){var n=this._name,o=this._id;"function"!=typeof t&&(t=r.i(e.k)(t));for(var a=this._groups,c=a.length,f=new Array(c),s=0;sp.b)v=v.L;else{if(!((o=a-f(v,s))>p.b)){u>-p.b?(n=v.P,e=v):o>-p.b?(n=v,e=v.N):n=e=v;break}if(!v.R){n=v;break}v=v.R}r.i(l.d)(t);var g=i(t);if(p.e.insert(n,g),n||e){if(n===e)return r.i(h.b)(n),e=i(n.site),p.e.insert(g,e),g.edge=e.edge=r.i(d.d)(n.site,g.site),r.i(h.c)(n),void r.i(h.c)(e);if(!e)return void(g.edge=r.i(d.d)(n.site,g.site));r.i(h.b)(n),r.i(h.b)(e);var y=n.site,_=y[0],b=y[1],m=t[0]-_,x=t[1]-b,w=e.site,M=w[0]-_,k=w[1]-b,T=2*(m*k-x*M),E=m*m+x*x,A=M*M+k*k,N=[(k*E-x*A)/T+_,(m*A-M*E)/T+b];r.i(d.c)(e.edge,y,w,N),g.edge=r.i(d.d)(y,t,null,N),e.edge=r.i(d.d)(t,w,null,N),r.i(h.c)(n),r.i(h.c)(e)}}function c(t,n){var r=t.site,e=r[0],i=r[1],u=i-n;if(!u)return e;var o=t.P;if(!o)return-1/0;r=o.site;var a=r[0],c=r[1],f=c-n;if(!f)return a;var s=a-e,l=1/u-1/f,h=s/f;return l?(-h+Math.sqrt(h*h-2*l*(s*s/(-2*f)-c+f/2+i-u/2)))/l+e:(e+a)/2}function f(t,n){var r=t.N;if(r)return c(r,n);var e=t.site;return e[1]===n?e[0]:1/0}var s=r(90),l=r(169),h=r(170),d=r(89),p=r(32);n.b=o,n.a=a;var v=[]},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(t){return t[0]}function i(t){return t[1]}n.a=e,n.b=i},function(t,n,r){"use strict";var e=r(457),i=r(458),u=r(32);n.a=function(){function t(t){return new u.a(t.map(function(r,e){var i=[Math.round(n(r,e,t)/u.b)*u.b,Math.round(o(r,e,t)/u.b)*u.b];return i.index=e,i.data=r,i}),a)}var n=i.a,o=i.b,a=null;return t.polygons=function(n){return t(n).polygons()},t.links=function(n){return t(n).links()},t.triangles=function(n){return t(n).triangles()},t.x=function(i){return arguments.length?(n="function"==typeof i?i:r.i(e.a)(+i),t):n},t.y=function(n){return arguments.length?(o="function"==typeof n?n:r.i(e.a)(+n),t):o},t.extent=function(n){return arguments.length?(a=null==n?null:[[+n[0][0],+n[0][1]],[+n[1][0],+n[1][1]]],t):a&&[[a[0][0],a[0][1]],[a[1][0],a[1][1]]]},t.size=function(n){return arguments.length?(a=null==n?null:[[0,0],[+n[0],+n[1]]],t):a&&[a[1][0]-a[0][0],a[1][1]-a[0][1]]},t}},function(t,n,r){"use strict";var e=r(464);r.d(n,"a",function(){return e.a});var i=r(171);r.d(n,"b",function(){return i.a}),r.d(n,"c",function(){return i.b})},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(t,n,r){this.target=t,this.type=n,this.transform=r}n.a=e},function(t,n,r){"use strict";function e(){i.q.stopImmediatePropagation()}var i=r(1);n.b=e,n.a=function(){i.q.preventDefault(),i.q.stopImmediatePropagation()}},function(t,n,r){"use strict";function e(){return!h.q.button}function i(){var t,n,r=this;return r instanceof SVGElement?(r=r.ownerSVGElement||r,t=r.width.baseVal.value,n=r.height.baseVal.value):(t=r.clientWidth,n=r.clientHeight),[[0,0],[t,n]]}function u(){return this.__zoom||g.b}function o(){return-h.q.deltaY*(h.q.deltaMode?120:1)/500}function a(){return"ontouchstart"in this}function c(t,n,r){var e=t.invertX(n[0][0])-r[0][0],i=t.invertX(n[1][0])-r[1][0],u=t.invertY(n[0][1])-r[0][1],o=t.invertY(n[1][1])-r[1][1];return t.translate(i>e?(e+i)/2:Math.min(0,e)||Math.max(0,i),o>u?(u+o)/2:Math.min(0,u)||Math.max(0,o))}var f=r(12),s=r(54),l=r(4),h=r(1),d=r(88),p=r(461),v=r(462),g=r(171),y=r(463);n.a=function(){function t(t){t.property("__zoom",u).on("wheel.zoom",M).on("mousedown.zoom",k).on("dblclick.zoom",T).filter(D).on("touchstart.zoom",E).on("touchmove.zoom",A).on("touchend.zoom touchcancel.zoom",N).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function n(t,n){return n=Math.max(R[0],Math.min(R[1],n)),n===t.k?t:new g.c(n,t.x,t.y)}function _(t,n,r){var e=n[0]-r[0]*t.k,i=n[1]-r[1]*t.k;return e===t.x&&i===t.y?t:new g.c(t.k,e,i)}function b(t){return[(+t[0][0]+ +t[1][0])/2,(+t[0][1]+ +t[1][1])/2]}function m(t,n,r){t.on("start.zoom",function(){x(this,arguments).start()}).on("interrupt.zoom end.zoom",function(){x(this,arguments).end()}).tween("zoom",function(){var t=this,e=arguments,i=x(t,e),u=z.apply(t,e),o=r||b(u),a=Math.max(u[1][0]-u[0][0],u[1][1]-u[0][1]),c=t.__zoom,f="function"==typeof n?n.apply(t,e):n,s=j(c.invert(o).concat(a/c.k),f.invert(o).concat(a/f.k));return function(t){if(1===t)t=f;else{var n=s(t),r=a/n[2];t=new g.c(r,o[0]-n[0]*r,o[1]-n[1]*r)}i.zoom(null,t)}})}function x(t,n){for(var r,e=0,i=I.length;eH}e.zoom("mouse",P(_(e.that.__zoom,e.mouse[0]=r.i(h.d)(e.that),e.mouse[1]),e.extent,U))}function n(){i.on("mousemove.zoom mouseup.zoom",null),r.i(s.c)(h.q.view,e.moved),r.i(y.a)(),e.end()}if(!C&&q.apply(this,arguments)){var e=x(this,arguments),i=r.i(h.h)(h.q.view).on("mousemove.zoom",t,!0).on("mouseup.zoom",n,!0),u=r.i(h.d)(this),o=h.q.clientX,a=h.q.clientY;r.i(s.b)(h.q.view),r.i(y.b)(),e.mouse=[u,this.__zoom.invert(u)],r.i(d.c)(this),e.start()}}function T(){if(q.apply(this,arguments)){var e=this.__zoom,i=r.i(h.d)(this),u=e.invert(i),o=e.k*(h.q.shiftKey?.5:2),a=P(_(n(e,o),i,u),z.apply(this,arguments),U);r.i(y.a)(),O>0?r.i(h.h)(this).transition().duration(O).call(m,a,i):r.i(h.h)(this).call(t.transform,a)}}function E(){if(q.apply(this,arguments)){var t,n,e,i,u=x(this,arguments),o=h.q.changedTouches,a=o.length;for(r.i(y.b)(),n=0;n1)for(var r=1;r0&&(l=e("port",s.attr("href"))),l||(l="53333");var h=new WebSocket("ws://localhost:"+l);h.onopen=function(t){console.log("Opened: ",t)},h.onclose=function(t){console.log("Closed: ",t),f.forEach(function(t){return t.stop()})},h.onmessage=function(e){var i=JSON.parse(e.data);switch(i.type){case"configure":t(i);break;case"data":r(i);break;case"status":n(i);break;default:console.log("Got unrecognized message type: "+i.type)}}}Object.defineProperty(n,"__esModule",{value:!0});var u=r(172),o=r(173),a=r(174),c=(r(175),r(49));i()}]); +!function(t){function n(e){if(r[e])return r[e].exports;var i=r[e]={i:e,l:!1,exports:{}};return t[e].call(i.exports,i,i.exports,n),i.l=!0,i.exports}var r={};n.m=t,n.c=r,n.i=function(t){return t},n.d=function(t,r,e){n.o(t,r)||Object.defineProperty(t,r,{configurable:!1,enumerable:!0,get:e})},n.n=function(t){var r=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(r,"a",r),r},n.o=function(t,n){return Object.prototype.hasOwnProperty.call(t,n)},n.p="",n(n.s=465)}([function(t,n,r){"use strict";function e(t){return t>1?0:t<-1?c:Math.acos(t)}function i(t){return t>1?f:t<-1?-f:Math.asin(t)}function u(t){return(t=w(t/2))*t}r.d(n,"o",function(){return a}),r.d(n,"w",function(){return o}),r.d(n,"a",function(){return c}),r.d(n,"k",function(){return f}),r.d(n,"v",function(){return s}),r.d(n,"b",function(){return l}),r.d(n,"h",function(){return h}),r.d(n,"g",function(){return d}),r.d(n,"p",function(){return p}),r.d(n,"l",function(){return v}),r.d(n,"e",function(){return g}),r.d(n,"c",function(){return y}),r.d(n,"u",function(){return _}),r.d(n,"m",function(){return b}),r.d(n,"i",function(){return m}),r.d(n,"r",function(){return x}),r.d(n,"d",function(){return w}),r.d(n,"q",function(){return M}),r.d(n,"n",function(){return k}),r.d(n,"j",function(){return T}),n.s=e,n.f=i,n.t=u;var a=1e-6,o=1e-12,c=Math.PI,f=c/2,s=c/4,l=2*c,h=180/c,d=c/180,p=Math.abs,v=Math.atan,g=Math.atan2,y=Math.cos,_=Math.ceil,b=Math.exp,m=(Math.floor,Math.log),x=Math.pow,w=Math.sin,M=Math.sign||function(t){return t>0?1:t<0?-1:0},k=Math.sqrt,T=Math.tan},function(t,n,r){"use strict";var e=r(74);r.d(n,"a",function(){return e.a});var i=r(360);r.d(n,"b",function(){return i.a});var u=r(146);r.d(n,"c",function(){return u.a});var a=r(361);r.d(n,"d",function(){return a.a});var o=r(75);r.d(n,"e",function(){return o.a});var c=r(76);r.d(n,"f",function(){return c.a});var f=r(41);r.d(n,"g",function(){return f.a});var s=r(362);r.d(n,"h",function(){return s.a});var l=r(363);r.d(n,"i",function(){return l.a});var h=r(5);r.d(n,"j",function(){return h.a});var d=r(78);r.d(n,"k",function(){return d.a});var p=r(150);r.d(n,"l",function(){return p.a});var v=r(149);r.d(n,"m",function(){return v.a});var g=r(390);r.d(n,"n",function(){return g.a});var y=r(391);r.d(n,"o",function(){return y.a});var _=r(80);r.d(n,"p",function(){return _.a});var b=r(77);r.d(n,"q",function(){return b.a}),r.d(n,"r",function(){return b.b})},function(t,n,r){"use strict";function e(t,n,r,a){function o(n){return t(n=new Date(+n)),n}return o.floor=o,o.ceil=function(r){return t(r=new Date(r-1)),n(r,1),t(r),r},o.round=function(t){var n=o(t),r=o.ceil(t);return t-n0))return a;do{a.push(u=new Date(+r)),n(r,i),t(r)}while(u=n)for(;t(n),!r(n);)n.setTime(n-1)},function(t,e){if(t>=t)if(e<0)for(;++e<=0;)for(;n(t,-1),!r(t););else for(;--e>=0;)for(;n(t,1),!r(t););})},r&&(o.count=function(n,e){return i.setTime(+n),u.setTime(+e),t(i),t(u),Math.floor(r(i,u))},o.every=function(t){return t=Math.floor(t),isFinite(t)&&t>0?t>1?o.filter(a?function(n){return a(n)%t==0}:function(n){return o.count(0,n)%t==0}):o:null}),o}n.a=e;var i=new Date,u=new Date},function(t,n,r){"use strict";var e=r(92);r.d(n,"a",function(){return e.a}),r.d(n,"b",function(){return e.b}),r.d(n,"c",function(){return e.c});var i=r(17);r.d(n,"d",function(){return i.a});var u=r(93);r.d(n,"e",function(){return u.a});var a=r(176);r.d(n,"f",function(){return a.a});var o=r(177);r.d(n,"g",function(){return o.a});var c=r(94);r.d(n,"h",function(){return c.a});var f=r(95);r.d(n,"i",function(){return f.a});var s=r(178);r.d(n,"j",function(){return s.a});var l=r(188);r.d(n,"k",function(){return l.a});var h=r(189);r.d(n,"l",function(){return h.a});var d=r(99);r.d(n,"m",function(){return d.a});var p=r(180);r.d(n,"n",function(){return p.a});var v=r(181);r.d(n,"o",function(){return v.a});var g=r(182);r.d(n,"p",function(){return g.a});var y=r(183);r.d(n,"q",function(){return y.a});var _=r(96);r.d(n,"r",function(){return _.a});var b=r(97);r.d(n,"s",function(){return b.a});var m=r(184);r.d(n,"t",function(){return m.a});var x=r(50);r.d(n,"u",function(){return x.a});var w=r(98);r.d(n,"v",function(){return w.a});var M=r(185);r.d(n,"w",function(){return M.a});var k=r(186);r.d(n,"x",function(){return k.a});var T=r(187);r.d(n,"y",function(){return T.a});var N=r(100);r.d(n,"z",function(){return N.a}),r.d(n,"A",function(){return N.b}),r.d(n,"B",function(){return N.c});var A=r(101);r.d(n,"C",function(){return A.a});var E=r(102);r.d(n,"D",function(){return E.a});var S=r(190);r.d(n,"E",function(){return S.a})},function(t,n,r){"use strict";var e=r(69);r.d(n,"a",function(){return e.a});var i=r(132);r.d(n,"b",function(){return i.a});var u=r(68);r.d(n,"c",function(){return u.a});var a=r(133);r.d(n,"d",function(){return a.a});var o=r(135);r.d(n,"e",function(){return o.a});var c=r(38);r.d(n,"f",function(){return c.a});var f=r(136);r.d(n,"g",function(){return f.a});var s=r(300);r.d(n,"h",function(){return s.a});var l=r(138);r.d(n,"i",function(){return l.a});var h=r(302);r.d(n,"j",function(){return h.a}),r.d(n,"k",function(){return h.b});var d=r(304);r.d(n,"l",function(){return d.a});var p=r(137);r.d(n,"m",function(){return p.a}),r.d(n,"n",function(){return p.b}),r.d(n,"o",function(){return p.c});var v=r(297);r.d(n,"p",function(){return v.a}),r.d(n,"q",function(){return v.b});var g=r(298);r.d(n,"r",function(){return g.a});var y=r(296);r.d(n,"s",function(){return y.a}),r.d(n,"t",function(){return y.b});var _=r(295);r.d(n,"u",function(){return _.a}),r.d(n,"v",function(){return _.b});var b=r(299);r.d(n,"w",function(){return b.a})},function(t,n,r){"use strict";function e(t,n){this._groups=t,this._parents=n}function i(){return new e([[document.documentElement]],D)}var u=r(385),a=r(386),o=r(374),c=r(368),f=r(147),s=r(373),l=r(378),h=r(381),d=r(388),p=r(366),v=r(380),g=r(379),y=r(387),_=r(372),b=r(371),m=r(365),x=r(149),w=r(382),M=r(367),k=r(389),T=r(375),N=r(383),A=r(377),E=r(364),S=r(376),C=r(384),q=r(369),z=r(77),P=r(370);r.d(n,"c",function(){return D}),n.b=e;var D=[null];e.prototype=i.prototype={constructor:e,select:u.a,selectAll:a.a,filter:o.a,data:c.a,enter:f.a,exit:s.a,merge:l.a,order:h.a,sort:d.a,call:p.a,nodes:v.a,node:g.a,size:y.a,empty:_.a,each:b.a,attr:m.a,style:x.b,property:w.a,classed:M.a,text:k.a,html:T.a,raise:N.a,lower:A.a,append:E.a,insert:S.a,remove:C.a,datum:q.a,on:z.c,dispatch:P.a},n.a=i},function(t,n,r){"use strict";function e(t,n){var r=u(t,n);if(r.state>l)throw new Error("too late; already scheduled");return r}function i(t,n){var r=u(t,n);if(r.state>d)throw new Error("too late; already started");return r}function u(t,n){var r=t.__transition;if(!r||!(r=r[n]))throw new Error("transition not found");return r}function a(t,n,e){function i(t){e.state=h,e.timer.restart(u,e.delay,e.time),e.delay<=t&&u(t-e.delay)}function u(i){var l,g,_,b;if(e.state!==h)return o();for(l in s)if(b=s[l],b.name===e.name){if(b.state===p)return r.i(c.d)(u);b.state===v?(b.state=y,b.timer.stop(),b.on.call("interrupt",t,t.__data__,b.index,b.group),delete s[l]):+l2?t[2]%360*l.g:0,d()):[P*l.h,D*l.h,L*l.h]},n.precision=function(t){return arguments.length?(F=r.i(v.a)(u,I=t*t),y()):r.i(l.n)(I)},n.fitExtent=function(t,e){return r.i(p.a)(n,t,e)},n.fitSize=function(t,e){return r.i(p.b)(n,t,e)},n.fitWidth=function(t,e){return r.i(p.c)(n,t,e)},n.fitHeight=function(t,e){return r.i(p.d)(n,t,e)},function(){return _=t.apply(this,arguments),n.invert=_.invert&&i,d()}}var a=r(115),o=r(117),c=r(34),f=r(120),s=r(60),l=r(0),h=r(35),d=r(36),p=r(63),v=r(270);n.a=i,n.b=u;var g=r.i(d.b)({point:function(t,n){this.stream.point(t*l.g,n*l.g)}})},function(t,n,r){"use strict";r.d(n,"e",function(){return e}),r.d(n,"d",function(){return i}),r.d(n,"c",function(){return u}),r.d(n,"b",function(){return a}),r.d(n,"a",function(){return o});var e=1e3,i=6e4,u=36e5,a=864e5,o=6048e5},function(t,n,r){"use strict";function e(){}n.a=e},function(t,n,r){"use strict";function e(t,n,r,e){this._groups=t,this._parents=n,this._name=r,this._id=e}function i(t){return r.i(a.j)().transition(t)}function u(){return++k}var a=r(1),o=r(438),c=r(439),f=r(440),s=r(441),l=r(442),h=r(443),d=r(444),p=r(445),v=r(446),g=r(447),y=r(448),_=r(449),b=r(450),m=r(451),x=r(452),w=r(453),M=r(48);n.b=e,n.a=i,n.c=u;var k=0,T=a.j.prototype;e.prototype=i.prototype={constructor:e,select:g.a,selectAll:y.a,filter:h.a,merge:d.a,selection:_.a,transition:w.a,call:T.call,nodes:T.nodes,node:T.node,size:T.size,empty:T.empty,each:T.each,on:p.a,attr:o.a,attrTween:c.a,style:b.a,styleTween:m.a,text:x.a,remove:v.a,tween:M.a,delay:f.a,duration:s.a,ease:l.a}},function(t,n,r){"use strict";var e=r(212);r.d(n,"a",function(){return e.a})},function(t,n,r){"use strict";function e(t,n){t&&o.hasOwnProperty(t.type)&&o[t.type](t,n)}function i(t,n,r){var e,i=-1,u=t.length-r;for(n.lineStart();++in?1:t>=n?0:NaN}},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(){this.reset()}function i(t,n,r){var e=t.s=n+r,i=e-n,u=e-i;t.t=n-u+(r-i)}n.a=function(){return new e},e.prototype={constructor:e,reset:function(){this.s=this.t=0},add:function(t){i(u,t,this.t),i(this,u.s,this.s),this.s?this.t+=u.t:this.s=u.t},valueOf:function(){return this.s}};var u=new e},function(t,n,r){"use strict";n.a=function(){return Math.random()}},function(t,n,r){"use strict";n.a=function(t){return null===t?NaN:+t}},function(t,n,r){"use strict";var e=r(207);r.d(n,"a",function(){return e.a});var i=r(208);r.d(n,"b",function(){return i.a});var u=r(51);r.d(n,"c",function(){return u.a});var a=r(206);r.d(n,"d",function(){return a.a});var o=r(209);r.d(n,"e",function(){return o.a});var c=r(205);r.d(n,"f",function(){return c.a})},function(t,n,r){"use strict";function e(t){return[r.i(s.e)(t[1],t[0]),r.i(s.f)(t[2])]}function i(t){var n=t[0],e=t[1],i=r.i(s.c)(e);return[i*r.i(s.c)(n),i*r.i(s.d)(n),r.i(s.d)(e)]}function u(t,n){return t[0]*n[0]+t[1]*n[1]+t[2]*n[2]}function a(t,n){return[t[1]*n[2]-t[2]*n[1],t[2]*n[0]-t[0]*n[2],t[0]*n[1]-t[1]*n[0]]}function o(t,n){t[0]+=n[0],t[1]+=n[1],t[2]+=n[2]}function c(t,n){return[t[0]*n,t[1]*n,t[2]*n]}function f(t){var n=r.i(s.n)(t[0]*t[0]+t[1]*t[1]+t[2]*t[2]);t[0]/=n,t[1]/=n,t[2]/=n}var s=r(0);n.g=e,n.a=i,n.d=u,n.b=a,n.f=o,n.e=c,n.c=f},function(t,n,r){"use strict";function e(t){return function(n,e){var i=r.i(u.c)(n),a=r.i(u.c)(e),o=t(i*a);return[o*a*r.i(u.d)(n),o*r.i(u.d)(e)]}}function i(t){return function(n,e){var i=r.i(u.n)(n*n+e*e),a=t(i),o=r.i(u.d)(a),c=r.i(u.c)(a);return[r.i(u.e)(n*o,i*c),r.i(u.f)(i&&e*o/i)]}}var u=r(0);n.b=e,n.a=i},function(t,n,r){"use strict";n.a=function(t,n,r,e,i){for(var u,a=t.children,o=-1,c=a.length,f=t.value&&(e-n)/t.value;++o180||i<-180?i-360*Math.round(i/360):i):r.i(c.a)(isNaN(t)?n:t)}function a(t){return 1==(t=+t)?o:function(n,e){return e-n?i(n,e,t):r.i(c.a)(isNaN(n)?e:n)}}function o(t,n){var i=n-t;return i?e(t,i):r.i(c.a)(isNaN(t)?n:t)}var c=r(134);n.b=u,n.c=a,n.a=o},function(t,n,r){"use strict";n.a=function(t){return t.match(/.{6}/g).map(function(t){return"#"+t})}},function(t,n,r){"use strict";function e(t){var n=t.domain;return t.ticks=function(t){var e=n();return r.i(u.z)(e[0],e[e.length-1],null==t?10:t)},t.tickFormat=function(t,e){return r.i(c.a)(n(),t,e)},t.nice=function(e){null==e&&(e=10);var i,a=n(),o=0,c=a.length-1,f=a[o],s=a[c];return s0?(f=Math.floor(f/i)*i,s=Math.ceil(s/i)*i,i=r.i(u.A)(f,s,e)):i<0&&(f=Math.ceil(f*i)/i,s=Math.floor(s*i)/i,i=r.i(u.A)(f,s,e)),i>0?(a[o]=Math.floor(f/i)*i,a[c]=Math.ceil(s/i)*i,n(a)):i<0&&(a[o]=Math.ceil(f*i)/i,a[c]=Math.floor(s*i)/i,n(a)),t},t}function i(){var t=r.i(o.a)(o.b,a.f);return t.copy=function(){return r.i(o.c)(t,i())},e(t)}var u=r(3),a=r(4),o=r(40),c=r(356);n.b=e,n.a=i},function(t,n,r){"use strict";function e(t){return t>1?0:t<-1?d:Math.acos(t)}function i(t){return t>=1?p:t<=-1?-p:Math.asin(t)}r.d(n,"g",function(){return u}),r.d(n,"m",function(){return a}),r.d(n,"h",function(){return o}),r.d(n,"e",function(){return c}),r.d(n,"j",function(){return f}),r.d(n,"i",function(){return s}),r.d(n,"d",function(){return l}),r.d(n,"a",function(){return h}),r.d(n,"b",function(){return d}),r.d(n,"f",function(){return p}),r.d(n,"c",function(){return v}),n.l=e,n.k=i;var u=Math.abs,a=Math.atan2,o=Math.cos,c=Math.max,f=Math.min,s=Math.sin,l=Math.sqrt,h=1e-12,d=Math.PI,p=d/2,v=2*d},function(t,n,r){"use strict";n.a=function(t,n){if((i=t.length)>1)for(var r,e,i,u=1,a=t[n[0]],o=a.length;u=0;)r[n]=n;return r}},function(t,n,r){"use strict";function e(t,n,r){return(t[0]-r[0])*(n[1]-t[1])-(t[0]-n[0])*(r[1]-t[1])}function i(t,n){return n[1]-t[1]||n[0]-t[0]}function u(t,n){var e,u,v,g=t.sort(i).pop();for(p=[],h=new Array(t.length),l=new s.a,d=new s.a;;)if(v=c.a,g&&(!v||g[1]=o)return null;var c=t-i.site[0],f=n-i.site[1],s=c*c+f*f;do{i=u.cells[e=a],a=null,i.halfedges.forEach(function(r){var e=u.edges[r],o=e.left;if(o!==i.site&&o||(o=e.right)){var c=t-o[0],f=n-o[1],l=c*c+f*f;l0)do{a.point(0===o||3===o?t:e,o>1?l:n)}while((o=(o+u+4)%4)!==c);else a.point(i[0],i[1])}function p(u,a){return r.i(i.p)(u[0]-t)0?0:3:r.i(i.p)(u[0]-e)0?2:1:r.i(i.p)(u[1]-n)0?1:0:a>0?3:2}function v(t,n){return g(t.x,n.x)}function g(t,n){var r=p(t,1),e=p(n,1);return r!==e?r-e:0===r?n[1]-t[1]:1===r?t[0]-n[0]:2===r?t[1]-n[1]:n[0]-t[0]}return function(i){function p(t,n){h(t,n)&&P.point(t,n)}function g(){for(var n=0,r=0,e=M.length;rl&&(s-i)*(l-u)>(h-u)*(t-i)&&++n:h<=l&&(s-i)*(l-u)<(h-u)*(t-i)&&--n;return n}function y(){P=D,w=[],M=[],z=!0}function _(){var t=g(),n=z&&t,e=(w=r.i(c.q)(w)).length;(n||e)&&(i.polygonStart(),n&&(i.lineStart(),d(null,null,1,i),i.lineEnd()),e&&r.i(o.a)(w,v,t,d,i),i.polygonEnd()),P=i,w=M=k=null}function b(){L.point=x,M&&M.push(k=[]),q=!0,C=!1,E=S=NaN}function m(){w&&(x(T,N),A&&C&&D.rejoin(),w.push(D.result())),L.point=p,C&&P.lineEnd()}function x(i,u){var o=h(i,u);if(M&&k.push([i,u]),q)T=i,N=u,A=o,q=!1,o&&(P.lineStart(),P.point(i,u));else if(o&&C)P.point(i,u);else{var c=[E=Math.max(s,Math.min(f,E)),S=Math.max(s,Math.min(f,S))],d=[i=Math.max(s,Math.min(f,i)),u=Math.max(s,Math.min(f,u))];r.i(a.a)(c,d,t,n,e,l)?(C||(P.lineStart(),P.point(c[0],c[1])),P.point(d[0],d[1]),o||P.lineEnd(),z=!1):o&&(P.lineStart(),P.point(i,u),z=!1)}E=i,S=u,C=o}var w,M,k,T,N,A,E,S,C,q,z,P=i,D=r.i(u.a)(),L={point:p,lineStart:b,lineEnd:m,polygonStart:y,polygonEnd:_};return L}}var i=r(0),u=r(116),a=r(249),o=r(119),c=r(3);n.a=e;var f=1e9,s=-f},function(t,n,r){"use strict";function e(t,n){return[t>f.a?t-f.b:t<-f.a?t+f.b:t,n]}function i(t,n,i){return(t%=f.b)?n||i?r.i(c.a)(a(t),o(n,i)):a(t):n||i?o(n,i):e}function u(t){return function(n,r){return n+=t,[n>f.a?n-f.b:n<-f.a?n+f.b:n,r]}}function a(t){var n=u(t);return n.invert=u(-t),n}function o(t,n){function e(t,n){var e=r.i(f.c)(n),c=r.i(f.c)(t)*e,s=r.i(f.d)(t)*e,l=r.i(f.d)(n),h=l*i+c*u;return[r.i(f.e)(s*a-h*o,c*i-l*u),r.i(f.f)(h*a+s*o)]}var i=r.i(f.c)(t),u=r.i(f.d)(t),a=r.i(f.c)(n),o=r.i(f.d)(n);return e.invert=function(t,n){var e=r.i(f.c)(n),c=r.i(f.c)(t)*e,s=r.i(f.d)(t)*e,l=r.i(f.d)(n),h=l*a-s*o;return[r.i(f.e)(s*a+l*o,c*i+h*u),r.i(f.f)(h*i-c*u)]},e}var c=r(120),f=r(0);n.b=i,e.invert=e,n.a=function(t){function n(n){return n=t(n[0]*f.g,n[1]*f.g),n[0]*=f.h,n[1]*=f.h,n}return t=i(t[0]*f.g,t[1]*f.g,t.length>2?t[2]*f.g:0),n.invert=function(n){return n=t.invert(n[0]*f.g,n[1]*f.g),n[0]*=f.h,n[1]*=f.h,n},n}},function(t,n,r){"use strict";function e(t){return function(n){var r=new i;for(var e in t)r[e]=t[e];return r.stream=n,r}}function i(){}n.b=e,n.a=function(t){return{stream:e(t)}},i.prototype={constructor:i,point:function(t,n){this.stream.point(t,n)},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()}}},function(t,n,r){"use strict";n.a=function(t,n,r,e,i){for(var u,a=t.children,o=-1,c=a.length,f=t.value&&(i-r)/t.value;++o=r?1:e(t)}}}function u(t){return function(n,r){var e=t(n=+n,r=+r);return function(t){return t<=0?n:t>=1?r:e(t)}}}function a(t,n,r,e){var i=t[0],u=t[1],a=n[0],o=n[1];return u2?o:a,s=d=null,c}function c(n){return(s||(s=f(g,y,b?i(t):t,_)))(+n)}var f,s,d,g=v,y=v,_=l.a,b=!1;return c.invert=function(t){return(d||(d=f(y,g,e,b?u(n):n)))(+t)},c.domain=function(t){return arguments.length?(g=h.a.call(t,p.a),r()):g.slice()},c.range=function(t){return arguments.length?(y=h.b.call(t),r()):y.slice()},c.rangeRound=function(t){return y=h.b.call(t),_=l.h,r()},c.clamp=function(t){return arguments.length?(b=!!t,r()):b},c.interpolate=function(t){return arguments.length?(_=t,r()):_},r()}var s=r(3),l=r(4),h=r(15),d=r(73),p=r(143);n.b=e,n.c=c,n.a=f;var v=[0,1]},function(t,n,r){"use strict";n.a=function(t,n){var r=t.ownerSVGElement||t;if(r.createSVGPoint){var e=r.createSVGPoint();return e.x=n.clientX,e.y=n.clientY,e=e.matrixTransform(t.getScreenCTM().inverse()),[e.x,e.y]}var i=t.getBoundingClientRect();return[n.clientX-i.left-t.clientLeft,n.clientY-i.top-t.clientTop]}},function(t,n,r){"use strict";function e(t,n,r){t._context.bezierCurveTo((2*t._x0+t._x1)/3,(2*t._y0+t._y1)/3,(t._x0+2*t._x1)/3,(t._y0+2*t._y1)/3,(t._x0+4*t._x1+n)/6,(t._y0+4*t._y1+r)/6)}function i(t){this._context=t}n.c=e,n.b=i,i.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=NaN,this._point=0},lineEnd:function(){switch(this._point){case 3:e(this,this._x1,this._y1);case 2:this._context.lineTo(this._x1,this._y1)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3,this._context.lineTo((5*this._x0+this._x1)/6,(5*this._y0+this._y1)/6);default:e(this,t,n)}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n}},n.a=function(t){return new i(t)}},function(t,n,r){"use strict";function e(t,n,r){t._context.bezierCurveTo(t._x1+t._k*(t._x2-t._x0),t._y1+t._k*(t._y2-t._y0),t._x2+t._k*(t._x1-n),t._y2+t._k*(t._y1-r),t._x2,t._y2)}function i(t,n){this._context=t,this._k=(1-n)/6}n.c=e,n.b=i,i.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:e(this,this._x1,this._y1)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2,this._x1=t,this._y1=n;break;case 2:this._point=3;default:e(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return new i(t,n)}return r.tension=function(n){return t(+n)},r}(0)},function(t,n,r){"use strict";function e(t){this._context=t}e.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;default:this._context.lineTo(t,n)}}},n.a=function(t){return new e(t)}},function(t,n,r){"use strict";n.a=function(){}},function(t,n,r){"use strict";var e=r(2);r.d(n,"a",function(){return e.a});var i=r(420);r.d(n,"b",function(){return i.a}),r.d(n,"c",function(){return i.b}),r.d(n,"d",function(){return i.a}),r.d(n,"e",function(){return i.b});var u=r(423);r.d(n,"f",function(){return u.a}),r.d(n,"g",function(){return u.b}),r.d(n,"h",function(){return u.a}),r.d(n,"i",function(){return u.b});var a=r(421);r.d(n,"j",function(){return a.a}),r.d(n,"k",function(){return a.b});var o=r(419);r.d(n,"l",function(){return o.a}),r.d(n,"m",function(){return o.b});var c=r(418);r.d(n,"n",function(){return c.a}),r.d(n,"o",function(){return c.b});var f=r(430);r.d(n,"p",function(){return f.a}),r.d(n,"q",function(){return f.b}),r.d(n,"r",function(){return f.a}),r.d(n,"s",function(){return f.b}),r.d(n,"t",function(){return f.c}),r.d(n,"u",function(){return f.d}),r.d(n,"v",function(){return f.e}),r.d(n,"w",function(){return f.f}),r.d(n,"x",function(){return f.g}),r.d(n,"y",function(){return f.h}),r.d(n,"z",function(){return f.i}),r.d(n,"A",function(){return f.j}),r.d(n,"B",function(){return f.k}),r.d(n,"C",function(){return f.l}),r.d(n,"D",function(){return f.m}),r.d(n,"E",function(){return f.n});var s=r(422);r.d(n,"F",function(){return s.a}),r.d(n,"G",function(){return s.b});var l=r(431);r.d(n,"H",function(){return l.a}),r.d(n,"I",function(){return l.b});var h=r(426);r.d(n,"J",function(){return h.a}),r.d(n,"K",function(){return h.b});var d=r(425);r.d(n,"L",function(){return d.a}),r.d(n,"M",function(){return d.b});var p=r(424);r.d(n,"N",function(){return p.a}),r.d(n,"O",function(){return p.b});var v=r(428);r.d(n,"P",function(){return v.a}),r.d(n,"Q",function(){return v.b}),r.d(n,"R",function(){return v.a}),r.d(n,"S",function(){return v.b}),r.d(n,"T",function(){return v.c}),r.d(n,"U",function(){return v.d}),r.d(n,"V",function(){return v.e}),r.d(n,"W",function(){return v.f}),r.d(n,"X",function(){return v.g}),r.d(n,"Y",function(){return v.h}),r.d(n,"Z",function(){return v.i}),r.d(n,"_0",function(){return v.j}),r.d(n,"_1",function(){return v.k}),r.d(n,"_2",function(){return v.l}),r.d(n,"_3",function(){return v.m}),r.d(n,"_4",function(){return v.n});var g=r(427);r.d(n,"_5",function(){return g.a}),r.d(n,"_6",function(){return g.b});var y=r(429);r.d(n,"_7",function(){return y.a}),r.d(n,"_8",function(){return y.b})},function(t,n,r){"use strict";var e=r(87);r.d(n,"a",function(){return e.a}),r.d(n,"b",function(){return e.b}),r.d(n,"c",function(){return e.c});var i=r(433);r.d(n,"d",function(){return i.a});var u=r(432);r.d(n,"e",function(){return u.a})},function(t,n,r){"use strict";function e(t,n){var e,i;return function(){var u=r.i(a.e)(this,t),o=u.tween;if(o!==e){i=e=o;for(var c=0,f=i.length;c=1)return+r(t[i-1],i-1,t);var i,u=(i-1)*n,a=Math.floor(u),o=+r(t[a],a,t);return o+(+r(t[a+1],a+1,t)-o)*(u-a)}}},function(t,n,r){"use strict";function e(){}function i(t,n){var r=new e;if(t instanceof e)t.each(function(t,n){r.set(n,t)});else if(Array.isArray(t)){var i,u=-1,a=t.length;if(null==n)for(;++u>8&15|n>>4&240,n>>4&15|240&n,(15&n)<<4|15&n,1)):(n=w.exec(t))?u(parseInt(n[1],16)):(n=M.exec(t))?new f(n[1],n[2],n[3],1):(n=k.exec(t))?new f(255*n[1]/100,255*n[2]/100,255*n[3]/100,1):(n=T.exec(t))?a(n[1],n[2],n[3],n[4]):(n=N.exec(t))?a(255*n[1]/100,255*n[2]/100,255*n[3]/100,n[4]):(n=A.exec(t))?s(n[1],n[2]/100,n[3]/100,1):(n=E.exec(t))?s(n[1],n[2]/100,n[3]/100,n[4]):S.hasOwnProperty(t)?u(S[t]):"transparent"===t?new f(NaN,NaN,NaN,0):null}function u(t){return new f(t>>16&255,t>>8&255,255&t,1)}function a(t,n,r,e){return e<=0&&(t=n=r=NaN),new f(t,n,r,e)}function o(t){return t instanceof e||(t=i(t)),t?(t=t.rgb(),new f(t.r,t.g,t.b,t.opacity)):new f}function c(t,n,r,e){return 1===arguments.length?o(t):new f(t,n,r,null==e?1:e)}function f(t,n,r,e){this.r=+t,this.g=+n,this.b=+r,this.opacity=+e}function s(t,n,r,e){return e<=0?t=n=r=NaN:r<=0||r>=1?t=n=NaN:n<=0&&(t=NaN),new d(t,n,r,e)}function l(t){if(t instanceof d)return new d(t.h,t.s,t.l,t.opacity);if(t instanceof e||(t=i(t)),!t)return new d;if(t instanceof d)return t;t=t.rgb();var n=t.r/255,r=t.g/255,u=t.b/255,a=Math.min(n,r,u),o=Math.max(n,r,u),c=NaN,f=o-a,s=(o+a)/2;return f?(c=n===o?(r-u)/f+6*(r0&&s<1?0:c,new d(c,f,s,t.opacity)}function h(t,n,r,e){return 1===arguments.length?l(t):new d(t,n,r,null==e?1:e)}function d(t,n,r,e){this.h=+t,this.s=+n,this.l=+r,this.opacity=+e}function p(t,n,r){return 255*(t<60?n+(r-n)*t/60:t<180?r:t<240?n+(r-n)*(240-t)/60:n)}var v=r(53);n.f=e,r.d(n,"h",function(){return g}),r.d(n,"g",function(){return y}),n.a=i,n.e=o,n.b=c,n.d=f,n.c=h;var g=.7,y=1/g,_="\\s*([+-]?\\d+)\\s*",b="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)\\s*",m="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)%\\s*",x=/^#([0-9a-f]{3})$/,w=/^#([0-9a-f]{6})$/,M=new RegExp("^rgb\\("+[_,_,_]+"\\)$"),k=new RegExp("^rgb\\("+[m,m,m]+"\\)$"),T=new RegExp("^rgba\\("+[_,_,_,b]+"\\)$"),N=new RegExp("^rgba\\("+[m,m,m,b]+"\\)$"),A=new RegExp("^hsl\\("+[b,m,m]+"\\)$"),E=new RegExp("^hsla\\("+[b,m,m,b]+"\\)$"),S={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};r.i(v.a)(e,i,{displayable:function(){return this.rgb().displayable()},toString:function(){return this.rgb()+""}}),r.i(v.a)(f,c,r.i(v.b)(e,{brighter:function(t){return t=null==t?y:Math.pow(y,t),new f(this.r*t,this.g*t,this.b*t,this.opacity)},darker:function(t){return t=null==t?g:Math.pow(g,t),new f(this.r*t,this.g*t,this.b*t,this.opacity)},rgb:function(){return this},displayable:function(){return 0<=this.r&&this.r<=255&&0<=this.g&&this.g<=255&&0<=this.b&&this.b<=255&&0<=this.opacity&&this.opacity<=1},toString:function(){var t=this.opacity;return t=isNaN(t)?1:Math.max(0,Math.min(1,t)),(1===t?"rgb(":"rgba(")+Math.max(0,Math.min(255,Math.round(this.r)||0))+", "+Math.max(0,Math.min(255,Math.round(this.g)||0))+", "+Math.max(0,Math.min(255,Math.round(this.b)||0))+(1===t?")":", "+t+")")}})),r.i(v.a)(d,h,r.i(v.b)(e,{brighter:function(t){return t=null==t?y:Math.pow(y,t),new d(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?g:Math.pow(g,t),new d(this.h,this.s,this.l*t,this.opacity)},rgb:function(){var t=this.h%360+360*(this.h<0),n=isNaN(t)||isNaN(this.s)?0:this.s,r=this.l,e=r+(r<.5?r:1-r)*n,i=2*r-e;return new f(p(t>=240?t-240:t+120,i,e),p(t,i,e),p(t<120?t+240:t-120,i,e),this.opacity)},displayable:function(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1}}))},function(t,n,r){"use strict";function e(t,n){var r=Object.create(t.prototype);for(var e in n)r[e]=n[e];return r}n.b=e,n.a=function(t,n,r){t.prototype=n.prototype=r,r.constructor=t}},function(t,n,r){"use strict";var e=r(214);r.d(n,"a",function(){return e.a});var i=r(105);r.d(n,"b",function(){return i.a}),r.d(n,"c",function(){return i.b})},function(t,n,r){"use strict";var e=r(56);r.d(n,"a",function(){return e.a});var i=r(216);r.d(n,"b",function(){return i.a}),r.d(n,"c",function(){return i.b}),r.d(n,"d",function(){return i.c}),r.d(n,"e",function(){return i.d});var u=r(217);r.d(n,"f",function(){return u.a}),r.d(n,"g",function(){return u.b}),r.d(n,"h",function(){return u.c}),r.d(n,"i",function(){return u.d})},function(t,n,r){"use strict";function e(t){return new Function("d","return {"+t.map(function(t,n){return JSON.stringify(t)+": d["+n+"]"}).join(",")+"}")}function i(t,n){var r=e(t);return function(e,i){return n(r(e),i,t)}}function u(t){var n=Object.create(null),r=[];return t.forEach(function(t){for(var e in t)e in n||r.push(n[e]=e)}),r}var a={},o={},c=34,f=10,s=13;n.a=function(t){function n(t,n){var u,a,o=r(t,function(t,r){if(u)return u(t,r-1);a=t,u=n?i(t,n):e(t)});return o.columns=a||[],o}function r(t,n){function r(){if(d)return o;if(p)return p=!1,a;var n,r,e=l;if(t.charCodeAt(e)===c){for(;l++=u?d=!0:(r=t.charCodeAt(l++))===f?p=!0:r===s&&(p=!0,t.charCodeAt(l)===f&&++l),t.slice(e+1,n-1).replace(/""/g,'"')}for(;l1?e[0]+e.slice(2):e,+t.slice(r+1)]}},function(t,n,r){"use strict";n.a=function(t){return t}},function(t,n,r){"use strict";function e(t){var n=0,e=i.a/3,a=r.i(u.b)(t),o=a(n,e);return o.parallels=function(t){return arguments.length?a(n=t[0]*i.g,e=t[1]*i.g):[n*i.h,e*i.h]},o}var i=r(0),u=r(8);n.a=e},function(t,n,r){"use strict";function e(t,n){function e(t,n){var e=r.i(i.n)(c-2*o*r.i(i.d)(n))/o;return[e*r.i(i.d)(t*=o),f-e*r.i(i.c)(t)]}var u=r.i(i.d)(t),o=(u+r.i(i.d)(n))/2;if(r.i(i.p)(o)=0;--a)h.push(e=r.children[a]=new c(i[a])),e.parent=r,e.depth=r.depth+1;return s.eachBefore(o)}function i(){return e(this).eachBefore(a)}function u(t){return t.children}function a(t){t.data=t.data.data}function o(t){var n=0;do{t.height=n}while((t=t.parent)&&t.height<++n)}function c(t){this.data=t,this.depth=this.height=0,this.parent=null}var f=r(277),s=r(279),l=r(281),h=r(280),d=r(286),p=r(285),v=r(284),g=r(276),y=r(278),_=r(282),b=r(283);n.a=e,n.c=o,n.b=c,c.prototype=e.prototype={constructor:c,count:f.a,each:s.a,eachAfter:h.a,eachBefore:l.a,sum:d.a,sort:p.a,path:v.a,ancestors:g.a,descendants:y.a,leaves:_.a,links:b.a,copy:i}},function(t,n,r){"use strict";function e(t,n,e,a,o,c){for(var f,s,l,h,d,p,v,g,y,_,b,m=[],x=n.children,w=0,M=0,k=x.length,T=n.value;wv&&(v=s),b=d*d*_,(g=Math.max(v/b,b/p))>y){d-=s;break}y=g}m.push(f={value:d,dice:l1?n:1)},r}(a)},function(t,n,r){"use strict";function e(t,n,r,e,i){var u=t*t,a=u*t;return((1-3*t+3*u-a)*n+(4-6*u+3*a)*r+(1+3*t+3*u-3*a)*e+a*i)/6}n.b=e,n.a=function(t){var n=t.length-1;return function(r){var i=r<=0?r=0:r>=1?(r=1,n-1):Math.floor(r*n),u=t[i],a=t[i+1],o=i>0?t[i-1]:2*u-a,c=i=200&&r<300||304===r){if(s)try{n=s.call(c,p)}catch(t){return void h.call("error",c,t)}else n=p;h.call("load",c,n)}else h.call("error",c,t)}var c,f,s,l,h=r.i(a.a)("beforesend","progress","load","error"),d=r.i(u.c)(),p=new XMLHttpRequest,v=null,g=null,y=0;if("undefined"==typeof XDomainRequest||"withCredentials"in p||!/^(http(s)?:)?\/\//.test(t)||(p=new XDomainRequest),"onload"in p?p.onload=p.onerror=p.ontimeout=o:p.onreadystatechange=function(t){p.readyState>3&&o(t)},p.onprogress=function(t){h.call("progress",c,t)},c={header:function(t,n){return t=(t+"").toLowerCase(),arguments.length<2?d.get(t):(null==n?d.remove(t):d.set(t,n+""),c)},mimeType:function(t){return arguments.length?(f=null==t?null:t+"",c):f},responseType:function(t){return arguments.length?(l=t,c):l},timeout:function(t){return arguments.length?(y=+t,c):y},user:function(t){return arguments.length<1?v:(v=null==t?null:t+"",c)},password:function(t){return arguments.length<1?g:(g=null==t?null:t+"",c)},response:function(t){return s=t,c},get:function(t,n){return c.send("GET",t,n)},post:function(t,n){return c.send("POST",t,n)},send:function(n,r,i){return p.open(n,t,!0,v,g),null==f||d.has("accept")||d.set("accept",f+",*/*"),p.setRequestHeader&&d.each(function(t,n){p.setRequestHeader(n,t)}),null!=f&&p.overrideMimeType&&p.overrideMimeType(f),null!=l&&(p.responseType=l),y>0&&(p.timeout=y),null==i&&"function"==typeof r&&(i=r,r=null),null!=i&&1===i.length&&(i=e(i)),null!=i&&c.on("error",i).on("load",function(t){i(null,t)}),h.call("beforesend",c,p),p.send(null==r?null:r),c},abort:function(){return p.abort(),c},on:function(){var t=h.on.apply(h,arguments);return t===h?c:t}},null!=n){if("function"!=typeof n)throw new Error("invalid callback: "+n);return c.get(n)}return c}},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(t){return function(){var n=this.ownerDocument,r=this.namespaceURI;return r===a.b&&n.documentElement.namespaceURI===a.b?n.createElement(t):n.createElementNS(r,t)}}function i(t){return function(){return this.ownerDocument.createElementNS(t.space,t.local)}}var u=r(75),a=r(76);n.a=function(t){var n=r.i(u.a)(t);return(n.local?i:e)(n)}},function(t,n,r){"use strict";var e=r(76);n.a=function(t){var n=t+="",r=n.indexOf(":");return r>=0&&"xmlns"!==(n=t.slice(0,r))&&(t=t.slice(r+1)),e.a.hasOwnProperty(n)?{space:e.a[n],local:t}:t}},function(t,n,r){"use strict";r.d(n,"b",function(){return e});var e="http://www.w3.org/1999/xhtml";n.a={svg:"http://www.w3.org/2000/svg",xhtml:e,xlink:"http://www.w3.org/1999/xlink",xml:"http://www.w3.org/XML/1998/namespace",xmlns:"http://www.w3.org/2000/xmlns/"}},function(t,n,r){"use strict";function e(t,n,r){return t=i(t,n,r),function(n){var r=n.relatedTarget;r&&(r===this||8&r.compareDocumentPosition(this))||t.call(this,n)}}function i(t,n,r){return function(e){var i=s;s=e;try{t.call(this,this.__data__,n,r)}finally{s=i}}}function u(t){return t.trim().split(/^|\s+/).map(function(t){var n="",r=t.indexOf(".");return r>=0&&(n=t.slice(r+1),t=t.slice(0,r)),{type:t,name:n}})}function a(t){return function(){var n=this.__on;if(n){for(var r,e=0,i=-1,u=n.length;eu.a){var c=2*t._l01_2a+3*t._l01_a*t._l12_a+t._l12_2a,f=3*t._l01_a*(t._l01_a+t._l12_a);e=(e*c-t._x0*t._l12_2a+t._x2*t._l01_2a)/f,i=(i*c-t._y0*t._l12_2a+t._y2*t._l01_2a)/f}if(t._l23_a>u.a){var s=2*t._l23_2a+3*t._l23_a*t._l12_a+t._l12_2a,l=3*t._l23_a*(t._l23_a+t._l12_a);a=(a*s+t._x1*t._l23_2a-n*t._l12_2a)/l,o=(o*s+t._y1*t._l23_2a-r*t._l12_2a)/l}t._context.bezierCurveTo(e,i,a,o,t._x2,t._y2)}function i(t,n){this._context=t,this._alpha=n}var u=r(29),a=r(43);n.b=e,i.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x2,this._y2);break;case 3:this.point(this._x2,this._y2)}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){if(t=+t,n=+n,this._point){var r=this._x2-t,i=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(r*r+i*i,this._alpha))}switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3;default:e(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return n?new i(t,n):new a.b(t,0)}return r.alpha=function(n){return t(+n)},r}(.5)},function(t,n,r){"use strict";var e=r(14),i=r(16),u=r(44),a=r(84);n.a=function(){function t(t){var i,u,a,h=t.length,d=!1;for(null==f&&(l=s(a=r.i(e.a)())),i=0;i<=h;++i)!(i=0&&n._call.call(null,t),n=n._next;--p}function c(){b=(_=x.now())+m,p=v=0;try{o()}finally{p=0,s(),b=0}}function f(){var t=x.now(),n=t-_;n>y&&(m-=n,_=t)}function s(){for(var t,n,r=h,e=1/0;r;)r._call?(e>r._time&&(e=r._time),t=r,r=r._next):(n=r._next,r._next=null,r=t?t._next=n:h=n);d=t,l(e)}function l(t){if(!p){v&&(v=clearTimeout(v));t-b>24?(t<1/0&&(v=setTimeout(c,t-x.now()-m)),g&&(g=clearInterval(g))):(g||(_=x.now(),g=setInterval(f,y)),p=1,w(c))}}n.a=e,n.d=u,n.b=a,n.c=o;var h,d,p=0,v=0,g=0,y=1e3,_=0,b=0,m=0,x="object"==typeof performance&&performance.now?performance:Date,w="object"==typeof window&&window.requestAnimationFrame?window.requestAnimationFrame.bind(window):function(t){setTimeout(t,17)};u.prototype=a.prototype={constructor:u,restart:function(t,n,r){if("function"!=typeof t)throw new TypeError("callback is not a function");r=(null==r?e():+r)+(null==n?0:+n),this._next||d===this||(d?d._next=this:h=this,d=this),this._call=t,this._time=r,l()},stop:function(){this._call&&(this._call=null,this._time=1/0,l())}}},function(t,n,r){"use strict";var e=(r(435),r(11));r.d(n,"a",function(){return e.a});var i=r(434);r.d(n,"b",function(){return i.a});var u=r(167);r.d(n,"c",function(){return u.a})},function(t,n,r){"use strict";function e(t,n,r,e){var i=[null,null],a=f.d.push(i)-1;return i.left=t,i.right=n,r&&u(i,t,n,r),e&&u(i,n,t,e),f.c[t.index].halfedges.push(a),f.c[n.index].halfedges.push(a),i}function i(t,n,r){var e=[n,r];return e.left=t,e}function u(t,n,r,e){t[0]||t[1]?t.left===r?t[1]=e:t[0]=e:(t[0]=e,t.left=n,t.right=r)}function a(t,n,r,e,i){var u,a=t[0],o=t[1],c=a[0],f=a[1],s=o[0],l=o[1],h=0,d=1,p=s-c,v=l-f;if(u=n-c,p||!(u>0)){if(u/=p,p<0){if(u0){if(u>d)return;u>h&&(h=u)}if(u=e-c,p||!(u<0)){if(u/=p,p<0){if(u>d)return;u>h&&(h=u)}else if(p>0){if(u0)){if(u/=v,v<0){if(u0){if(u>d)return;u>h&&(h=u)}if(u=i-f,v||!(u<0)){if(u/=v,v<0){if(u>d)return;u>h&&(h=u)}else if(v>0){if(u0||d<1)||(h>0&&(t[0]=[c+h*p,f+h*v]),d<1&&(t[1]=[c+d*p,f+d*v]),!0)}}}}}function o(t,n,r,e,i){var u=t[1];if(u)return!0;var a,o,c=t[0],f=t.left,s=t.right,l=f[0],h=f[1],d=s[0],p=s[1],v=(l+d)/2,g=(h+p)/2;if(p===h){if(v=e)return;if(l>d){if(c){if(c[1]>=i)return}else c=[v,r];u=[v,i]}else{if(c){if(c[1]1)if(l>d){if(c){if(c[1]>=i)return}else c=[(r-o)/a,r];u=[(i-o)/a,i]}else{if(c){if(c[1]=e)return}else c=[n,a*n+o];u=[e,a*e+o]}else{if(c){if(c[0]f.b||Math.abs(i[0][1]-i[1][1])>f.b)||delete f.d[u]}var f=r(32);n.d=e,n.b=i,n.c=u,n.a=c},function(t,n,r){"use strict";function e(){this._=null}function i(t){t.U=t.C=t.L=t.R=t.P=t.N=null}function u(t,n){var r=n,e=n.R,i=r.U;i?i.L===r?i.L=e:i.R=e:t._=e,e.U=i,r.U=e,r.R=e.L,r.R&&(r.R.U=r),e.L=r}function a(t,n){var r=n,e=n.L,i=r.U;i?i.L===r?i.L=e:i.R=e:t._=e,e.U=i,r.U=e,r.L=e.R,r.L&&(r.L.U=r),e.R=r}function o(t){for(;t.L;)t=t.L;return t}n.b=i,e.prototype={constructor:e,insert:function(t,n){var r,e,i;if(t){if(n.P=t,n.N=t.N,t.N&&(t.N.P=n),t.N=n,t.R){for(t=t.R;t.L;)t=t.L;t.L=n}else t.R=n;r=t}else this._?(t=o(this._),n.P=null,n.N=t,t.P=t.L=n,r=t):(n.P=n.N=null,this._=n,r=null);for(n.L=n.R=null,n.U=r,n.C=!0,t=n;r&&r.C;)e=r.U,r===e.L?(i=e.R,i&&i.C?(r.C=i.C=!1,e.C=!0,t=e):(t===r.R&&(u(this,r),t=r,r=t.U),r.C=!1,e.C=!0,a(this,e))):(i=e.L,i&&i.C?(r.C=i.C=!1,e.C=!0,t=e):(t===r.L&&(a(this,r),t=r,r=t.U),r.C=!1,e.C=!0,u(this,e))),r=t.U;this._.C=!1},remove:function(t){t.N&&(t.N.P=t.P),t.P&&(t.P.N=t.N),t.N=t.P=null;var n,r,e,i=t.U,c=t.L,f=t.R;if(r=c?f?o(f):c:f,i?i.L===t?i.L=r:i.R=r:this._=r,c&&f?(e=r.C,r.C=t.C,r.L=c,c.U=r,r!==f?(i=r.U,r.U=t.U,t=r.R,i.L=t,r.R=f,f.U=r):(r.U=i,i=r,t=r.R)):(e=t.C,t=r),t&&(t.U=i),!e){if(t&&t.C)return void(t.C=!1);do{if(t===this._)break;if(t===i.L){if(n=i.R,n.C&&(n.C=!1,i.C=!0,u(this,i),n=i.R),n.L&&n.L.C||n.R&&n.R.C){n.R&&n.R.C||(n.L.C=!1,n.C=!0,a(this,n),n=i.R),n.C=i.C,i.C=n.R.C=!1,u(this,i),t=this._;break}}else if(n=i.L,n.C&&(n.C=!1,i.C=!0,a(this,i),n=i.L),n.L&&n.L.C||n.R&&n.R.C){n.L&&n.L.C||(n.R.C=!1,n.C=!0,u(this,n),n=i.L),n.C=i.C,i.C=n.L.C=!1,a(this,i),t=this._;break}n.C=!0,t=i,i=i.U}while(!t.C);t&&(t.C=!1)}}},n.a=e},function(t,n,r){"use strict";r.d(n,"b",function(){return i}),r.d(n,"a",function(){return u});var e=Array.prototype,i=e.slice,u=e.map},function(t,n,r){"use strict";var e=r(17),i=r(93);r.d(n,"b",function(){return a}),r.d(n,"c",function(){return o});var u=r.i(i.a)(e.a),a=u.right,o=u.left;n.a=a},function(t,n,r){"use strict";function e(t){return function(n,e){return r.i(i.a)(t(n),e)}}var i=r(17);n.a=function(t){return 1===t.length&&(t=e(t)),{left:function(n,r,e,i){for(null==e&&(e=0),null==i&&(i=n.length);e>>1;t(n[u],r)<0?e=u+1:i=u}return e},right:function(n,r,e,i){for(null==e&&(e=0),null==i&&(i=n.length);e>>1;t(n[u],r)>0?i=u:e=u+1}return e}}}},function(t,n,r){"use strict";var e=r(102);n.a=function(t,n){var i=r.i(e.a)(t,n);return i?Math.sqrt(i):i}},function(t,n,r){"use strict";n.a=function(t,n){var r,e,i,u=t.length,a=-1;if(null==n){for(;++a=r)for(e=i=r;++ar&&(e=r),i=r)for(e=i=r;++ar&&(e=r),i=r)for(e=r;++ur&&(e=r)}else for(;++u=r)for(e=r;++ur&&(e=r);return e}},function(t,n,r){"use strict";function e(t,n){return[t,n]}n.b=e,n.a=function(t,n){null==n&&(n=e);for(var r=0,i=t.length-1,u=t[0],a=new Array(i<0?0:i);r=0?(c>=u?10:c>=a?5:c>=o?2:1)*Math.pow(10,i):-Math.pow(10,-i)/(c>=u?10:c>=a?5:c>=o?2:1)}function i(t,n,r){var e=Math.abs(n-t)/Math.max(0,r),i=Math.pow(10,Math.floor(Math.log(e)/Math.LN10)),c=e/i;return c>=u?i*=10:c>=a?i*=5:c>=o&&(i*=2),n0)return[t];if((i=n0)for(t=Math.ceil(t/o),n=Math.floor(n/o),a=new Array(u=Math.ceil(n-t+1));++c1)return s/(o-1)}},function(t,n,r){"use strict";r.d(n,"b",function(){return e}),r.d(n,"c",function(){return i}),r.d(n,"a",function(){return a}),r.d(n,"e",function(){return o}),r.d(n,"d",function(){return c});var e=Math.cos,i=Math.sin,u=Math.PI,a=u/2,o=2*u,c=Math.max},function(t,n,r){"use strict";r.d(n,"b",function(){return e}),r.d(n,"a",function(){return i});var e=Math.PI/180,i=180/Math.PI},function(t,n,r){"use strict";function e(t,n){var e=t.document.documentElement,a=r.i(i.h)(t).on("dragstart.drag",null);n&&(a.on("click.drag",u.a,!0),setTimeout(function(){a.on("click.drag",null)},0)),"onselectstart"in e?a.on("selectstart.drag",null):(e.style.MozUserSelect=e.__noselect,delete e.__noselect)}var i=r(1),u=r(106);n.b=e,n.a=function(t){var n=t.document.documentElement,e=r.i(i.h)(t).on("dragstart.drag",u.a,!0);"onselectstart"in n?e.on("selectstart.drag",u.a,!0):(n.__noselect=n.style.MozUserSelect,n.style.MozUserSelect="none")}},function(t,n,r){"use strict";function e(){i.q.stopImmediatePropagation()}var i=r(1);n.b=e,n.a=function(){i.q.preventDefault(),i.q.stopImmediatePropagation()}},function(t,n,r){"use strict";var e=r(224);r.d(n,"a",function(){return e.a});var i=r(226);r.d(n,"b",function(){return i.a}),r.d(n,"c",function(){return i.b}),r.d(n,"d",function(){return i.c}),r.d(n,"e",function(){return i.a});var u=r(221);r.d(n,"f",function(){return u.a}),r.d(n,"g",function(){return u.b}),r.d(n,"h",function(){return u.c}),r.d(n,"i",function(){return u.a});var a=r(225);r.d(n,"j",function(){return a.a}),r.d(n,"k",function(){return a.b}),r.d(n,"l",function(){return a.c}),r.d(n,"m",function(){return a.a});var o=r(227);r.d(n,"n",function(){return o.a}),r.d(n,"o",function(){return o.b}),r.d(n,"p",function(){return o.c}),r.d(n,"q",function(){return o.a});var c=r(223);r.d(n,"r",function(){return c.a}),r.d(n,"s",function(){return c.b}),r.d(n,"t",function(){return c.c}),r.d(n,"u",function(){return c.a});var f=r(220);r.d(n,"v",function(){return f.a}),r.d(n,"w",function(){return f.b}),r.d(n,"x",function(){return f.c}),r.d(n,"y",function(){return f.a});var s=r(219);r.d(n,"z",function(){return s.a}),r.d(n,"A",function(){return s.b}),r.d(n,"B",function(){return s.a}),r.d(n,"C",function(){return s.c});var l=r(218);r.d(n,"D",function(){return l.a}),r.d(n,"E",function(){return l.b}),r.d(n,"F",function(){return l.c}),r.d(n,"G",function(){return l.a});var h=r(222);r.d(n,"H",function(){return h.a}),r.d(n,"I",function(){return h.b}),r.d(n,"J",function(){return h.a}),r.d(n,"K",function(){return h.c})},function(t,n,r){"use strict";function e(t){return t.x}function i(t){return t.y}var u=r(12),a=r(22),o=r(47);n.b=e,n.c=i;var c=Math.PI*(3-Math.sqrt(5));n.a=function(t){function n(){e(),_.call("tick",s),l1?(null==n?g.remove(t):g.set(t,f(n)),s):g.get(t)},find:function(n,r,e){var i,u,a,o,c,f=0,s=t.length;for(null==e?e=1/0:e*=e,f=0;f1?(_.on(t,n),s):_.on(t)}}}},function(t,n,r){"use strict";var e=r(59);r.d(n,"b",function(){return i});var i;n.a=function(t,n){var u=r.i(e.a)(t,n);if(!u)return t+"";var a=u[0],o=u[1],c=o-(i=3*Math.max(-8,Math.min(8,Math.floor(o/3))))+1,f=a.length;return c===f?a:c>f?a+new Array(c-f+1).join("0"):c>0?a.slice(0,c)+"."+a.slice(c):"0."+new Array(1-c).join("0")+r.i(e.a)(t,Math.max(0,n+c-1))[0]}},function(t,n,r){"use strict";function e(t){return new i(t)}function i(t){if(!(n=a.exec(t)))throw new Error("invalid format: "+t);var n,r=n[1]||" ",e=n[2]||">",i=n[3]||"-",o=n[4]||"",c=!!n[5],f=n[6]&&+n[6],s=!!n[7],l=n[8]&&+n[8].slice(1),h=n[9]||"";"n"===h?(s=!0,h="g"):u.a[h]||(h=""),(c||"0"===r&&"="===e)&&(c=!0,r="0",e="="),this.fill=r,this.align=e,this.sign=i,this.symbol=o,this.zero=c,this.width=f,this.comma=s,this.precision=l,this.type=h}var u=r(111);n.a=e;var a=/^(?:(.)?([<>=^]))?([+\-\( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?([a-z%])?$/i;e.prototype=i.prototype,i.prototype.toString=function(){return this.fill+this.align+this.sign+this.symbol+(this.zero?"0":"")+(null==this.width?"":Math.max(1,0|this.width))+(this.comma?",":"")+(null==this.precision?"":"."+Math.max(0,0|this.precision))+this.type}},function(t,n,r){"use strict";var e=r(237),i=r(109),u=r(240);n.a={"":e.a,"%":function(t,n){return(100*t).toFixed(n)},b:function(t){return Math.round(t).toString(2)},c:function(t){return t+""},d:function(t){return Math.round(t).toString(10)},e:function(t,n){return t.toExponential(n)},f:function(t,n){return t.toFixed(n)},g:function(t,n){return t.toPrecision(n)},o:function(t){return Math.round(t).toString(8)},p:function(t,n){return r.i(u.a)(100*t,n)},r:u.a,s:i.a,X:function(t){return Math.round(t).toString(16).toUpperCase()},x:function(t){return Math.round(t).toString(16)}}},function(t,n,r){"use strict";var e=r(33),i=r(238),u=r(239),a=r(110),o=r(111),c=r(109),f=r(241),s=["y","z","a","f","p","n","µ","m","","k","M","G","T","P","E","Z","Y"];n.a=function(t){function n(t){function n(t){var n,r,a,o=x,f=w;if("c"===m)f=M(t)+f,t="";else{t=+t;var d=t<0;if(t=M(Math.abs(t),b),d&&0==+t&&(d=!1),o=(d?"("===u?u:"-":"-"===u||"("===u?"":u)+o,f=f+("s"===m?s[8+c.b/3]:"")+(d&&"("===u?")":""),k)for(n=-1,r=t.length;++n(a=t.charCodeAt(n))||a>57){f=(46===a?p+t.slice(n+1):t.slice(n))+f,t=t.slice(0,n);break}}_&&!l&&(t=h(t,1/0));var g=o.length+t.length+f.length,T=g>1)+o+t+f+T.slice(g);break;default:t=T+o+t+f}return v(t)}t=r.i(a.a)(t);var e=t.fill,i=t.align,u=t.sign,f=t.symbol,l=t.zero,y=t.width,_=t.comma,b=t.precision,m=t.type,x="$"===f?d[0]:"#"===f&&/[boxX]/.test(m)?"0"+m.toLowerCase():"",w="$"===f?d[1]:/[%p]/.test(m)?g:"",M=o.a[m],k=!m||/[defgprs%]/.test(m);return b=null==b?m?6:12:/[gprs]/.test(m)?Math.max(1,Math.min(21,b)):Math.max(0,Math.min(20,b)),n.toString=function(){return t+""},n}function l(t,i){var u=n((t=r.i(a.a)(t),t.type="f",t)),o=3*Math.max(-8,Math.min(8,Math.floor(r.i(e.a)(i)/3))),c=Math.pow(10,-o),f=s[8+o/3];return function(t){return u(c*t)+f}}var h=t.grouping&&t.thousands?r.i(i.a)(t.grouping,t.thousands):f.a,d=t.currency,p=t.decimal,v=t.numerals?r.i(u.a)(t.numerals):f.a,g=t.percent||"%";return{format:n,formatPrefix:l}}},function(t,n,r){"use strict";function e(){_.point=u}function i(){a(l,h)}function u(t,n){_.point=a,l=t,h=n,t*=c.g,n*=c.g,d=t,p=r.i(c.c)(n=n/2+c.v),v=r.i(c.d)(n)}function a(t,n){t*=c.g,n*=c.g,n=n/2+c.v;var e=t-d,i=e>=0?1:-1,u=i*e,a=r.i(c.c)(n),o=r.i(c.d)(n),f=v*o,s=p*a+f*r.i(c.c)(u),l=f*i*r.i(c.d)(u);g.add(r.i(c.e)(l,s)),d=t,p=a,v=o}var o=r(19),c=r(0),f=r(10),s=r(13);r.d(n,"c",function(){return g}),r.d(n,"b",function(){return _});var l,h,d,p,v,g=r.i(o.a)(),y=r.i(o.a)(),_={point:f.a,lineStart:f.a,lineEnd:f.a,polygonStart:function(){g.reset(),_.lineStart=e,_.lineEnd=i},polygonEnd:function(){var t=+g;y.add(t<0?c.b+t:t),this.lineStart=this.lineEnd=this.point=f.a},sphere:function(){y.add(c.b)}};n.a=function(t){return y.reset(),r.i(s.a)(t,_),2*y}},function(t,n,r){"use strict";function e(t,n,e,a,c,f){if(e){var s=r.i(o.c)(n),l=r.i(o.d)(n),h=a*e;null==c?(c=n+a*o.b,f=n-h/2):(c=i(s,c),f=i(s,f),(a>0?cf)&&(c+=a*o.b));for(var d,p=c;a>0?p>f:p0?o.a:-o.a,l=r.i(o.p)(c-e);r.i(o.p)(l-o.a)0?o.k:-o.k),t.point(a,u),t.lineEnd(),t.lineStart(),t.point(s,u),t.point(c,u),n=0):a!==s&&l>=o.a&&(r.i(o.p)(e-a)o.o?r.i(o.l)((r.i(o.d)(n)*(a=r.i(o.c)(i))*r.i(o.d)(e)-r.i(o.d)(i)*(u=r.i(o.c)(n))*r.i(o.d)(t))/(u*a*c)):(n+i)/2}function u(t,n,e,i){var u;if(null==t)u=e*o.k,i.point(-o.a,u),i.point(0,u),i.point(o.a,u),i.point(o.a,0),i.point(o.a,-u),i.point(0,-u),i.point(-o.a,-u),i.point(-o.a,0),i.point(-o.a,u);else if(r.i(o.p)(t[0]-n[0])>o.o){var a=t[0]1&&n.push(n.pop().concat(n.shift()))},result:function(){var r=n;return n=[],t=null,r}}}},function(t,n,r){"use strict";var e=r(23),i=r(114),u=r(0),a=r(124),o=r(118);n.a=function(t){function n(n,e,u,a){r.i(i.b)(a,t,d,u,n,e)}function c(t,n){return r.i(u.c)(t)*r.i(u.c)(n)>h}function f(t){var n,e,i,o,f;return{lineStart:function(){o=i=!1,f=1},point:function(h,d){var g,y=[h,d],_=c(h,d),b=p?_?0:l(h,d):_?l(h+(h<0?u.a:-u.a),d):0;if(!n&&(o=i=_)&&t.lineStart(),_!==i&&(!(g=s(n,y))||r.i(a.a)(n,g)||r.i(a.a)(y,g))&&(y[0]+=u.o,y[1]+=u.o,_=c(y[0],y[1])),_!==i)f=0,_?(t.lineStart(),g=s(y,n),t.point(g[0],g[1])):(g=s(n,y),t.point(g[0],g[1]),t.lineEnd()),n=g;else if(v&&n&&p^_){var m;b&e||!(m=s(y,n,!0))||(f=0,p?(t.lineStart(),t.point(m[0][0],m[0][1]),t.point(m[1][0],m[1][1]),t.lineEnd()):(t.point(m[1][0],m[1][1]),t.lineEnd(),t.lineStart(),t.point(m[0][0],m[0][1])))}!_||n&&r.i(a.a)(n,y)||t.point(y[0],y[1]),n=y,i=_,e=b},lineEnd:function(){i&&t.lineEnd(),n=null},clean:function(){return f|(o&&i)<<1}}}function s(t,n,i){var a=r.i(e.a)(t),o=r.i(e.a)(n),c=[1,0,0],f=r.i(e.b)(a,o),s=r.i(e.d)(f,f),l=f[0],d=s-l*l;if(!d)return!i&&t;var p=h*s/d,v=-h*l/d,g=r.i(e.b)(c,f),y=r.i(e.e)(c,p),_=r.i(e.e)(f,v);r.i(e.f)(y,_);var b=g,m=r.i(e.d)(y,b),x=r.i(e.d)(b,b),w=m*m-x*(r.i(e.d)(y,y)-1);if(!(w<0)){var M=r.i(u.n)(w),k=r.i(e.e)(b,(-m-M)/x);if(r.i(e.f)(k,y),k=r.i(e.g)(k),!i)return k;var T,N=t[0],A=n[0],E=t[1],S=n[1];A0^k[1]<(r.i(u.p)(k[0]-N)u.a^(N<=k[0]&&k[0]<=A)){var P=r.i(e.e)(b,(-m+M)/x);return r.i(e.f)(P,y),[k,r.i(e.g)(P)]}}}function l(n,r){var e=p?t:u.a-t,i=0;return n<-e?i|=1:n>e&&(i|=2),r<-e?i|=4:r>e&&(i|=8),i}var h=r.i(u.c)(t),d=6*u.g,p=h>0,v=r.i(u.p)(h)>u.o;return r.i(o.a)(c,f,n,p?[0,-t]:[-u.a,t-u.a])}},function(t,n,r){"use strict";function e(t){return t.length>1}function i(t,n){return((t=t.x)[0]<0?t[1]-o.k-o.o:o.k-t[1])-((n=n.x)[0]<0?n[1]-o.k-o.o:o.k-n[1])}var u=r(116),a=r(119),o=r(0),c=r(125),f=r(3);n.a=function(t,n,o,s){return function(l){function h(n,r){t(n,r)&&l.point(n,r)}function d(t,n){w.point(t,n)}function p(){N.point=d,w.lineStart()}function v(){N.point=h,w.lineEnd()}function g(t,n){x.push([t,n]),k.point(t,n)}function y(){k.lineStart(),x=[]}function _(){g(x[0][0],x[0][1]),k.lineEnd();var t,n,r,i,u=k.clean(),a=M.result(),o=a.length;if(x.pop(),b.push(x),x=null,o)if(1&u){if(r=a[0],(n=r.length-1)>0){for(T||(l.polygonStart(),T=!0),l.lineStart(),t=0;t1&&2&u&&a.push(a.pop().concat(a.shift())),m.push(a.filter(e))}var b,m,x,w=n(l),M=r.i(u.a)(),k=n(M),T=!1,N={point:h,lineStart:p,lineEnd:v,polygonStart:function(){N.point=g,N.lineStart=y,N.lineEnd=_,m=[],b=[]},polygonEnd:function(){N.point=h,N.lineStart=p,N.lineEnd=v,m=r.i(f.q)(m);var t=r.i(c.a)(b,s);m.length?(T||(l.polygonStart(),T=!0),r.i(a.a)(m,i,t,o,l)):t&&(T||(l.polygonStart(),T=!0),l.lineStart(),o(null,null,1,l),l.lineEnd()),T&&(l.polygonEnd(),T=!1),m=b=null},sphere:function(){l.polygonStart(),l.lineStart(),o(null,null,1,l),l.lineEnd(),l.polygonEnd()}};return N}}},function(t,n,r){"use strict";function e(t,n,r,e){this.x=t,this.z=n,this.o=r,this.e=e,this.v=!1,this.n=this.p=null}function i(t){if(n=t.length){for(var n,r,e=0,i=t[0];++e=0;--f)c.point((p=d[f])[0],p[1]);else o(g.x,g.p.x,-1,c);g=g.p}g=g.o,d=g.z,y=!y}while(!g.v);c.lineEnd()}}}},function(t,n,r){"use strict";n.a=function(t,n){function r(r,e){return r=t(r,e),n(r[0],r[1])}return t.invert&&n.invert&&(r.invert=function(r,e){return(r=n.invert(r,e))&&t.invert(r[0],r[1])}),r}},function(t,n,r){"use strict";var e=r(122),i=[null,null],u={type:"LineString",coordinates:i};n.a=function(t,n){return i[0]=t,i[1]=n,r.i(e.a)(u)}},function(t,n,r){"use strict";function e(){v.point=u,v.lineEnd=i}function i(){v.point=v.lineEnd=h.a}function u(t,n){t*=l.g,n*=l.g,o=t,c=r.i(l.d)(n),f=r.i(l.c)(n),v.point=a}function a(t,n){t*=l.g,n*=l.g;var e=r.i(l.d)(n),i=r.i(l.c)(n),u=r.i(l.p)(t-o),a=r.i(l.c)(u),s=r.i(l.d)(u),h=i*s,d=f*e-c*i*a,v=c*e+f*i*a;p.add(r.i(l.e)(r.i(l.n)(h*h+d*d),v)),o=t,c=e,f=i}var o,c,f,s=r(19),l=r(0),h=r(10),d=r(13),p=r.i(s.a)(),v={sphere:h.a,point:h.a,lineStart:e,lineEnd:h.a,polygonStart:h.a,polygonEnd:h.a};n.a=function(t){return p.reset(),r.i(d.a)(t,v),+p}},function(t,n,r){"use strict";function e(t,n){to&&(o=t),nc&&(c=n)}var i=r(10),u=1/0,a=u,o=-u,c=o,f={point:e,lineStart:i.a,lineEnd:i.a,polygonStart:i.a,polygonEnd:i.a,result:function(){var t=[[u,a],[o,c]];return o=c=-(a=u=1/0),t}};n.a=f},function(t,n,r){"use strict";var e=r(0);n.a=function(t,n){return r.i(e.p)(t[0]-n[0])=0?1:-1,E=A*N,S=E>u.a,C=_*k;if(a.add(r.i(u.e)(C*A*r.i(u.d)(E),b*T+C*r.i(u.c)(E))),f+=S?N+A*u.b:N,S^g>=e^w>=e){var q=r.i(i.b)(r.i(i.a)(v),r.i(i.a)(x));r.i(i.c)(q);var z=r.i(i.b)(c,q);r.i(i.c)(z);var P=(S^N>=0?-1:1)*r.i(u.f)(z[2]);(o>P||o===P&&(q[0]||q[1]))&&(s+=S^N>=0?1:-1)}}return(f<-u.o||f0&&r*r>e*e+i*i}function a(t,n){for(var r=0;rr*r+e*e}function u(t){var n=t._,r=t.next._,e=n.r+r.r,i=(n.x*r.r+r.x*n.r)/e,u=(n.y*r.r+r.y*n.r)/e;return i*i+u*u}function a(t){this._=t,this.next=null,this.previous=null}function o(t){if(!(s=t.length))return 0;var n,o,f,s,l,h,d,p,v,g,y;if(n=t[0],n.x=0,n.y=0,!(s>1))return n.r;if(o=t[1],n.x=-o.r,o.x=n.r,o.y=0,!(s>2))return n.r+o.r;e(o,n,f=t[2]),n=new a(n),o=new a(o),f=new a(f),n.next=f.previous=o,o.next=n.previous=f,f.next=o.previous=n;t:for(d=3;dl&&(s=n.slice(l,s),d[h]?d[h]+=s:d[++h]=s),(c=c[0])===(f=f[0])?d[h]?d[h]+=f:d[++h]=f:(d[++h]=null,p.push({i:h,x:r.i(u.a)(c,f)})),l=o.lastIndex;return l1);return t+r*u*Math.sqrt(-2*Math.log(i)/i)}}return r.source=t,r}(e.a)},function(t,n,r){"use strict";function e(t,n){return function(r){return t(r.responseText,n)}}var i=r(72);n.a=function(t,n){return function(u,a,o){arguments.length<3&&(o=a,a=null);var c=r.i(i.a)(u).mimeType(t);return c.row=function(t){return arguments.length?c.response(e(n,a=t)):a},c.row(a),o?c.get(o):c}}},function(t,n,r){"use strict";n.a=function(t,n){t=t.slice();var r,e=0,i=t.length-1,u=t[e],a=t[i];return a1?this.each((null==n?e:"function"==typeof n?u:i)(t,n,null==r?"":r)):a(this.node(),t)}},function(t,n,r){"use strict";function e(){return[]}n.a=function(t){return null==t?e:function(){return this.querySelectorAll(t)}}},function(t,n,r){"use strict";var e=r(14),i=r(16),u=r(44),a=r(82),o=r(84);n.a=function(){function t(t){var n,i,u,a,o,g=t.length,y=!1,_=new Array(g),b=new Array(g);for(null==d&&(v=p(o=r.i(e.a)())),n=0;n<=g;++n){if(!(n=i;--u)v.point(_[u],b[u]);v.lineEnd(),v.areaEnd()}y&&(_[n]=+c(a,n,t),b[n]=+s(a,n,t),v.point(f?+f(a,n,t):_[n],l?+l(a,n,t):b[n]))}if(o)return v=null,o+""||null}function n(){return r.i(a.a)().defined(h).curve(p).context(d)}var c=o.a,f=null,s=r.i(i.a)(0),l=o.b,h=r.i(i.a)(!0),d=null,p=u.a,v=null;return t.x=function(n){return arguments.length?(c="function"==typeof n?n:r.i(i.a)(+n),f=null,t):c},t.x0=function(n){return arguments.length?(c="function"==typeof n?n:r.i(i.a)(+n),t):c},t.x1=function(n){return arguments.length?(f=null==n?null:"function"==typeof n?n:r.i(i.a)(+n),t):f},t.y=function(n){return arguments.length?(s="function"==typeof n?n:r.i(i.a)(+n),l=null,t):s},t.y0=function(n){return arguments.length?(s="function"==typeof n?n:r.i(i.a)(+n),t):s},t.y1=function(n){return arguments.length?(l=null==n?null:"function"==typeof n?n:r.i(i.a)(+n),t):l},t.lineX0=t.lineY0=function(){return n().x(c).y(s)},t.lineY1=function(){return n().x(c).y(l)},t.lineX1=function(){return n().x(f).y(s)},t.defined=function(n){return arguments.length?(h="function"==typeof n?n:r.i(i.a)(!!n),t):h},t.curve=function(n){return arguments.length?(p=n,null!=d&&(v=p(d)),t):p},t.context=function(n){return arguments.length?(null==n?d=v=null:v=p(d=n),t):d},t}},function(t,n,r){"use strict";r.d(n,"a",function(){return e});var e=Array.prototype.slice},function(t,n,r){"use strict";function e(t,n){this._context=t,this._k=(1-n)/6}var i=r(45),u=r(43);n.b=e,e.prototype={areaStart:i.a,areaEnd:i.a,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x3,this._y3),this._context.closePath();break;case 2:this._context.lineTo(this._x3,this._y3),this._context.closePath();break;case 3:this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5)}},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._x3=t,this._y3=n;break;case 1:this._point=2,this._context.moveTo(this._x4=t,this._y4=n);break;case 2:this._point=3,this._x5=t,this._y5=n;break;default:r.i(u.c)(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return new e(t,n)}return r.tension=function(n){return t(+n)},r}(0)},function(t,n,r){"use strict";function e(t,n){this._context=t,this._k=(1-n)/6}var i=r(43);n.b=e,e.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:r.i(i.c)(this,t,n)}this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return new e(t,n)}return r.tension=function(n){return t(+n)},r}(0)},function(t,n,r){"use strict";function e(t){this._curve=t}function i(t){function n(n){return new e(t(n))}return n._curve=t,n}var u=r(44);r.d(n,"b",function(){return a}),n.a=i;var a=i(u.a);e.prototype={areaStart:function(){this._curve.areaStart()},areaEnd:function(){this._curve.areaEnd()},lineStart:function(){this._curve.lineStart()},lineEnd:function(){this._curve.lineEnd()},point:function(t,n){this._curve.point(n*Math.sin(t),n*-Math.cos(t))}}},function(t,n,r){"use strict";function e(t){var n=t.curve;return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t.curve=function(t){return arguments.length?n(r.i(i.a)(t)):n()._curve},t}var i=r(155),u=r(82);n.b=e,n.a=function(){return e(r.i(u.a)().curve(i.b))}},function(t,n,r){"use strict";n.a=function(t,n){return[(n=+n)*Math.cos(t-=Math.PI/2),n*Math.sin(t)]}},function(t,n,r){"use strict";var e=r(29);n.a={draw:function(t,n){var r=Math.sqrt(n/e.b);t.moveTo(r,0),t.arc(0,0,r,0,e.c)}}},function(t,n,r){"use strict";n.a={draw:function(t,n){var r=Math.sqrt(n/5)/2;t.moveTo(-3*r,-r),t.lineTo(-r,-r),t.lineTo(-r,-3*r),t.lineTo(r,-3*r),t.lineTo(r,-r),t.lineTo(3*r,-r),t.lineTo(3*r,r),t.lineTo(r,r),t.lineTo(r,3*r),t.lineTo(-r,3*r),t.lineTo(-r,r),t.lineTo(-3*r,r),t.closePath()}}},function(t,n,r){"use strict";var e=Math.sqrt(1/3),i=2*e;n.a={draw:function(t,n){var r=Math.sqrt(n/i),u=r*e;t.moveTo(0,-r),t.lineTo(u,0),t.lineTo(0,r),t.lineTo(-u,0),t.closePath()}}},function(t,n,r){"use strict";n.a={draw:function(t,n){var r=Math.sqrt(n),e=-r/2;t.rect(e,e,r,r)}}},function(t,n,r){"use strict";var e=r(29),i=Math.sin(e.b/10)/Math.sin(7*e.b/10),u=Math.sin(e.c/10)*i,a=-Math.cos(e.c/10)*i;n.a={draw:function(t,n){var r=Math.sqrt(.8908130915292852*n),i=u*r,o=a*r;t.moveTo(0,-r),t.lineTo(i,o);for(var c=1;c<5;++c){var f=e.c*c/5,s=Math.cos(f),l=Math.sin(f);t.lineTo(l*r,-s*r),t.lineTo(s*i-l*o,l*i+s*o)}t.closePath()}}},function(t,n,r){"use strict";var e=Math.sqrt(3);n.a={draw:function(t,n){var r=-Math.sqrt(n/(3*e));t.moveTo(0,2*r),t.lineTo(-e*r,-r),t.lineTo(e*r,-r),t.closePath()}}},function(t,n,r){"use strict";var e=-.5,i=Math.sqrt(3)/2,u=1/Math.sqrt(12),a=3*(u/2+1);n.a={draw:function(t,n){var r=Math.sqrt(n/a),o=r/2,c=r*u,f=o,s=r*u+r,l=-f,h=s;t.moveTo(o,c),t.lineTo(f,s),t.lineTo(l,h),t.lineTo(e*o-i*c,i*o+e*c),t.lineTo(e*f-i*s,i*f+e*s),t.lineTo(e*l-i*h,i*l+e*h),t.lineTo(e*o+i*c,e*c-i*o),t.lineTo(e*f+i*s,e*s-i*f),t.lineTo(e*l+i*h,e*h-i*l),t.closePath()}}},function(t,n,r){"use strict";function e(t){return t.toISOString()}var i=r(86);r.d(n,"b",function(){return u});var u="%Y-%m-%dT%H:%M:%S.%LZ",a=Date.prototype.toISOString?e:r.i(i.d)(u);n.a=a},function(t,n,r){"use strict";function e(t){if(0<=t.y&&t.y<100){var n=new Date(-1,t.m,t.d,t.H,t.M,t.S,t.L);return n.setFullYear(t.y),n}return new Date(t.y,t.m,t.d,t.H,t.M,t.S,t.L)}function i(t){if(0<=t.y&&t.y<100){var n=new Date(Date.UTC(-1,t.m,t.d,t.H,t.M,t.S,t.L));return n.setUTCFullYear(t.y),n}return new Date(Date.UTC(t.y,t.m,t.d,t.H,t.M,t.S,t.L))}function u(t){return{y:t,m:0,d:1,H:0,M:0,S:0,L:0}}function a(t){function n(t,n){return function(r){var e,i,u,a=[],o=-1,c=0,f=t.length;for(r instanceof Date||(r=new Date(+r));++o53)return null;"w"in f||(f.w=1),"Z"in f?(a=i(u(f.y)),c=a.getUTCDay(),a=c>4||0===c?dt.T.ceil(a):r.i(dt.T)(a),a=dt.N.offset(a,7*(f.V-1)),f.y=a.getUTCFullYear(),f.m=a.getUTCMonth(),f.d=a.getUTCDate()+(f.w+6)%7):(a=n(u(f.y)),c=a.getDay(),a=c>4||0===c?dt.t.ceil(a):r.i(dt.t)(a),a=dt.n.offset(a,7*(f.V-1)),f.y=a.getFullYear(),f.m=a.getMonth(),f.d=a.getDate()+(f.w+6)%7)}else("W"in f||"U"in f)&&("w"in f||(f.w="u"in f?f.u%7:"W"in f?1:0),c="Z"in f?i(u(f.y)).getUTCDay():n(u(f.y)).getDay(),f.m=0,f.d="W"in f?(f.w+6)%7+7*f.W-(c+5)%7:f.w+7*f.U-(c+6)%7);return"Z"in f?(f.H+=f.Z/100|0,f.M+=f.Z%100,i(f)):n(f)}}function o(t,n,r,e){for(var i,u,a=0,o=n.length,c=r.length;a=c)return-1;if(37===(i=n.charCodeAt(a++))){if(i=n.charAt(a++),!(u=Jt[i in pt?n.charAt(a++):i])||(e=u(t,r,e))<0)return-1}else if(i!=r.charCodeAt(e++))return-1}return e}function c(t,n,r){var e=It.exec(n.slice(r));return e?(t.p=Ft[e[0].toLowerCase()],r+e[0].length):-1}function vt(t,n,r){var e=Ht.exec(n.slice(r));return e?(t.w=Xt[e[0].toLowerCase()],r+e[0].length):-1}function gt(t,n,r){var e=Yt.exec(n.slice(r));return e?(t.w=Bt[e[0].toLowerCase()],r+e[0].length):-1}function yt(t,n,r){var e=Wt.exec(n.slice(r));return e?(t.m=Zt[e[0].toLowerCase()],r+e[0].length):-1}function _t(t,n,r){var e=Vt.exec(n.slice(r));return e?(t.m=Gt[e[0].toLowerCase()],r+e[0].length):-1}function bt(t,n,r){return o(t,zt,n,r)}function mt(t,n,r){return o(t,Pt,n,r)}function xt(t,n,r){return o(t,Dt,n,r)}function wt(t){return Ut[t.getDay()]}function Mt(t){return Rt[t.getDay()]}function kt(t){return Ot[t.getMonth()]}function Tt(t){return jt[t.getMonth()]}function Nt(t){return Lt[+(t.getHours()>=12)]}function At(t){return Ut[t.getUTCDay()]}function Et(t){return Rt[t.getUTCDay()]}function St(t){return Ot[t.getUTCMonth()]}function Ct(t){return jt[t.getUTCMonth()]}function qt(t){return Lt[+(t.getUTCHours()>=12)]}var zt=t.dateTime,Pt=t.date,Dt=t.time,Lt=t.periods,Rt=t.days,Ut=t.shortDays,jt=t.months,Ot=t.shortMonths,It=f(Lt),Ft=s(Lt),Yt=f(Rt),Bt=s(Rt),Ht=f(Ut),Xt=s(Ut),Vt=f(jt),Gt=s(jt),Wt=f(Ot),Zt=s(Ot),Qt={a:wt,A:Mt,b:kt,B:Tt,c:null,d:C,e:C,f:L,H:q,I:z,j:P,L:D,m:R,M:U,p:Nt,Q:lt,s:ht,S:j,u:O,U:I,V:F,w:Y,W:B,x:null,X:null,y:H,Y:X,Z:V,"%":st},$t={a:At,A:Et,b:St,B:Ct,c:null,d:G,e:G,f:J,H:W,I:Z,j:Q,L:$,m:K,M:tt,p:qt,Q:lt,s:ht,S:nt,u:rt,U:et,V:it,w:ut,W:at,x:null,X:null,y:ot,Y:ct,Z:ft,"%":st},Jt={a:vt,A:gt,b:yt,B:_t,c:bt,d:m,e:m,f:N,H:w,I:w,j:x,L:T,m:b,M:M,p:c,Q:E,s:S,S:k,u:h,U:d,V:p,w:l,W:v,x:mt,X:xt,y:y,Y:g,Z:_,"%":A};return Qt.x=n(Pt,Qt),Qt.X=n(Dt,Qt),Qt.c=n(zt,Qt),$t.x=n(Pt,$t),$t.X=n(Dt,$t),$t.c=n(zt,$t),{format:function(t){var r=n(t+="",Qt);return r.toString=function(){return t},r},parse:function(t){var n=a(t+="",e);return n.toString=function(){return t},n},utcFormat:function(t){var r=n(t+="",$t);return r.toString=function(){return t},r},utcParse:function(t){var n=a(t,i);return n.toString=function(){return t},n}}}function o(t,n,r){var e=t<0?"-":"",i=(e?-t:t)+"",u=i.length;return e+(u68?1900:2e3),r+e[0].length):-1}function _(t,n,r){var e=/^(Z)|([+-]\d\d)(?::?(\d\d))?/.exec(n.slice(r,r+6));return e?(t.Z=e[1]?0:-(e[2]+(e[3]||"00")),r+e[0].length):-1}function b(t,n,r){var e=vt.exec(n.slice(r,r+2));return e?(t.m=e[0]-1,r+e[0].length):-1}function m(t,n,r){var e=vt.exec(n.slice(r,r+2));return e?(t.d=+e[0],r+e[0].length):-1}function x(t,n,r){var e=vt.exec(n.slice(r,r+3));return e?(t.m=0,t.d=+e[0],r+e[0].length):-1}function w(t,n,r){var e=vt.exec(n.slice(r,r+2));return e?(t.H=+e[0],r+e[0].length):-1}function M(t,n,r){var e=vt.exec(n.slice(r,r+2));return e?(t.M=+e[0],r+e[0].length):-1}function k(t,n,r){var e=vt.exec(n.slice(r,r+2));return e?(t.S=+e[0],r+e[0].length):-1}function T(t,n,r){var e=vt.exec(n.slice(r,r+3));return e?(t.L=+e[0],r+e[0].length):-1}function N(t,n,r){var e=vt.exec(n.slice(r,r+6));return e?(t.L=Math.floor(e[0]/1e3),r+e[0].length):-1}function A(t,n,r){var e=gt.exec(n.slice(r,r+1));return e?r+e[0].length:-1}function E(t,n,r){var e=vt.exec(n.slice(r));return e?(t.Q=+e[0],r+e[0].length):-1}function S(t,n,r){var e=vt.exec(n.slice(r));return e?(t.Q=1e3*+e[0],r+e[0].length):-1}function C(t,n){return o(t.getDate(),n,2)}function q(t,n){return o(t.getHours(),n,2)}function z(t,n){return o(t.getHours()%12||12,n,2)}function P(t,n){return o(1+dt.n.count(r.i(dt.H)(t),t),n,3)}function D(t,n){return o(t.getMilliseconds(),n,3)}function L(t,n){return D(t,n)+"000"}function R(t,n){return o(t.getMonth()+1,n,2)}function U(t,n){return o(t.getMinutes(),n,2)}function j(t,n){return o(t.getSeconds(),n,2)}function O(t){var n=t.getDay();return 0===n?7:n}function I(t,n){return o(dt.r.count(r.i(dt.H)(t),t),n,2)}function F(t,n){var e=t.getDay();return t=e>=4||0===e?r.i(dt.z)(t):dt.z.ceil(t),o(dt.z.count(r.i(dt.H)(t),t)+(4===r.i(dt.H)(t).getDay()),n,2)}function Y(t){return t.getDay()}function B(t,n){return o(dt.t.count(r.i(dt.H)(t),t),n,2)}function H(t,n){return o(t.getFullYear()%100,n,2)}function X(t,n){return o(t.getFullYear()%1e4,n,4)}function V(t){var n=t.getTimezoneOffset();return(n>0?"-":(n*=-1,"+"))+o(n/60|0,"0",2)+o(n%60,"0",2)}function G(t,n){return o(t.getUTCDate(),n,2)}function W(t,n){return o(t.getUTCHours(),n,2)}function Z(t,n){return o(t.getUTCHours()%12||12,n,2)}function Q(t,n){return o(1+dt.N.count(r.i(dt._7)(t),t),n,3)}function $(t,n){return o(t.getUTCMilliseconds(),n,3)}function J(t,n){return $(t,n)+"000"}function K(t,n){return o(t.getUTCMonth()+1,n,2)}function tt(t,n){return o(t.getUTCMinutes(),n,2)}function nt(t,n){return o(t.getUTCSeconds(),n,2)}function rt(t){var n=t.getUTCDay();return 0===n?7:n}function et(t,n){return o(dt.R.count(r.i(dt._7)(t),t),n,2)}function it(t,n){var e=t.getUTCDay();return t=e>=4||0===e?r.i(dt.Z)(t):dt.Z.ceil(t),o(dt.Z.count(r.i(dt._7)(t),t)+(4===r.i(dt._7)(t).getUTCDay()),n,2)}function ut(t){return t.getUTCDay()}function at(t,n){return o(dt.T.count(r.i(dt._7)(t),t),n,2)}function ot(t,n){return o(t.getUTCFullYear()%100,n,2)}function ct(t,n){return o(t.getUTCFullYear()%1e4,n,4)}function ft(){return"+0000"}function st(){return"%"}function lt(t){return+t}function ht(t){return Math.floor(+t/1e3)}var dt=r(46);n.a=a;var pt={"-":"",_:" ",0:"0"},vt=/^\s*\d+/,gt=/^%/,yt=/[\\^$*+?|[\]().{}]/g},function(t,n,r){"use strict";var e=r(6);n.a=function(t,n){var r,i,u,a=t.__transition,o=!0;if(a){n=null==n?null:n+"";for(u in a)(r=a[u]).name===n?(i=r.state>e.a&&r.states.b||Math.abs(m-y)>s.b)&&(d.splice(h,0,s.d.push(r.i(f.b)(l,_,Math.abs(b-t)s.b?[t,Math.abs(g-t)s.b?[Math.abs(y-i)s.b?[e,Math.abs(g-e)s.b?[Math.abs(y-n)=-o.f)){var y=h*h+d*d,_=p*p+v*v,b=(v*y-d*_)/g,m=(h*_-p*y)/g,x=f.pop()||new e;x.arc=t,x.site=u,x.x=b+s,x.y=(x.cy=m+l)+Math.sqrt(b*b+m*m),t.circle=x;for(var w=null,M=o.g._;M;)if(x.y=n-t.span&&r.timestamp<=n}),i=this.ag.selectAll("line.annotation").data(r).attr("x1",function(n){return t.x(n.timestamp)}).attr("x2",function(n){return t.x(n.timestamp)});i.enter().append("line").classed("annotation",!0).attr("stroke",function(t){return"continued"===t.type?"rgba(0, 255, 0, 0.25)":"rgba(255, 0, 0, 0.25)"}).attr("stroke-width",1).attr("y1",0).attr("y2",this.height).attr("x1",function(n){return t.x(n.timestamp)}).attr("x2",function(n){return t.x(n.timestamp)}),i.exit().remove(),this.paths.forEach(function(r){try{var e=t.datasource.getData(r.graphId,n-t.span,n,!0);r.path.datum(e).attr("d",t.line)}catch(t){console.log("Error Updating Plot: ",t)}}),this.spaths.forEach(function(r){try{var e=t.datasource.sampleData(r.graphId,t.width,t.start,n);r.path.datum(e).attr("d",t.sline)}catch(t){console.log("Error Updating Plot: ",t)}});var u=n-this.span;u0){var r=this.points[this.points.length-1];this.points=this.points.filter(function(t){return t.timestamp>=n}),0===this.points.length&&this.points.push(r),this.path.datum(this.points).attr("d",this.line)}}catch(t){console.log("Error Updating Plot: ",t)}window.requestAnimationFrame(this.updateGraph.bind(this))},t}();n.XYGraph=i},function(t,n,r){"use strict";Object.defineProperty(n,"__esModule",{value:!0});var e=function(){function t(){this.data={},this.subscriptions={}}return t.prototype.receiveMessage=function(t){var n={timestamp:t.timestamp,value:t.data},r=t.id;this.data[r]||(this.data[r]=[]),this.data[r]&&this.data[r].push(n),this.subscriptions[r]&&this.subscriptions[r].forEach(function(t){return t(n)})},t.prototype.getData=function(t,n,r,e){void 0===e&&(e=!0);var i=this.data[t];if(!i)return[];if(i=i.filter(function(t){return t.timestamp>=n&&t.timestamp<=r}),e&&i.length>=1){var u=i[i.length-1];i.push({timestamp:r,value:u.value});var a=i[0];i.unshift({timestamp:n,value:a.value})}return i},t.prototype.sampleData=function(t,n,r,e){void 0===r&&(r=null),void 0===e&&(e=null);var i=this.data[t];if(!i)return[];if(null===r&&(r=0),null==e&&(e=(new Date).getTime()),i=i.filter(function(t){return t.timestamp>=r&&t.timestamp<=e}),i.length>1.5*n){var u=Math.round(i.length/n);i=i.filter(function(t,n){return n%u==0})}return i},t.prototype.subscribe=function(t,n){this.subscriptions[t]||(this.subscriptions[t]=[]),this.subscriptions[t].push(n)},t}();n.GraphDataSource=e},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";var e=r(97);n.a=function(t,n,r){var i,u,a,o,c=t.length,f=n.length,s=new Array(c*f);for(null==r&&(r=e.b),i=a=0;it?1:n>=t?0:NaN}},function(t,n,r){"use strict";var e=r(91),i=r(92),u=r(175),a=r(95),o=r(179),c=r(98),f=r(100),s=r(99);n.a=function(){function t(t){var e,u,a=t.length,o=new Array(a);for(e=0;ep;)v.pop(),--g;var y,_=new Array(g+1);for(e=0;e<=g;++e)y=_[e]=[],y.x0=e>0?v[e-1]:d,y.x1=e=r)for(e=r;++ue&&(e=r)}else for(;++u=r)for(e=r;++ue&&(e=r);return e}},function(t,n,r){"use strict";var e=r(21);n.a=function(t,n){var i,u=t.length,a=u,o=-1,c=0;if(null==n)for(;++o=0;)for(e=t[i],n=e.length;--n>=0;)r[--a]=e[n];return r}},function(t,n,r){"use strict";n.a=function(t,n){for(var r=n.length,e=new Array(r);r--;)e[r]=t[n[r]];return e}},function(t,n,r){"use strict";var e=r(17);n.a=function(t,n){if(r=t.length){var r,i,u=0,a=0,o=t[a];for(null==n&&(n=e.a);++uMath.abs(t[1]-nt[1])?I=!0:O=!0),nt=t,j=!0,r.i(b.a)(),e()}function e(){var t;switch(R=nt[0]-tt[0],U=nt[1]-tt[1],B){case x:case m:H&&(R=Math.max(Z-l,Math.min($-_,R)),h=l+R,N=_+R),X&&(U=Math.max(Q-p,Math.min(J-P,U)),y=p+U,L=P+U);break;case w:H<0?(R=Math.max(Z-l,Math.min($-l,R)),h=l+R,N=_):H>0&&(R=Math.max(Z-_,Math.min($-_,R)),h=l,N=_+R),X<0?(U=Math.max(Q-p,Math.min(J-p,U)),y=p+U,L=P):X>0&&(U=Math.max(Q-P,Math.min(J-P,U)),y=p,L=P+U);break;case M:H&&(h=Math.max(Z,Math.min($,l-R*H)),N=Math.max(Z,Math.min($,_+R*H))),X&&(y=Math.max(Q,Math.min(J,p-U*X)),L=Math.max(Q,Math.min(J,P+U*X)))}N0&&(l=h-R),X<0?P=L-U:X>0&&(p=y-U),B=x,it.attr("cursor",A.selection),e());break;default:return}r.i(b.a)()}function s(){switch(v.q.keyCode){case 16:K&&(O=I=K=!1,e());break;case 18:B===M&&(H<0?_=N:H>0&&(l=h),X<0?P=L:X>0&&(p=y),B=w,e());break;case 32:B===x&&(v.q.altKey?(H&&(_=N-R*H,l=h+R*H),X&&(P=L-U*X,p=y+U*X),B=M):(H<0?_=N:H>0&&(l=h),X<0?P=L:X>0&&(p=y),B=w),it.attr("cursor",A[Y]),e());break;default:return}r.i(b.a)()}if(v.q.touches){if(v.q.changedTouches.length=l.length)return null!=c&&n.sort(c),null!=f?f(n):n;for(var a,s,h,d=-1,p=n.length,v=l[e++],g=r.i(o.a)(),y=i();++dl.length)return t;var e,i=h[r-1];return null!=f&&r>=l.length?e=t.entries():(e=[],t.each(function(t,i){e.push({key:i,values:n(t,r)})})),null!=i?e.sort(function(t,n){return i(t.key,n.key)}):e}var c,f,s,l=[],h=[];return s={object:function(n){return t(n,0,e,i)},map:function(n){return t(n,0,u,a)},entries:function(r){return n(t(r,0,u,a),0)},key:function(t){return l.push(t),s},sortKeys:function(t){return h[l.length-1]=t,s},sortValues:function(t){return c=t,s},rollup:function(t){return f=t,s}}}},function(t,n,r){"use strict";function e(){}function i(t,n){var r=new e;if(t instanceof e)t.each(function(t){r.add(t)});else if(t){var i=-1,u=t.length;if(null==n)for(;++iM?Math.pow(t,1/3):t/w+m}function o(t){return t>x?t*t*t:w*(t-m)}function c(t){return 255*(t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055)}function f(t){return(t/=255)<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}function s(t){if(t instanceof h)return new h(t.h,t.c,t.l,t.opacity);t instanceof u||(t=e(t));var n=Math.atan2(t.b,t.a)*v.a;return new h(n<0?n+360:n,Math.sqrt(t.a*t.a+t.b*t.b),t.l,t.opacity)}function l(t,n,r,e){return 1===arguments.length?s(t):new h(t,n,r,null==e?1:e)}function h(t,n,r,e){this.h=+t,this.c=+n,this.l=+r,this.opacity=+e}var d=r(53),p=r(52),v=r(104);n.a=i,n.b=l;var g=18,y=.95047,_=1,b=1.08883,m=4/29,x=6/29,w=3*x*x,M=x*x*x;r.i(d.a)(u,i,r.i(d.b)(p.f,{brighter:function(t){return new u(this.l+g*(null==t?1:t),this.a,this.b,this.opacity)},darker:function(t){return new u(this.l-g*(null==t?1:t),this.a,this.b,this.opacity)},rgb:function(){var t=(this.l+16)/116,n=isNaN(this.a)?t:t+this.a/500,r=isNaN(this.b)?t:t-this.b/200;return t=_*o(t),n=y*o(n),r=b*o(r),new p.d(c(3.2404542*n-1.5371385*t-.4985314*r),c(-.969266*n+1.8760108*t+.041556*r),c(.0556434*n-.2040259*t+1.0572252*r),this.opacity)}})),r.i(d.a)(h,l,r.i(d.b)(p.f,{brighter:function(t){return new h(this.h,this.c,this.l+g*(null==t?1:t),this.opacity)},darker:function(t){return new h(this.h,this.c,this.l-g*(null==t?1:t),this.opacity)},rgb:function(){return e(this).rgb()}}))},function(t,n,r){"use strict";function e(){for(var t,n=0,r=arguments.length,e={};n=0&&(r=t.slice(e+1),t=t.slice(0,e)),t&&!n.hasOwnProperty(t))throw new Error("unknown type: "+t);return{type:t,name:r}})}function a(t,n){for(var r,e=0,i=t.length;e0)for(var r,e,i=new Array(r),u=0;uC}A.mouse("drag")}function p(){r.i(c.h)(c.q.view).on("mousemove.drag mouseup.drag",null),r.i(f.b)(c.q.view,x),r.i(s.a)(),A.mouse("end")}function v(){if(M.apply(this,arguments)){var t,n,e=c.q.changedTouches,i=k.apply(this,arguments),u=e.length;for(t=0;tp+s||iv+s||uf.index){var l=p-o.x-o.vx,d=v-o.y-o.vy,_=l*l+d*d;_t.r&&(t.r=t[n].r)}function f(){if(s){var n,r,e=s.length;for(l=new Array(e),n=0;n=v)){(t.data!==s||t.next)&&(0===a&&(a=r.i(i.a)(),f+=a*a),0===o&&(o=r.i(i.a)(),f+=o*o),f0&&(u=0)}return u>0?t.slice(0,u)+t.slice(r+1):t}},function(t,n,r){"use strict";n.a=function(t,n){return function(r,e){for(var i=r.length,u=[],a=0,o=t[0],c=0;i>0&&o>0&&(c+o+1>e&&(o=Math.max(1,e-c)),u.push(r.substring(i-=o,i+o)),!((c+=o+1)>e));)o=t[a=(a+1)%t.length];return u.reverse().join(n)}}},function(t,n,r){"use strict";n.a=function(t){return function(n){return n.replace(/[0-9]/g,function(n){return t[+n]})}}},function(t,n,r){"use strict";var e=r(59);n.a=function(t,n){var i=r.i(e.a)(t,n);if(!i)return t+"";var u=i[0],a=i[1];return a<0?"0."+new Array(-a).join("0")+u:u.length>a+1?u.slice(0,a+1)+"."+u.slice(a+1):u+new Array(a-u.length+2).join("0")}},function(t,n,r){"use strict";n.a=function(t){return t}},function(t,n,r){"use strict";var e=r(33);n.a=function(t){return Math.max(0,-r.i(e.a)(Math.abs(t)))}},function(t,n,r){"use strict";var e=r(33);n.a=function(t,n){return Math.max(0,3*Math.max(-8,Math.min(8,Math.floor(r.i(e.a)(n)/3)))-r.i(e.a)(Math.abs(t)))}},function(t,n,r){"use strict";var e=r(33);n.a=function(t,n){return t=Math.abs(t),n=Math.abs(n)-t,Math.max(0,r.i(e.a)(n)-r.i(e.a)(t))+1}},function(t,n,r){"use strict";var e=r(113);r.d(n,"a",function(){return e.a});var i=r(246);r.d(n,"b",function(){return i.a});var u=r(247);r.d(n,"c",function(){return u.a});var a=r(114);r.d(n,"d",function(){return a.a});var o=r(115);r.d(n,"e",function(){return o.a});var c=r(117);r.d(n,"f",function(){return c.a});var f=r(248);r.d(n,"g",function(){return f.a});var s=r(34);r.d(n,"h",function(){return s.a});var l=r(251);r.d(n,"i",function(){return l.a});var h=r(121);r.d(n,"j",function(){return h.a});var d=r(252);r.d(n,"k",function(){return d.a}),r.d(n,"l",function(){return d.b});var p=r(253);r.d(n,"m",function(){return p.a});var v=r(122);r.d(n,"n",function(){return v.a});var g=r(257);r.d(n,"o",function(){return g.a});var y=r(126);r.d(n,"p",function(){return y.a});var _=r(260);r.d(n,"q",function(){return _.a});var b=r(261);r.d(n,"r",function(){return b.a}),r.d(n,"s",function(){return b.b});var m=r(262);r.d(n,"t",function(){return m.a}),r.d(n,"u",function(){return m.b});var x=r(263);r.d(n,"v",function(){return x.a}),r.d(n,"w",function(){return x.b});var w=r(62);r.d(n,"x",function(){return w.a}),r.d(n,"y",function(){return w.b});var M=r(264);r.d(n,"z",function(){return M.a}),r.d(n,"A",function(){return M.b});var k=r(127);r.d(n,"B",function(){return k.a}),r.d(n,"C",function(){return k.b});var T=r(266);r.d(n,"D",function(){return T.a}),r.d(n,"E",function(){return T.b});var N=r(267);r.d(n,"F",function(){return N.a});var A=r(8);r.d(n,"G",function(){return A.a}),r.d(n,"H",function(){return A.b});var E=r(64);r.d(n,"I",function(){return E.a}),r.d(n,"J",function(){return E.b});var S=r(268);r.d(n,"K",function(){return S.a}),r.d(n,"L",function(){return S.b});var C=r(269);r.d(n,"M",function(){return C.a}),r.d(n,"N",function(){return C.b});var q=r(271);r.d(n,"O",function(){return q.a}),r.d(n,"P",function(){return q.b});var z=r(272);r.d(n,"Q",function(){return z.a}),r.d(n,"R",function(){return z.b});var P=r(35);r.d(n,"S",function(){return P.a});var D=r(13);r.d(n,"T",function(){return D.a});var L=r(36);r.d(n,"U",function(){return L.a})},function(t,n,r){"use strict";function e(t,n){x.push(w=[d=t,v=t]),ng&&(g=n)}function i(t,n){var e=r.i(T.a)([t*N.g,n*N.g]);if(m){var i=r.i(T.b)(m,e),u=[i[1],-i[0],0],a=r.i(T.b)(u,i);r.i(T.c)(a),a=r.i(T.g)(a);var o,c=t-y,f=c>0?1:-1,l=a[0]*N.h*f,h=r.i(N.p)(c)>180;h^(f*yg&&(g=o):(l=(l+360)%360-180,h^(f*yg&&(g=n))),h?ts(d,v)&&(v=t):s(t,v)>s(d,v)&&(d=t):v>=d?(tv&&(v=t)):t>y?s(d,t)>s(d,v)&&(v=t):s(t,v)>s(d,v)&&(d=t)}else x.push(w=[d=t,v=t]);ng&&(g=n),m=e,y=t}function u(){S.point=i}function a(){w[0]=d,w[1]=v,S.point=e,m=null}function o(t,n){if(m){var e=t-y;E.add(r.i(N.p)(e)>180?e+(e>0?360:-360):e)}else _=t,b=n;k.b.point(t,n),i(t,n)}function c(){k.b.lineStart()}function f(){o(_,b),k.b.lineEnd(),r.i(N.p)(E)>N.o&&(d=-(v=180)),w[0]=d,w[1]=v,m=null}function s(t,n){return(n-=t)<0?n+360:n}function l(t,n){return t[0]-n[0]}function h(t,n){return t[0]<=t[1]?t[0]<=n&&n<=t[1]:nN.o?g=90:E<-N.o&&(p=-90),w[0]=d,w[1]=v}};n.a=function(t){var n,e,i,u,a,o,c;if(g=v=-(d=p=1/0),x=[],r.i(A.a)(t,S),e=x.length){for(x.sort(l),n=1,i=x[0],a=[i];ns(i[0],i[1])&&(i[1]=u[1]),s(u[0],i[1])>s(i[0],i[1])&&(i[0]=u[0])):a.push(i=u);for(o=-1/0,e=a.length-1,n=0,i=a[e];n<=e;i=u,++n)u=a[n],(c=s(i[1],u[0]))>o&&(o=c,d=u[0],v=i[1])}return x=w=null,d===1/0||p===1/0?[[NaN,NaN],[NaN,NaN]]:[[d,p],[v,g]]}},function(t,n,r){"use strict";function e(t,n){t*=S.g,n*=S.g;var e=r.i(S.c)(n);i(e*r.i(S.c)(t),e*r.i(S.d)(t),r.i(S.d)(n))}function i(t,n,r){++d,v+=(t-v)/d,g+=(n-g)/d,y+=(r-y)/d}function u(){z.point=a}function a(t,n){t*=S.g,n*=S.g;var e=r.i(S.c)(n);N=e*r.i(S.c)(t),A=e*r.i(S.d)(t),E=r.i(S.d)(n),z.point=o,i(N,A,E)}function o(t,n){t*=S.g,n*=S.g;var e=r.i(S.c)(n),u=e*r.i(S.c)(t),a=e*r.i(S.d)(t),o=r.i(S.d)(n),c=r.i(S.e)(r.i(S.n)((c=A*o-E*a)*c+(c=E*u-N*o)*c+(c=N*a-A*u)*c),N*u+A*a+E*o);p+=c,_+=c*(N+(N=u)),b+=c*(A+(A=a)),m+=c*(E+(E=o)),i(N,A,E)}function c(){z.point=e}function f(){z.point=l}function s(){h(k,T),z.point=e}function l(t,n){k=t,T=n,t*=S.g,n*=S.g,z.point=h;var e=r.i(S.c)(n);N=e*r.i(S.c)(t),A=e*r.i(S.d)(t),E=r.i(S.d)(n),i(N,A,E)}function h(t,n){t*=S.g,n*=S.g;var e=r.i(S.c)(n),u=e*r.i(S.c)(t),a=e*r.i(S.d)(t),o=r.i(S.d)(n),c=A*o-E*a,f=E*u-N*o,s=N*a-A*u,l=r.i(S.n)(c*c+f*f+s*s),h=r.i(S.f)(l),d=l&&-h/l;x+=d*c,w+=d*f,M+=d*s,p+=h,_+=h*(N+(N=u)),b+=h*(A+(A=a)),m+=h*(E+(E=o)),i(N,A,E)}var d,p,v,g,y,_,b,m,x,w,M,k,T,N,A,E,S=r(0),C=r(10),q=r(13),z={sphere:C.a,point:e,lineStart:u,lineEnd:c,polygonStart:function(){z.lineStart=f,z.lineEnd=s},polygonEnd:function(){z.lineStart=u,z.lineEnd=c}};n.a=function(t){d=p=v=g=y=_=b=m=x=w=M=0,r.i(q.a)(t,z);var n=x,e=w,i=M,u=n*n+e*e+i*i;return u0)){if(a/=d,d<0){if(a0){if(a>h)return;a>l&&(l=a)}if(a=i-o,d||!(a<0)){if(a/=d,d<0){if(a>h)return;a>l&&(l=a)}else if(d>0){if(a0)){if(a/=p,p<0){if(a0){if(a>h)return;a>l&&(l=a)}if(a=u-c,p||!(a<0)){if(a/=p,p<0){if(a>h)return;a>l&&(l=a)}else if(p>0){if(a0&&(t[0]=o+l*d,t[1]=c+l*p),h<1&&(n[0]=o+h*d,n[1]=c+h*p),!0}}}}}},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(t,n){return!(!t||!d.hasOwnProperty(t.type))&&d[t.type](t,n)}function i(t,n){return 0===r.i(s.a)(t,n)}function u(t,n){var e=r.i(s.a)(t[0],t[1]);return r.i(s.a)(t[0],n)+r.i(s.a)(n,t[1])<=e+l.o}function a(t,n){return!!r.i(f.a)(t.map(o),c(n))}function o(t){return t=t.map(c),t.pop(),t}function c(t){return[t[0]*l.g,t[1]*l.g]}var f=r(125),s=r(121),l=r(0),h={Feature:function(t,n){return e(t.geometry,n)},FeatureCollection:function(t,n){for(var r=t.features,i=-1,u=r.length;++ic.o}).map(v)).concat(r.i(o.v)(r.i(c.u)(h/m)*m,l,m).filter(function(t){return r.i(c.p)(t%w)>c.o}).map(g))}var u,a,f,s,l,h,d,p,v,g,y,_,b=10,m=b,x=90,w=360,M=2.5;return t.lines=function(){return n().map(function(t){return{type:"LineString",coordinates:t}})},t.outline=function(){return{type:"Polygon",coordinates:[y(s).concat(_(d).slice(1),y(f).reverse().slice(1),_(p).reverse().slice(1))]}},t.extent=function(n){return arguments.length?t.extentMajor(n).extentMinor(n):t.extentMinor()},t.extentMajor=function(n){return arguments.length?(s=+n[0][0],f=+n[1][0],p=+n[0][1],d=+n[1][1],s>f&&(n=s,s=f,f=n),p>d&&(n=p,p=d,d=n),t.precision(M)):[[s,p],[f,d]]},t.extentMinor=function(n){return arguments.length?(a=+n[0][0],u=+n[1][0],h=+n[0][1],l=+n[1][1],a>u&&(n=a,a=u,u=n),h>l&&(n=h,h=l,l=n),t.precision(M)):[[a,h],[u,l]]},t.step=function(n){return arguments.length?t.stepMajor(n).stepMinor(n):t.stepMinor()},t.stepMajor=function(n){return arguments.length?(x=+n[0],w=+n[1],t):[x,w]},t.stepMinor=function(n){return arguments.length?(b=+n[0],m=+n[1],t):[b,m]},t.precision=function(n){return arguments.length?(M=+n,v=e(h,l,90),g=i(a,u,M),y=e(p,d,90),_=i(s,f,M),t):M},t.extentMajor([[-180,-90+c.o],[180,90-c.o]]).extentMinor([[-180,-80-c.o],[180,80+c.o]])}function a(){return u()()}var o=r(3),c=r(0);n.a=u,n.b=a},function(t,n,r){"use strict";var e=r(0);n.a=function(t,n){var i=t[0]*e.g,u=t[1]*e.g,a=n[0]*e.g,o=n[1]*e.g,c=r.i(e.c)(u),f=r.i(e.d)(u),s=r.i(e.c)(o),l=r.i(e.d)(o),h=c*r.i(e.c)(i),d=c*r.i(e.d)(i),p=s*r.i(e.c)(a),v=s*r.i(e.d)(a),g=2*r.i(e.f)(r.i(e.n)(r.i(e.t)(o-u)+c*s*r.i(e.t)(a-i))),y=r.i(e.d)(g),_=g?function(t){var n=r.i(e.d)(t*=g)/y,i=r.i(e.d)(g-t)/y,u=i*h+n*p,a=i*d+n*v,o=i*f+n*l;return[r.i(e.e)(a,u)*e.h,r.i(e.e)(o,r.i(e.n)(u*u+a*a))*e.h]}:function(){return[i*e.h,u*e.h]};return _.distance=g,_}},function(t,n,r){"use strict";function e(){g.point=i}function i(t,n){g.point=u,o=f=t,c=s=n}function u(t,n){v.add(s*t-f*n),f=t,s=n}function a(){u(o,c)}var o,c,f,s,l=r(19),h=r(0),d=r(10),p=r.i(l.a)(),v=r.i(l.a)(),g={point:d.a,lineStart:d.a,lineEnd:d.a,polygonStart:function(){g.lineStart=e,g.lineEnd=a},polygonEnd:function(){g.lineStart=g.lineEnd=g.point=d.a,p.add(r.i(h.p)(v)),v.reset()},result:function(){var t=p/2;return p.reset(),t}};n.a=g},function(t,n,r){"use strict";function e(t,n){y+=t,_+=n,++b}function i(){N.point=u}function u(t,n){N.point=a,e(p=t,v=n)}function a(t,n){var i=t-p,u=n-v,a=r.i(g.n)(i*i+u*u);m+=a*(p+t)/2,x+=a*(v+n)/2,w+=a,e(p=t,v=n)}function o(){N.point=e}function c(){N.point=s}function f(){l(h,d)}function s(t,n){N.point=l,e(h=p=t,d=v=n)}function l(t,n){var i=t-p,u=n-v,a=r.i(g.n)(i*i+u*u);m+=a*(p+t)/2,x+=a*(v+n)/2,w+=a,a=v*t-p*n,M+=a*(p+t),k+=a*(v+n),T+=3*a,e(p=t,v=n)}var h,d,p,v,g=r(0),y=0,_=0,b=0,m=0,x=0,w=0,M=0,k=0,T=0,N={point:e,lineStart:i,lineEnd:o,polygonStart:function(){N.lineStart=c,N.lineEnd=f},polygonEnd:function(){N.point=e,N.lineStart=i,N.lineEnd=o},result:function(){var t=T?[M/T,k/T]:w?[m/w,x/w]:b?[y/b,_/b]:[NaN,NaN];return y=_=b=m=x=w=M=k=T=0,t}};n.a=N},function(t,n,r){"use strict";function e(t){this._context=t}var i=r(0),u=r(10);n.a=e,e.prototype={_radius:4.5,pointRadius:function(t){return this._radius=t,this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._context.closePath(),this._point=NaN},point:function(t,n){switch(this._point){case 0:this._context.moveTo(t,n),this._point=1;break;case 1:this._context.lineTo(t,n);break;default:this._context.moveTo(t+this._radius,n),this._context.arc(t,n,this._radius,0,i.b)}},result:u.a}},function(t,n,r){"use strict";var e=r(60),i=r(13),u=r(254),a=r(123),o=r(255),c=r(256),f=r(258),s=r(259);n.a=function(t,n){function l(t){return t&&("function"==typeof p&&d.pointRadius(+p.apply(this,arguments)),r.i(i.a)(t,h(d))),d.result()}var h,d,p=4.5;return l.area=function(t){return r.i(i.a)(t,h(u.a)),u.a.result()},l.measure=function(t){return r.i(i.a)(t,h(f.a)),f.a.result()},l.bounds=function(t){return r.i(i.a)(t,h(a.a)),a.a.result()},l.centroid=function(t){return r.i(i.a)(t,h(o.a)),o.a.result()},l.projection=function(n){return arguments.length?(h=null==n?(t=null,e.a):(t=n).stream,l):t},l.context=function(t){return arguments.length?(d=null==t?(n=null,new s.a):new c.a(n=t),"function"!=typeof p&&d.pointRadius(p),l):n},l.pointRadius=function(t){return arguments.length?(p="function"==typeof t?t:(d.pointRadius(+t),+t),l):p},l.projection(t).context(n)}},function(t,n,r){"use strict";function e(t,n){p.point=i,a=c=t,o=f=n}function i(t,n){c-=t,f-=n,d.add(r.i(l.n)(c*c+f*f)),c=t,f=n}var u,a,o,c,f,s=r(19),l=r(0),h=r(10),d=r.i(s.a)(),p={point:h.a,lineStart:function(){p.point=e},lineEnd:function(){u&&i(a,o),p.point=h.a},polygonStart:function(){u=!0},polygonEnd:function(){u=null},result:function(){var t=+d;return d.reset(),t}};n.a=p},function(t,n,r){"use strict";function e(){this._string=[]}function i(t){return"m0,"+t+"a"+t+","+t+" 0 1,1 0,"+-2*t+"a"+t+","+t+" 0 1,1 0,"+2*t+"z"}n.a=e,e.prototype={_radius:4.5,_circle:i(4.5),pointRadius:function(t){return(t=+t)!==this._radius&&(this._radius=t,this._circle=null),this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){0===this._line&&this._string.push("Z"),this._point=NaN},point:function(t,n){switch(this._point){case 0:this._string.push("M",t,",",n),this._point=1;break;case 1:this._string.push("L",t,",",n);break;default:null==this._circle&&(this._circle=i(this._radius)),this._string.push("M",t,",",n,this._circle)}},result:function(){if(this._string.length){var t=this._string.join("");return this._string=[],t}return null}}},function(t,n,r){"use strict";function e(t){var n=t.length;return{point:function(r,e){for(var i=-1;++i=.12&&i<.234&&e>=-.425&&e<-.214?v:i>=.166&&i<.234&&e>=-.214&&e<-.115?g:p).invert(t)},t.stream=function(t){return c&&f===t?c:c=e([p.stream(f=t),v.stream(t),g.stream(t)])},t.precision=function(t){return arguments.length?(p.precision(t),v.precision(t),g.precision(t),n()):p.precision()},t.scale=function(n){return arguments.length?(p.scale(n),v.scale(.35*n),g.scale(n),t.translate(p.translate())):p.scale()},t.translate=function(t){if(!arguments.length)return p.translate();var r=p.scale(),e=+t[0],u=+t[1];return s=p.translate(t).clipExtent([[e-.455*r,u-.238*r],[e+.455*r,u+.238*r]]).stream(y),l=v.translate([e-.307*r,u+.201*r]).clipExtent([[e-.425*r+i.o,u+.12*r+i.o],[e-.214*r-i.o,u+.234*r-i.o]]).stream(y),h=g.translate([e-.205*r,u+.212*r]).clipExtent([[e-.214*r+i.o,u+.166*r+i.o],[e-.115*r-i.o,u+.234*r-i.o]]).stream(y),n()},t.fitExtent=function(n,e){return r.i(o.a)(t,n,e)},t.fitSize=function(n,e){return r.i(o.b)(t,n,e)},t.fitWidth=function(n,e){return r.i(o.c)(t,n,e)},t.fitHeight=function(n,e){return r.i(o.d)(t,n,e)},t.scale(1070)}},function(t,n,r){"use strict";var e=r(0),i=r(24),u=r(8);r.d(n,"b",function(){return a});var a=r.i(i.b)(function(t){return r.i(e.n)(2/(1+t))});a.invert=r.i(i.a)(function(t){return 2*r.i(e.f)(t/2)}),n.a=function(){return r.i(u.a)(a).scale(124.75).clipAngle(179.999)}},function(t,n,r){"use strict";var e=r(0),i=r(24),u=r(8);r.d(n,"b",function(){return a});var a=r.i(i.b)(function(t){return(t=r.i(e.s)(t))&&t/r.i(e.d)(t)});a.invert=r.i(i.a)(function(t){return t}),n.a=function(){return r.i(u.a)(a).scale(79.4188).clipAngle(179.999)}},function(t,n,r){"use strict";function e(t){return r.i(u.j)((u.k+t)/2)}function i(t,n){function i(t,n){f>0?n<-u.k+u.o&&(n=-u.k+u.o):n>u.k-u.o&&(n=u.k-u.o);var i=f/r.i(u.r)(e(n),c);return[i*r.i(u.d)(c*t),f-i*r.i(u.c)(c*t)]}var a=r.i(u.c)(t),c=t===n?r.i(u.d)(t):r.i(u.i)(a/r.i(u.c)(n))/r.i(u.i)(e(n)/e(t)),f=a*r.i(u.r)(e(t),c)/c;return c?(i.invert=function(t,n){var e=f-n,i=r.i(u.q)(c)*r.i(u.n)(t*t+e*e);return[r.i(u.e)(t,r.i(u.p)(e))/c*r.i(u.q)(e),2*r.i(u.l)(r.i(u.r)(f/i,1/c))-u.k]},i):o.b}var u=r(0),a=r(61),o=r(64);n.b=i,n.a=function(){return r.i(a.a)(i).scale(109.5).parallels([30,30])}},function(t,n,r){"use strict";function e(t,n){function e(t,n){var e=c-n,u=o*t;return[e*r.i(i.d)(u),c-e*r.i(i.c)(u)]}var u=r.i(i.c)(t),o=t===n?r.i(i.d)(t):(u-r.i(i.c)(n))/(n-t),c=u/o+t;return r.i(i.p)(o)u.o&&--a>0);return[t/(.8707+(o=i*i)*(o*(o*o*o*(.003971-.001529*o)-.013791)-.131979)),i]},n.a=function(){return r.i(i.a)(e).scale(175.295)}},function(t,n,r){"use strict";function e(t,n){return[r.i(i.c)(n)*r.i(i.d)(t),r.i(i.d)(n)]}var i=r(0),u=r(24),a=r(8);n.b=e,e.invert=r.i(u.a)(i.f),n.a=function(){return r.i(a.a)(e).scale(249.5).clipAngle(90+i.o)}},function(t,n,r){"use strict";function e(t){return r.i(o.b)({point:function(n,r){n=t(n,r),this.stream.point(n[0],n[1])}})}function i(t,n){function e(i,u,o,c,s,l,h,d,p,v,g,y,_,b){var m=h-i,x=d-u,w=m*m+x*x;if(w>4*n&&_--){var M=c+v,k=s+g,T=l+y,N=r.i(a.n)(M*M+k*k+T*T),A=r.i(a.f)(T/=N),E=r.i(a.p)(r.i(a.p)(T)-1)n||r.i(a.p)((m*z+x*P)/w-.5)>.3||c*v+s*g+l*y2?t[2]+90:90]):(t=i(),[t[0],t[1],t[2]-90])},i([0,0,90]).scale(159.155)}},function(t,n,r){"use strict";var e=r(275);r.d(n,"a",function(){return e.a});var i=r(66);r.d(n,"b",function(){return i.a});var u=r(287);r.d(n,"c",function(){return u.a});var a=r(130);r.d(n,"d",function(){return a.a});var o=r(129);r.d(n,"e",function(){return o.a});var c=r(288);r.d(n,"f",function(){return c.a});var f=r(289);r.d(n,"g",function(){return f.a});var s=r(290);r.d(n,"h",function(){return s.a});var l=r(292);r.d(n,"i",function(){return l.a});var h=r(291);r.d(n,"j",function(){return h.a});var d=r(25);r.d(n,"k",function(){return d.a});var p=r(37);r.d(n,"l",function(){return p.a});var v=r(294);r.d(n,"m",function(){return v.a});var g=r(67);r.d(n,"n",function(){return g.a});var y=r(293);r.d(n,"o",function(){return y.a})},function(t,n,r){"use strict";function e(t){for(var n,r,e=t.length;e;)r=Math.random()*e--|0,n=t[e],t[e]=t[r],t[r]=n;return t}r.d(n,"b",function(){return i}),n.a=e;var i=Array.prototype.slice},function(t,n,r){"use strict";function e(t,n){return t.parent===n.parent?1:2}function i(t){return t.reduce(u,0)/t.length}function u(t,n){return t+n.x}function a(t){return 1+t.reduce(o,0)}function o(t,n){return Math.max(t,n.y)}function c(t){for(var n;n=t.children;)t=n[0];return t}function f(t){for(var n;n=t.children;)t=n[n.length-1];return t}n.a=function(){function t(t){var e,s=0;t.eachAfter(function(t){var r=t.children;r?(t.x=i(r),t.y=a(r)):(t.x=e?s+=n(t,e):0,t.y=0,e=t)});var l=c(t),h=f(t),d=l.x-n(l,h)/2,p=h.x+n(h,l)/2;return t.eachAfter(o?function(n){n.x=(n.x-t.x)*r,n.y=(t.y-n.y)*u}:function(n){n.x=(n.x-d)/(p-d)*r,n.y=(1-(t.y?n.y/t.y:1))*u})}var n=e,r=1,u=1,o=!1;return t.separation=function(r){return arguments.length?(n=r,t):n},t.size=function(n){return arguments.length?(o=!1,r=+n[0],u=+n[1],t):o?null:[r,u]},t.nodeSize=function(n){return arguments.length?(o=!0,r=+n[0],u=+n[1],t):o?[r,u]:null},t}},function(t,n,r){"use strict";n.a=function(){for(var t=this,n=[t];t=t.parent;)n.push(t);return n}},function(t,n,r){"use strict";function e(t){var n=0,r=t.children,e=r&&r.length;if(e)for(;--e>=0;)n+=r[e].value;else n=1;t.value=n}n.a=function(){return this.eachAfter(e)}},function(t,n,r){"use strict";n.a=function(){var t=[];return this.each(function(n){t.push(n)}),t}},function(t,n,r){"use strict";n.a=function(t){var n,r,e,i,u=this,a=[u];do{for(n=a.reverse(),a=[];u=n.pop();)if(t(u),r=u.children)for(e=0,i=r.length;e=0;--r)i.push(n[r]);return this}},function(t,n,r){"use strict";n.a=function(){var t=[];return this.eachBefore(function(n){n.children||t.push(n)}),t}},function(t,n,r){"use strict";n.a=function(){var t=this,n=[];return t.each(function(r){r!==t&&n.push({source:r.parent,target:r})}),n}},function(t,n,r){"use strict";function e(t,n){if(t===n)return t;var r=t.ancestors(),e=n.ancestors(),i=null;for(t=r.pop(),n=e.pop();t===n;)i=t,t=r.pop(),n=e.pop();return i}n.a=function(t){for(var n=this,r=e(n,t),i=[n];n!==r;)n=n.parent,i.push(n);for(var u=i.length;t!==r;)i.splice(u,0,t),t=t.parent;return i}},function(t,n,r){"use strict";n.a=function(t){return this.eachBefore(function(n){n.children&&n.children.sort(t)})}},function(t,n,r){"use strict";n.a=function(t){return this.eachAfter(function(n){for(var r=+t(n.data)||0,e=n.children,i=e&&e.length;--i>=0;)r+=e[i].value;n.value=r})}},function(t,n,r){"use strict";function e(t){return Math.sqrt(t.value)}function i(t){return function(n){n.children||(n.r=Math.max(0,+t(n)||0))}}function u(t,n){return function(e){if(i=e.children){var i,u,a,c=i.length,f=t(e)*n||0;if(f)for(u=0;u0)throw new Error("cycle");return i}var n=e,s=i;return t.id=function(e){return arguments.length?(n=r.i(u.a)(e),t):n},t.parentId=function(n){return arguments.length?(s=r.i(u.a)(n),t):s},t}},function(t,n,r){"use strict";function e(t,n){return t.parent===n.parent?1:2}function i(t){var n=t.children;return n?n[0]:t.t}function u(t){var n=t.children;return n?n[n.length-1]:t.t}function a(t,n,r){var e=r/(n.i-t.i);n.c-=e,n.s+=r,t.c+=e,n.z+=r,n.m+=r}function o(t){for(var n,r=0,e=0,i=t.children,u=i.length;--u>=0;)n=i[u],n.z+=r,n.m+=r,r+=n.s+(e+=n.c)}function c(t,n,r){return t.a.parent===n.parent?t.a:r}function f(t,n){this._=t,this.parent=null,this.children=null,this.A=null,this.a=this,this.z=0,this.m=0,this.c=0,this.s=0,this.t=null,this.i=n}function s(t){for(var n,r,e,i,u,a=new f(t,0),o=[a];n=o.pop();)if(e=n._.children)for(n.children=new Array(u=e.length),i=u-1;i>=0;--i)o.push(r=n.children[i]=new f(e[i],i)),r.parent=n;return(a.parent=new f(null,0)).children=[a],a}var l=r(66);f.prototype=Object.create(l.b.prototype),n.a=function(){function t(t){var e=s(t);if(e.eachAfter(n),e.parent.m=-e.z,e.eachBefore(r),v)t.eachBefore(l);else{var i=t,u=t,a=t;t.eachBefore(function(t){t.xu.x&&(u=t),t.depth>a.depth&&(a=t)});var o=i===u?1:h(i,u)/2,c=o-i.x,f=d/(u.x+o+c),g=p/(a.depth||1);t.eachBefore(function(t){t.x=(t.x+c)*f,t.y=t.depth*g})}return t}function n(t){var n=t.children,r=t.parent.children,e=t.i?r[t.i-1]:null;if(n){o(t);var i=(n[0].z+n[n.length-1].z)/2;e?(t.z=e.z+h(t._,e._),t.m=t.z-i):t.z=i}else e&&(t.z=e.z+h(t._,e._));t.parent.A=f(t,e,t.parent.A||r[0])}function r(t){t._.x=t.z+t.parent.m,t.m+=t.parent.m}function f(t,n,r){if(n){for(var e,o=t,f=t,s=n,l=o.parent.children[0],d=o.m,p=f.m,v=s.m,g=l.m;s=u(s),o=i(o),s&&o;)l=i(l),f=u(f),f.a=t,e=s.z+v-o.z-d+h(s._,o._),e>0&&(a(c(s,t,r),t,e),d+=e,p+=e),v+=s.m,d+=o.m,g+=l.m,p+=f.m;s&&!u(f)&&(f.t=s,f.m+=v-p),o&&!i(l)&&(l.t=o,l.m+=d-g,r=t)}return r}function l(t){t.x*=d,t.y=t.depth*p}var h=e,d=1,p=1,v=null;return t.separation=function(n){return arguments.length?(h=n,t):h},t.size=function(n){return arguments.length?(v=!1,d=+n[0],p=+n[1],t):v?null:[d,p]},t.nodeSize=function(n){return arguments.length?(v=!0,d=+n[0],p=+n[1],t):v?[d,p]:null},t}},function(t,n,r){"use strict";n.a=function(t,n,r,e,i){function u(t,n,r,e,i,a,o){if(t>=n-1){var f=c[t];return f.x0=e,f.y0=i,f.x1=a,f.y1=o,void 0}for(var l=s[t],h=r/2+l,d=t+1,p=n-1;d>>1;s[v]o-i){var _=(e*y+a*g)/r;u(t,d,g,e,i,_,o),u(d,n,y,_,i,a,o)}else{var b=(i*y+o*g)/r;u(t,d,g,e,i,a,b),u(d,n,y,e,b,a,o)}}var a,o,c=t.children,f=c.length,s=new Array(f+1);for(s[0]=o=a=0;a1?n:1)},a}(u.c)},function(t,n,r){"use strict";var e=r(25),i=r(37);n.a=function(t,n,r,u,a){(1&t.depth?i.a:e.a)(t,n,r,u,a)}},function(t,n,r){"use strict";function e(t){return function n(e){function a(n,a){var o=t((n=r.i(i.f)(n)).h,(a=r.i(i.f)(a)).h),c=r.i(u.a)(n.s,a.s),f=r.i(u.a)(n.l,a.l),s=r.i(u.a)(n.opacity,a.opacity);return function(t){return n.h=o(t),n.s=c(t),n.l=f(Math.pow(t,e)),n.opacity=s(t),n+""}}return e=+e,a.gamma=n,a}(1)}var i=r(7),u=r(26);r.d(n,"b",function(){return a}),n.a=e(u.b);var a=e(u.a)},function(t,n,r){"use strict";function e(t){return function(n,e){var a=t((n=r.i(i.e)(n)).h,(e=r.i(i.e)(e)).h),o=r.i(u.a)(n.c,e.c),c=r.i(u.a)(n.l,e.l),f=r.i(u.a)(n.opacity,e.opacity);return function(t){return n.h=a(t),n.c=o(t),n.l=c(t),n.opacity=f(t),n+""}}}var i=r(7),u=r(26);r.d(n,"b",function(){return a}),n.a=e(u.b);var a=e(u.a)},function(t,n,r){"use strict";function e(t){return function(n,e){var a=t((n=r.i(i.c)(n)).h,(e=r.i(i.c)(e)).h),o=r.i(u.a)(n.s,e.s),c=r.i(u.a)(n.l,e.l),f=r.i(u.a)(n.opacity,e.opacity);return function(t){return n.h=a(t),n.s=o(t),n.l=c(t),n.opacity=f(t),n+""}}}var i=r(7),u=r(26);r.d(n,"b",function(){return a}),n.a=e(u.b);var a=e(u.a)},function(t,n,r){"use strict";function e(t,n){var e=r.i(u.a)((t=r.i(i.d)(t)).l,(n=r.i(i.d)(n)).l),a=r.i(u.a)(t.a,n.a),o=r.i(u.a)(t.b,n.b),c=r.i(u.a)(t.opacity,n.opacity);return function(n){return t.l=e(n),t.a=a(n),t.b=o(n),t.opacity=c(n),t+""}}var i=r(7),u=r(26);n.a=e},function(t,n,r){"use strict";n.a=function(t,n){for(var r=new Array(n),e=0;e180?n+=360:n-t>180&&(t+=360),o.push({i:e.push(a(e)+"rotate(",null,u)-2,x:r.i(i.a)(t,n)})):n&&e.push(a(e)+"rotate("+n+u)}function f(t,n,e,o){t!==n?o.push({i:e.push(a(e)+"skewX(",null,u)-2,x:r.i(i.a)(t,n)}):n&&e.push(a(e)+"skewX("+n+u)}function s(t,n,e,u,o,c){if(t!==e||n!==u){var f=o.push(a(o)+"scale(",null,",",null,")");c.push({i:f-4,x:r.i(i.a)(t,e)},{i:f-2,x:r.i(i.a)(n,u)})}else 1===e&&1===u||o.push(a(o)+"scale("+e+","+u+")")}return function(n,r){var e=[],i=[];return n=t(n),r=t(r),o(n.translateX,n.translateY,r.translateX,r.translateY,e,i),c(n.rotate,r.rotate,e,i),f(n.skewX,r.skewX,e,i),s(n.scaleX,n.scaleY,r.scaleX,r.scaleY,e,i),n=r=null,function(t){for(var n,r=-1,u=i.length;++ro)if(Math.abs(h*f-s*l)>o&&i){var p=r-a,v=e-c,g=f*f+s*s,y=p*p+v*v,_=Math.sqrt(g),b=Math.sqrt(d),m=i*Math.tan((u-Math.acos((g+d-y)/(2*_*b)))/2),x=m/b,w=m/_;Math.abs(x-1)>o&&(this._+="L"+(t+x*l)+","+(n+x*h)),this._+="A"+i+","+i+",0,0,"+ +(h*p>l*v)+","+(this._x1=t+w*f)+","+(this._y1=n+w*s)}else this._+="L"+(this._x1=t)+","+(this._y1=n);else;},arc:function(t,n,r,e,i,f){t=+t,n=+n,r=+r;var s=r*Math.cos(e),l=r*Math.sin(e),h=t+s,d=n+l,p=1^f,v=f?e-i:i-e;if(r<0)throw new Error("negative radius: "+r);null===this._x1?this._+="M"+h+","+d:(Math.abs(this._x1-h)>o||Math.abs(this._y1-d)>o)&&(this._+="L"+h+","+d),r&&(v<0&&(v=v%a+a),v>c?this._+="A"+r+","+r+",0,1,"+p+","+(t-s)+","+(n-l)+"A"+r+","+r+",0,1,"+p+","+(this._x1=h)+","+(this._y1=d):v>o&&(this._+="A"+r+","+r+",0,"+ +(v>=u)+","+p+","+(this._x1=t+r*Math.cos(i))+","+(this._y1=n+r*Math.sin(i))))},rect:function(t,n,r,e){this._+="M"+(this._x0=this._x1=+t)+","+(this._y0=this._y1=+n)+"h"+ +r+"v"+ +e+"h"+-r+"Z"},toString:function(){return this._}},n.a=i},function(t,n,r){"use strict";var e=r(307);r.d(n,"a",function(){return e.a});var i=r(308);r.d(n,"b",function(){return i.a});var u=r(311);r.d(n,"c",function(){return u.a});var a=r(309);r.d(n,"d",function(){return a.a});var o=r(312);r.d(n,"e",function(){return o.a})},function(t,n,r){"use strict";n.a=function(t){for(var n,r=-1,e=t.length,i=t[e-1],u=0;++ro!=f>o&&a<(c-r)*(o-e)/(f-e)+r&&(s=!s),c=r,f=e;return s}},function(t,n,r){"use strict";n.a=function(t,n,r){return(n[0]-t[0])*(r[1]-t[1])-(n[1]-t[1])*(r[0]-t[0])}},function(t,n,r){"use strict";function e(t,n){return t[0]-n[0]||t[1]-n[1]}function i(t){for(var n=t.length,e=[0,1],i=2,a=2;a1&&r.i(u.a)(t[e[i-2]],t[e[i-1]],t[a])<=0;)--i;e[i++]=a}return e.slice(0,i)}var u=r(310);n.a=function(t){if((r=t.length)<3)return null;var n,r,u=new Array(r),a=new Array(r);for(n=0;n=0;--n)l.push(t[u[o[n]][2]]);for(n=+f;n=(u=(v+y)/2))?v=u:y=u,(s=r>=(a=(g+_)/2))?g=a:_=a,i=d,!(d=d[l=s<<1|f]))return i[l]=p,t;if(o=+t._x.call(null,d.data),c=+t._y.call(null,d.data),n===o&&r===c)return p.next=d,i?i[l]=p:t._root=p,t;do{i=i?i[l]=new Array(4):t._root=new Array(4),(f=n>=(u=(v+y)/2))?v=u:y=u,(s=r>=(a=(g+_)/2))?g=a:_=a}while((l=s<<1|f)==(h=(c>=a)<<1|o>=u));return i[h]=d,i[l]=p,t}function i(t){var n,r,i,u,a=t.length,o=new Array(a),c=new Array(a),f=1/0,s=1/0,l=-1/0,h=-1/0;for(r=0;rl&&(l=i),uh&&(h=u));for(lt||t>i||e>n||n>u))return this;var a,o,c=i-r,f=this._root;switch(o=(n<(e+u)/2)<<1|t<(r+i)/2){case 0:do{a=new Array(4),a[o]=f,f=a}while(c*=2,i=r+c,u=e+c,t>i||n>u);break;case 1:do{a=new Array(4),a[o]=f,f=a}while(c*=2,r=i-c,u=e+c,r>t||n>u);break;case 2:do{a=new Array(4),a[o]=f,f=a}while(c*=2,i=r+c,e=u-c,t>i||e>n);break;case 3:do{a=new Array(4),a[o]=f,f=a}while(c*=2,r=i-c,e=u-c,r>t||e>n)}this._root&&this._root.length&&(this._root=f)}return this._x0=r,this._y0=e,this._x1=i,this._y1=u,this}},function(t,n,r){"use strict";n.a=function(){var t=[];return this.visit(function(n){if(!n.length)do{t.push(n.data)}while(n=n.next)}),t}},function(t,n,r){"use strict";n.a=function(t){return arguments.length?this.cover(+t[0][0],+t[0][1]).cover(+t[1][0],+t[1][1]):isNaN(this._x0)?void 0:[[this._x0,this._y0],[this._x1,this._y1]]}},function(t,n,r){"use strict";var e=r(71);n.a=function(t,n,r){var i,u,a,o,c,f,s,l=this._x0,h=this._y0,d=this._x1,p=this._y1,v=[],g=this._root;for(g&&v.push(new e.a(g,l,h,d,p)),null==r?r=1/0:(l=t-r,h=n-r,d=t+r,p=n+r,r*=r);f=v.pop();)if(!(!(g=f.node)||(u=f.x0)>d||(a=f.y0)>p||(o=f.x1)=_)<<1|t>=y)&&(f=v[v.length-1],v[v.length-1]=v[v.length-1-s],v[v.length-1-s]=f)}else{var b=t-+this._x.call(null,g.data),m=n-+this._y.call(null,g.data),x=b*b+m*m;if(x=(o=(p+g)/2))?p=o:g=o,(s=a>=(c=(v+y)/2))?v=c:y=c,n=d,!(d=d[l=s<<1|f]))return this;if(!d.length)break;(n[l+1&3]||n[l+2&3]||n[l+3&3])&&(r=n,h=l)}for(;d.data!==t;)if(e=d,!(d=d.next))return this;return(i=d.next)&&delete d.next,e?(i?e.next=i:delete e.next,this):n?(i?n[l]=i:delete n[l],(d=n[0]||n[1]||n[2]||n[3])&&d===(n[3]||n[2]||n[1]||n[0])&&!d.length&&(r?r[h]=d:this._root=d),this):(this._root=i,this)}},function(t,n,r){"use strict";n.a=function(){return this._root}},function(t,n,r){"use strict";n.a=function(){var t=0;return this.visit(function(n){if(!n.length)do{++t}while(n=n.next)}),t}},function(t,n,r){"use strict";var e=r(71);n.a=function(t){var n,r,i,u,a,o,c=[],f=this._root;for(f&&c.push(new e.a(f,this._x0,this._y0,this._x1,this._y1));n=c.pop();)if(!t(f=n.node,i=n.x0,u=n.y0,a=n.x1,o=n.y1)&&f.length){var s=(i+a)/2,l=(u+o)/2;(r=f[3])&&c.push(new e.a(r,s,l,a,o)),(r=f[2])&&c.push(new e.a(r,i,l,s,o)),(r=f[1])&&c.push(new e.a(r,s,u,a,l)),(r=f[0])&&c.push(new e.a(r,i,u,s,l))}return this}},function(t,n,r){"use strict";var e=r(71);n.a=function(t){var n,r=[],i=[];for(this._root&&r.push(new e.a(this._root,this._x0,this._y0,this._x1,this._y1));n=r.pop();){var u=n.node;if(u.length){var a,o=n.x0,c=n.y0,f=n.x1,s=n.y1,l=(o+f)/2,h=(c+s)/2;(a=u[0])&&r.push(new e.a(a,o,c,l,h)),(a=u[1])&&r.push(new e.a(a,l,c,f,h)),(a=u[2])&&r.push(new e.a(a,o,h,l,s)),(a=u[3])&&r.push(new e.a(a,l,h,f,s))}i.push(n)}for(;n=i.pop();)t(n.node,n.x0,n.y0,n.x1,n.y1);return this}},function(t,n,r){"use strict";function e(t){return t[0]}n.a=e,n.b=function(t){return arguments.length?(this._x=t,this):this._x}},function(t,n,r){"use strict";function e(t){return t[1]}n.a=e,n.b=function(t){return arguments.length?(this._y=t,this):this._y}},function(t,n,r){"use strict";var e=r(328);r.d(n,"a",function(){return e.a})},function(t,n,r){"use strict";r.d(n,"a",function(){return e});var e=[].slice},function(t,n,r){"use strict";function e(t){this._size=t,this._call=this._error=null,this._tasks=[],this._data=[],this._waiting=this._active=this._ended=this._start=0}function i(t){if(!t._start)try{u(t)}catch(n){if(t._tasks[t._ended+t._active-1])o(t,n);else if(!t._data)throw n}}function u(t){for(;t._start=t._waiting&&t._active=0;)if((r=t._tasks[e])&&(t._tasks[e]=null,r.abort))try{r.abort()}catch(n){}t._active=NaN,c(t)}function c(t){if(!t._active&&t._call){var n=t._data;t._data=void 0,t._call(t._error,n)}}function f(t){if(null==t)t=1/0;else if(!((t=+t)>=1))throw new Error("invalid concurrency");return new e(t)}var s=r(327);n.a=f;var l={};e.prototype=f.prototype={constructor:e,defer:function(t){if("function"!=typeof t)throw new Error("invalid callback");if(this._call)throw new Error("defer after await");if(null!=this._error)return this;var n=s.a.call(arguments,1);return n.push(t),++this._waiting,this._tasks.push(n),i(this),this},abort:function(){return null==this._error&&o(this,new Error("abort")),this},await:function(t){if("function"!=typeof t)throw new Error("invalid callback");if(this._call)throw new Error("multiple await");return this._call=function(n,r){t.apply(null,[n].concat(r))},c(this),this},awaitAll:function(t){if("function"!=typeof t)throw new Error("invalid callback");if(this._call)throw new Error("multiple await");return this._call=t,c(this),this}}},function(t,n,r){"use strict";var e=r(333);r.d(n,"a",function(){return e.a});var i=r(140);r.d(n,"b",function(){return i.a});var u=r(332);r.d(n,"c",function(){return u.a});var a=r(330);r.d(n,"d",function(){return a.a});var o=r(139);r.d(n,"e",function(){return o.a});var c=r(331);r.d(n,"f",function(){return c.a})},function(t,n,r){"use strict";var e=r(20),i=r(139);n.a=function t(n){function r(t){var r=i.a.source(n)(t);return function(){return r()/t}}return r.source=t,r}(e.a)},function(t,n,r){"use strict";var e=r(20);n.a=function t(n){function r(t){return function(){return-Math.log(1-n())/t}}return r.source=t,r}(e.a)},function(t,n,r){"use strict";var e=r(20),i=r(140);n.a=function t(n){function r(){var t=i.a.source(n).apply(this,arguments);return function(){return Math.exp(t())}}return r.source=t,r}(e.a)},function(t,n,r){"use strict";var e=r(20);n.a=function t(n){function r(t,r){return t=null==t?0:+t,r=null==r?1:+r,1===arguments.length?(r=t,t=0):r-=t,function(){return n()*r+t}}return r.source=t,r}(e.a)},function(t,n,r){"use strict";var e=r(72);r.d(n,"a",function(){return e.a});var i=r(336);r.d(n,"b",function(){return i.a});var u=r(337);r.d(n,"c",function(){return u.a});var a=r(338);r.d(n,"d",function(){return a.a});var o=r(340);r.d(n,"e",function(){return o.a});var c=r(335);r.d(n,"f",function(){return c.a});var f=r(339);r.d(n,"g",function(){return f.a})},function(t,n,r){"use strict";var e=r(55),i=r(141);n.a=r.i(i.a)("text/csv",e.b)},function(t,n,r){"use strict";var e=r(39);n.a=r.i(e.a)("text/html",function(t){return document.createRange().createContextualFragment(t.responseText)})},function(t,n,r){"use strict";var e=r(39);n.a=r.i(e.a)("application/json",function(t){return JSON.parse(t.responseText)})},function(t,n,r){"use strict";var e=r(39);n.a=r.i(e.a)("text/plain",function(t){return t.responseText})},function(t,n,r){"use strict";var e=r(55),i=r(141);n.a=r.i(i.a)("text/tab-separated-values",e.f)},function(t,n,r){"use strict";var e=r(39);n.a=r.i(e.a)("application/xml",function(t){var n=t.responseXML;if(!n)throw new Error("parse error");return n})},function(t,n,r){"use strict";var e=r(342);r.d(n,"a",function(){return e.a}),r.d(n,"b",function(){return e.b});var i=r(348);r.d(n,"c",function(){return i.a});var u=r(28);r.d(n,"d",function(){return u.a});var a=r(349);r.d(n,"e",function(){return a.a});var o=r(144);r.d(n,"f",function(){return o.a}),r.d(n,"g",function(){return o.b});var c=r(350);r.d(n,"h",function(){return c.a}),r.d(n,"i",function(){return c.b});var f=r(351);r.d(n,"j",function(){return f.a});var s=r(352);r.d(n,"k",function(){return s.a});var l=r(355);r.d(n,"l",function(){return l.a});var h=r(145);r.d(n,"m",function(){return h.a});var d=r(357);r.d(n,"n",function(){return d.a});var p=r(343);r.d(n,"o",function(){return p.a});var v=r(345);r.d(n,"p",function(){return v.a});var g=r(346);r.d(n,"q",function(){return g.a});var y=r(344);r.d(n,"r",function(){return y.a});var _=r(347);r.d(n,"s",function(){return _.a});var b=r(353);r.d(n,"t",function(){return b.a}),r.d(n,"u",function(){return b.b}),r.d(n,"v",function(){return b.c});var m=r(358);r.d(n,"w",function(){return m.a}),r.d(n,"x",function(){return m.b}),r.d(n,"y",function(){return m.c}),r.d(n,"z",function(){return m.d});var x=r(354);r.d(n,"A",function(){return x.a})},function(t,n,r){"use strict";function e(){function t(){var t=c().length,e=s[1]0){for(;la)break;y.push(f)}}else for(;l=1;--c)if(!((f=o*c)a)break;y.push(f)}}else y=r.i(s.z)(l,d,Math.min(d-l,p)).map(g);return n?y.reverse():y},n.tickFormat=function(t,e){if(null==e&&(e=10===h?".0e":","),"function"!=typeof e&&(e=r.i(l.b)(e)),t===1/0)return e;null==t&&(t=10);var i=Math.max(1,h*t/n.ticks().length);return function(t){var n=t/g(Math.round(v(t)));return n*h0?c[n-1]:a[0],n=f?[s[f-1],c]:[s[n-1],s[n]]},t.copy=function(){return e().domain([o,c]).range(l)},r.i(a.b)(t)}var i=r(3),u=r(15),a=r(28);n.a=e},function(t,n,r){"use strict";var e=r(7),i=r(4);r.d(n,"b",function(){return u}),r.d(n,"c",function(){return a});var u=r.i(i.v)(r.i(e.f)(-100,.75,.35),r.i(e.f)(80,1.5,.8)),a=r.i(i.v)(r.i(e.f)(260,.75,.35),r.i(e.f)(80,1.5,.8)),o=r.i(e.f)();n.a=function(t){(t<0||t>1)&&(t-=Math.floor(t));var n=Math.abs(t-.5);return o.h=360*t-100,o.s=1.5-1.5*n,o.l=.8-.9*n,o+""}},function(t,n,r){"use strict";function e(t){function n(n){var r=(n-u)/(a-u);return t(o?Math.max(0,Math.min(1,r)):r)}var u=0,a=1,o=!1;return n.domain=function(t){return arguments.length?(u=+t[0],a=+t[1],n):[u,a]},n.clamp=function(t){return arguments.length?(o=!!t,n):o},n.interpolator=function(r){return arguments.length?(t=r,n):t},n.copy=function(){return e(t).domain([u,a]).clamp(o)},r.i(i.b)(n)}var i=r(28);n.a=e},function(t,n,r){"use strict";function e(){function t(t){if(t<=t)return a[r.i(i.a)(n,t,0,o)]}var n=[.5],a=[0,1],o=1;return t.domain=function(r){return arguments.length?(n=u.b.call(r),o=Math.min(n.length,a.length-1),t):n.slice()},t.range=function(r){return arguments.length?(a=u.b.call(r),o=Math.min(n.length,a.length-1),t):a.slice()},t.invertExtent=function(t){var r=a.indexOf(t);return[n[r-1],n[r]]},t.copy=function(){return e().domain(n).range(a)},t}var i=r(3),u=r(15);n.a=e},function(t,n,r){"use strict";var e=r(3),i=r(58);n.a=function(t,n,u){var a,o=t[0],c=t[t.length-1],f=r.i(e.B)(o,c,null==n?10:n);switch(u=r.i(i.e)(null==u?",f":u),u.type){case"s":var s=Math.max(Math.abs(o),Math.abs(c));return null!=u.precision||isNaN(a=r.i(i.g)(f,s))||(u.precision=a),r.i(i.c)(u,s);case"":case"e":case"g":case"p":case"r":null!=u.precision||isNaN(a=r.i(i.h)(f,Math.max(Math.abs(o),Math.abs(c))))||(u.precision=a-("e"===u.type));break;case"f":case"%":null!=u.precision||isNaN(a=r.i(i.f)(f))||(u.precision=a-2*("%"===u.type))}return r.i(i.b)(u)}},function(t,n,r){"use strict";var e=r(145),i=r(85),u=r(46);n.a=function(){return r.i(e.b)(u._7,u._5,u.P,u.N,u.L,u.J,u.h,u.d,i.d).domain([Date.UTC(2e3,0,1),Date.UTC(2e3,0,2)])}},function(t,n,r){"use strict";function e(t){var n=t.length;return function(r){return t[Math.max(0,Math.min(n-1,Math.floor(r*n)))]}}var i=r(27);r.d(n,"b",function(){return u}),r.d(n,"c",function(){return a}),r.d(n,"d",function(){return o}),n.a=e(r.i(i.a)("44015444025645045745055946075a46085c460a5d460b5e470d60470e6147106347116447136548146748166848176948186a481a6c481b6d481c6e481d6f481f70482071482173482374482475482576482677482878482979472a7a472c7a472d7b472e7c472f7d46307e46327e46337f463480453581453781453882443983443a83443b84433d84433e85423f854240864241864142874144874045884046883f47883f48893e49893e4a893e4c8a3d4d8a3d4e8a3c4f8a3c508b3b518b3b528b3a538b3a548c39558c39568c38588c38598c375a8c375b8d365c8d365d8d355e8d355f8d34608d34618d33628d33638d32648e32658e31668e31678e31688e30698e306a8e2f6b8e2f6c8e2e6d8e2e6e8e2e6f8e2d708e2d718e2c718e2c728e2c738e2b748e2b758e2a768e2a778e2a788e29798e297a8e297b8e287c8e287d8e277e8e277f8e27808e26818e26828e26828e25838e25848e25858e24868e24878e23888e23898e238a8d228b8d228c8d228d8d218e8d218f8d21908d21918c20928c20928c20938c1f948c1f958b1f968b1f978b1f988b1f998a1f9a8a1e9b8a1e9c891e9d891f9e891f9f881fa0881fa1881fa1871fa28720a38620a48621a58521a68522a78522a88423a98324aa8325ab8225ac8226ad8127ad8128ae8029af7f2ab07f2cb17e2db27d2eb37c2fb47c31b57b32b67a34b67935b77937b87838b9773aba763bbb753dbc743fbc7340bd7242be7144bf7046c06f48c16e4ac16d4cc26c4ec36b50c46a52c56954c56856c66758c7655ac8645cc8635ec96260ca6063cb5f65cb5e67cc5c69cd5b6ccd5a6ece5870cf5773d05675d05477d1537ad1517cd2507fd34e81d34d84d44b86d54989d5488bd6468ed64590d74393d74195d84098d83e9bd93c9dd93ba0da39a2da37a5db36a8db34aadc32addc30b0dd2fb2dd2db5de2bb8de29bade28bddf26c0df25c2df23c5e021c8e020cae11fcde11dd0e11cd2e21bd5e21ad8e219dae319dde318dfe318e2e418e5e419e7e419eae51aece51befe51cf1e51df4e61ef6e620f8e621fbe723fde725"));var u=e(r.i(i.a)("00000401000501010601010802010902020b02020d03030f03031204041405041606051806051a07061c08071e0907200a08220b09240c09260d0a290e0b2b100b2d110c2f120d31130d34140e36150e38160f3b180f3d19103f1a10421c10441d11471e114920114b21114e22115024125325125527125829115a2a115c2c115f2d11612f116331116533106734106936106b38106c390f6e3b0f703d0f713f0f72400f74420f75440f764510774710784910784a10794c117a4e117b4f127b51127c52137c54137d56147d57157e59157e5a167e5c167f5d177f5f187f601880621980641a80651a80671b80681c816a1c816b1d816d1d816e1e81701f81721f817320817521817621817822817922827b23827c23827e24828025828125818326818426818627818827818928818b29818c29818e2a81902a81912b81932b80942c80962c80982d80992d809b2e7f9c2e7f9e2f7fa02f7fa1307ea3307ea5317ea6317da8327daa337dab337cad347cae347bb0357bb2357bb3367ab5367ab73779b83779ba3878bc3978bd3977bf3a77c03a76c23b75c43c75c53c74c73d73c83e73ca3e72cc3f71cd4071cf4070d0416fd2426fd3436ed5446dd6456cd8456cd9466bdb476adc4869de4968df4a68e04c67e24d66e34e65e44f64e55064e75263e85362e95462ea5661eb5760ec5860ed5a5fee5b5eef5d5ef05f5ef1605df2625df2645cf3655cf4675cf4695cf56b5cf66c5cf66e5cf7705cf7725cf8745cf8765cf9785df9795df97b5dfa7d5efa7f5efa815ffb835ffb8560fb8761fc8961fc8a62fc8c63fc8e64fc9065fd9266fd9467fd9668fd9869fd9a6afd9b6bfe9d6cfe9f6dfea16efea36ffea571fea772fea973feaa74feac76feae77feb078feb27afeb47bfeb67cfeb77efeb97ffebb81febd82febf84fec185fec287fec488fec68afec88cfeca8dfecc8ffecd90fecf92fed194fed395fed597fed799fed89afdda9cfddc9efddea0fde0a1fde2a3fde3a5fde5a7fde7a9fde9aafdebacfcecaefceeb0fcf0b2fcf2b4fcf4b6fcf6b8fcf7b9fcf9bbfcfbbdfcfdbf")),a=e(r.i(i.a)("00000401000501010601010802010a02020c02020e03021004031204031405041706041907051b08051d09061f0a07220b07240c08260d08290e092b10092d110a30120a32140b34150b37160b39180c3c190c3e1b0c411c0c431e0c451f0c48210c4a230c4c240c4f260c51280b53290b552b0b572d0b592f0a5b310a5c320a5e340a5f3609613809623909633b09643d09653e0966400a67420a68440a68450a69470b6a490b6a4a0c6b4c0c6b4d0d6c4f0d6c510e6c520e6d540f6d550f6d57106e59106e5a116e5c126e5d126e5f136e61136e62146e64156e65156e67166e69166e6a176e6c186e6d186e6f196e71196e721a6e741a6e751b6e771c6d781c6d7a1d6d7c1d6d7d1e6d7f1e6c801f6c82206c84206b85216b87216b88226a8a226a8c23698d23698f24699025689225689326679526679727669827669a28659b29649d29649f2a63a02a63a22b62a32c61a52c60a62d60a82e5fa92e5eab2f5ead305dae305cb0315bb1325ab3325ab43359b63458b73557b93556ba3655bc3754bd3853bf3952c03a51c13a50c33b4fc43c4ec63d4dc73e4cc83f4bca404acb4149cc4248ce4347cf4446d04545d24644d34743d44842d54a41d74b3fd84c3ed94d3dda4e3cdb503bdd513ade5238df5337e05536e15635e25734e35933e45a31e55c30e65d2fe75e2ee8602de9612bea632aeb6429eb6628ec6726ed6925ee6a24ef6c23ef6e21f06f20f1711ff1731df2741cf3761bf37819f47918f57b17f57d15f67e14f68013f78212f78410f8850ff8870ef8890cf98b0bf98c0af98e09fa9008fa9207fa9407fb9606fb9706fb9906fb9b06fb9d07fc9f07fca108fca309fca50afca60cfca80dfcaa0ffcac11fcae12fcb014fcb216fcb418fbb61afbb81dfbba1ffbbc21fbbe23fac026fac228fac42afac62df9c72ff9c932f9cb35f8cd37f8cf3af7d13df7d340f6d543f6d746f5d949f5db4cf4dd4ff4df53f4e156f3e35af3e55df2e661f2e865f2ea69f1ec6df1ed71f1ef75f1f179f2f27df2f482f3f586f3f68af4f88ef5f992f6fa96f8fb9af9fc9dfafda1fcffa4")),o=e(r.i(i.a)("0d088710078813078916078a19068c1b068d1d068e20068f2206902406912605912805922a05932c05942e05952f059631059733059735049837049938049a3a049a3c049b3e049c3f049c41049d43039e44039e46039f48039f4903a04b03a14c02a14e02a25002a25102a35302a35502a45601a45801a45901a55b01a55c01a65e01a66001a66100a76300a76400a76600a76700a86900a86a00a86c00a86e00a86f00a87100a87201a87401a87501a87701a87801a87a02a87b02a87d03a87e03a88004a88104a78305a78405a78606a68707a68808a68a09a58b0aa58d0ba58e0ca48f0da4910ea3920fa39410a29511a19613a19814a099159f9a169f9c179e9d189d9e199da01a9ca11b9ba21d9aa31e9aa51f99a62098a72197a82296aa2395ab2494ac2694ad2793ae2892b02991b12a90b22b8fb32c8eb42e8db52f8cb6308bb7318ab83289ba3388bb3488bc3587bd3786be3885bf3984c03a83c13b82c23c81c33d80c43e7fc5407ec6417dc7427cc8437bc9447aca457acb4679cc4778cc4977cd4a76ce4b75cf4c74d04d73d14e72d24f71d35171d45270d5536fd5546ed6556dd7566cd8576bd9586ada5a6ada5b69db5c68dc5d67dd5e66de5f65de6164df6263e06363e16462e26561e26660e3685fe4695ee56a5de56b5de66c5ce76e5be76f5ae87059e97158e97257ea7457eb7556eb7655ec7754ed7953ed7a52ee7b51ef7c51ef7e50f07f4ff0804ef1814df1834cf2844bf3854bf3874af48849f48948f58b47f58c46f68d45f68f44f79044f79143f79342f89441f89540f9973ff9983ef99a3efa9b3dfa9c3cfa9e3bfb9f3afba139fba238fca338fca537fca636fca835fca934fdab33fdac33fdae32fdaf31fdb130fdb22ffdb42ffdb52efeb72dfeb82cfeba2cfebb2bfebd2afebe2afec029fdc229fdc328fdc527fdc627fdc827fdca26fdcb26fccd25fcce25fcd025fcd225fbd324fbd524fbd724fad824fada24f9dc24f9dd25f8df25f8e125f7e225f7e425f6e626f6e826f5e926f5eb27f4ed27f3ee27f3f027f2f227f1f426f1f525f0f724f0f921"))},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(){return new i}function i(){this._="@"+(++u).toString(36)}n.a=e;var u=0;i.prototype=e.prototype={constructor:i,get:function(t){for(var n=this._;!(n in t);)if(!(t=t.parentNode))return;return t[n]},set:function(t,n){return t[this._]=n},remove:function(t){return this._ in t&&delete t[this._]},toString:function(){return this._}}},function(t,n,r){"use strict";var e=r(79),i=r(41);n.a=function(t){var n=r.i(e.a)();return n.changedTouches&&(n=n.changedTouches[0]),r.i(i.a)(t,n)}},function(t,n,r){"use strict";var e=r(5);n.a=function(t){return"string"==typeof t?new e.b([[document.querySelector(t)]],[document.documentElement]):new e.b([[t]],e.c)}},function(t,n,r){"use strict";var e=r(5);n.a=function(t){return"string"==typeof t?new e.b([document.querySelectorAll(t)],[document.documentElement]):new e.b([null==t?[]:t],e.c)}},function(t,n,r){"use strict";var e=r(74);n.a=function(t){var n="function"==typeof t?t:r.i(e.a)(t);return this.select(function(){return this.appendChild(n.apply(this,arguments))})}},function(t,n,r){"use strict";function e(t){return function(){this.removeAttribute(t)}}function i(t){return function(){this.removeAttributeNS(t.space,t.local)}}function u(t,n){return function(){this.setAttribute(t,n)}}function a(t,n){return function(){this.setAttributeNS(t.space,t.local,n)}}function o(t,n){return function(){var r=n.apply(this,arguments);null==r?this.removeAttribute(t):this.setAttribute(t,r)}}function c(t,n){return function(){var r=n.apply(this,arguments);null==r?this.removeAttributeNS(t.space,t.local):this.setAttributeNS(t.space,t.local,r)}}var f=r(75);n.a=function(t,n){var s=r.i(f.a)(t);if(arguments.length<2){var l=this.node();return s.local?l.getAttributeNS(s.space,s.local):l.getAttribute(s)}return this.each((null==n?s.local?i:e:"function"==typeof n?s.local?c:o:s.local?a:u)(s,n))}},function(t,n,r){"use strict";n.a=function(){var t=arguments[0];return arguments[0]=this,t.apply(null,arguments),this}},function(t,n,r){"use strict";function e(t){return t.trim().split(/^|\s+/)}function i(t){return t.classList||new u(t)}function u(t){this._node=t,this._names=e(t.getAttribute("class")||"")}function a(t,n){for(var r=i(t),e=-1,u=n.length;++e=0&&(this._names.splice(n,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(t){return this._names.indexOf(t)>=0}},n.a=function(t,n){var r=e(t+"");if(arguments.length<2){for(var u=i(this.node()),a=-1,o=r.length;++a=T&&(T=k+1);!(M=x[T])&&++T=0;)(e=i[u])&&(a&&a!==e.nextSibling&&a.parentNode.insertBefore(e,a),a=e);return this}},function(t,n,r){"use strict";function e(t){return function(){delete this[t]}}function i(t,n){return function(){this[t]=n}}function u(t,n){return function(){var r=n.apply(this,arguments);null==r?delete this[t]:this[t]=r}}n.a=function(t,n){return arguments.length>1?this.each((null==n?e:"function"==typeof n?u:i)(t,n)):this.node()[t]}},function(t,n,r){"use strict";function e(){this.nextSibling&&this.parentNode.appendChild(this)}n.a=function(){return this.each(e)}},function(t,n,r){"use strict";function e(){var t=this.parentNode;t&&t.removeChild(this)}n.a=function(){return this.each(e)}},function(t,n,r){"use strict";var e=r(5),i=r(78);n.a=function(t){"function"!=typeof t&&(t=r.i(i.a)(t));for(var n=this._groups,u=n.length,a=new Array(u),o=0;on?1:t>=n?0:NaN}var i=r(5);n.a=function(t){function n(n,r){return n&&r?t(n.__data__,r.__data__):!n-!r}t||(t=e);for(var r=this._groups,u=r.length,a=new Array(u),o=0;oz*z+P*P&&(N=E,A=S),{cx:N,cy:A,x01:-l,y01:-d,x11:N*(u/M-1),y11:A*(u/M-1)}}var s=r(14),l=r(16),h=r(29);n.a=function(){function t(){var t,e,i=+n.apply(this,arguments),u=+d.apply(this,arguments),a=g.apply(this,arguments)-h.f,o=y.apply(this,arguments)-h.f,l=r.i(h.g)(o-a),m=o>a;if(b||(b=t=r.i(s.a)()),uh.a)if(l>h.c-h.a)b.moveTo(u*r.i(h.h)(a),u*r.i(h.i)(a)),b.arc(0,0,u,a,o,!m),i>h.a&&(b.moveTo(i*r.i(h.h)(o),i*r.i(h.i)(o)),b.arc(0,0,i,o,a,m));else{var x,w,M=a,k=o,T=a,N=o,A=l,E=l,S=_.apply(this,arguments)/2,C=S>h.a&&(v?+v.apply(this,arguments):r.i(h.d)(i*i+u*u)),q=r.i(h.j)(r.i(h.g)(u-i)/2,+p.apply(this,arguments)),z=q,P=q;if(C>h.a){var D=r.i(h.k)(C/i*r.i(h.i)(S)),L=r.i(h.k)(C/u*r.i(h.i)(S));(A-=2*D)>h.a?(D*=m?1:-1,T+=D,N-=D):(A=0,T=N=(a+o)/2),(E-=2*L)>h.a?(L*=m?1:-1,M+=L,k-=L):(E=0,M=k=(a+o)/2)}var R=u*r.i(h.h)(M),U=u*r.i(h.i)(M),j=i*r.i(h.h)(N),O=i*r.i(h.i)(N);if(q>h.a){var I=u*r.i(h.h)(k),F=u*r.i(h.i)(k),Y=i*r.i(h.h)(T),B=i*r.i(h.i)(T);if(lh.a?c(R,U,Y,B,I,F,j,O):[j,O],X=R-H[0],V=U-H[1],G=I-H[0],W=F-H[1],Z=1/r.i(h.i)(r.i(h.l)((X*G+V*W)/(r.i(h.d)(X*X+V*V)*r.i(h.d)(G*G+W*W)))/2),Q=r.i(h.d)(H[0]*H[0]+H[1]*H[1]);z=r.i(h.j)(q,(i-Q)/(Z-1)),P=r.i(h.j)(q,(u-Q)/(Z+1))}}E>h.a?P>h.a?(x=f(Y,B,R,U,u,P,m),w=f(I,F,j,O,u,P,m),b.moveTo(x.cx+x.x01,x.cy+x.y01),Ph.a&&A>h.a?z>h.a?(x=f(j,O,I,F,i,-z,m),w=f(R,U,Y,B,i,-z,m),b.lineTo(x.cx+x.x01,x.cy+x.y01),z0)for(var e,i=t[0],u=n[0],a=t[r]-i,o=n[r]-u,c=-1;++c<=r;)e=c/r,this._basis.point(this._beta*t[c]+(1-this._beta)*(i+e*a),this._beta*n[c]+(1-this._beta)*(u+e*o));this._x=this._y=null,this._basis.lineEnd()},point:function(t,n){this._x.push(+t),this._y.push(+n)}},n.a=function t(n){function r(t){return 1===n?new i.b(t):new e(t,n)}return r.beta=function(n){return t(+n)},r}(.85)},function(t,n,r){"use strict";function e(t,n){this._context=t,this._alpha=n}var i=r(153),u=r(45),a=r(81);e.prototype={areaStart:u.a,areaEnd:u.a,lineStart:function(){this._x0=this._x1=this._x2=this._x3=this._x4=this._x5=this._y0=this._y1=this._y2=this._y3=this._y4=this._y5=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){switch(this._point){case 1:this._context.moveTo(this._x3,this._y3),this._context.closePath();break;case 2:this._context.lineTo(this._x3,this._y3),this._context.closePath();break;case 3:this.point(this._x3,this._y3),this.point(this._x4,this._y4),this.point(this._x5,this._y5)}},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,i=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+i*i,this._alpha))}switch(this._point){case 0:this._point=1,this._x3=t,this._y3=n;break;case 1:this._point=2,this._context.moveTo(this._x4=t,this._y4=n);break;case 2:this._point=3,this._x5=t,this._y5=n;break;default:r.i(a.b)(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return n?new e(t,n):new i.b(t,0)}return r.alpha=function(n){return t(+n)},r}(.5)},function(t,n,r){"use strict";function e(t,n){this._context=t,this._alpha=n}var i=r(154),u=r(81);e.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._x2=this._y0=this._y1=this._y2=NaN,this._l01_a=this._l12_a=this._l23_a=this._l01_2a=this._l12_2a=this._l23_2a=this._point=0},lineEnd:function(){(this._line||0!==this._line&&3===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){if(t=+t,n=+n,this._point){var e=this._x2-t,i=this._y2-n;this._l23_a=Math.sqrt(this._l23_2a=Math.pow(e*e+i*i,this._alpha))}switch(this._point){case 0:this._point=1;break;case 1:this._point=2;break;case 2:this._point=3,this._line?this._context.lineTo(this._x2,this._y2):this._context.moveTo(this._x2,this._y2);break;case 3:this._point=4;default:r.i(u.b)(this,t,n)}this._l01_a=this._l12_a,this._l12_a=this._l23_a,this._l01_2a=this._l12_2a,this._l12_2a=this._l23_2a,this._x0=this._x1,this._x1=this._x2,this._x2=t,this._y0=this._y1,this._y1=this._y2,this._y2=n}},n.a=function t(n){function r(t){return n?new e(t,n):new i.b(t,0)}return r.alpha=function(n){return t(+n)},r}(.5)},function(t,n,r){"use strict";function e(t){this._context=t}var i=r(45);e.prototype={areaStart:i.a,areaEnd:i.a,lineStart:function(){this._point=0},lineEnd:function(){this._point&&this._context.closePath()},point:function(t,n){t=+t,n=+n,this._point?this._context.lineTo(t,n):(this._point=1,this._context.moveTo(t,n))}},n.a=function(t){return new e(t)}},function(t,n,r){"use strict";function e(t){return t<0?-1:1}function i(t,n,r){var i=t._x1-t._x0,u=n-t._x1,a=(t._y1-t._y0)/(i||u<0&&-0),o=(r-t._y1)/(u||i<0&&-0),c=(a*u+o*i)/(i+u);return(e(a)+e(o))*Math.min(Math.abs(a),Math.abs(o),.5*Math.abs(c))||0}function u(t,n){var r=t._x1-t._x0;return r?(3*(t._y1-t._y0)/r-n)/2:n}function a(t,n,r){var e=t._x0,i=t._y0,u=t._x1,a=t._y1,o=(u-e)/3;t._context.bezierCurveTo(e+o,i+o*n,u-o,a-o*r,u,a)}function o(t){this._context=t}function c(t){this._context=new f(t)}function f(t){this._context=t}function s(t){return new o(t)}function l(t){return new c(t)}n.a=s,n.b=l,o.prototype={areaStart:function(){this._line=0},areaEnd:function(){this._line=NaN},lineStart:function(){this._x0=this._x1=this._y0=this._y1=this._t0=NaN,this._point=0},lineEnd:function(){switch(this._point){case 2:this._context.lineTo(this._x1,this._y1);break;case 3:a(this,this._t0,u(this,this._t0))}(this._line||0!==this._line&&1===this._point)&&this._context.closePath(),this._line=1-this._line},point:function(t,n){var r=NaN;if(t=+t,n=+n,t!==this._x1||n!==this._y1){switch(this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;break;case 2:this._point=3,a(this,u(this,r=i(this,t,n)),r);break;default:a(this,this._t0,r=i(this,t,n))}this._x0=this._x1,this._x1=t,this._y0=this._y1,this._y1=n,this._t0=r}}},(c.prototype=Object.create(o.prototype)).point=function(t,n){o.prototype.point.call(this,n,t)},f.prototype={moveTo:function(t,n){this._context.moveTo(n,t)},closePath:function(){this._context.closePath()},lineTo:function(t,n){this._context.lineTo(n,t)},bezierCurveTo:function(t,n,r,e,i,u){this._context.bezierCurveTo(n,t,e,r,u,i)}}},function(t,n,r){"use strict";function e(t){this._context=t}function i(t){var n,r,e=t.length-1,i=new Array(e),u=new Array(e),a=new Array(e);for(i[0]=0,u[0]=2,a[0]=t[0]+2*t[1],n=1;n=0;--n)i[n]=(a[n]-i[n+1])/u[n];for(u[e-1]=(t[e]+i[e-1])/2,n=0;n=0&&(this._t=1-this._t,this._line=1-this._line)},point:function(t,n){switch(t=+t,n=+n,this._point){case 0:this._point=1,this._line?this._context.lineTo(t,n):this._context.moveTo(t,n);break;case 1:this._point=2;default:if(this._t<=0)this._context.lineTo(this._x,n),this._context.lineTo(t,n);else{var r=this._x*(1-this._t)+t*this._t;this._context.lineTo(r,this._y),this._context.lineTo(r,n)}}this._x=t,this._y=n}},n.a=function(t){return new e(t,.5)}},function(t,n,r){"use strict";n.a=function(t,n){return nt?1:n>=t?0:NaN}},function(t,n,r){"use strict";n.a=function(t){return t}},function(t,n,r){"use strict";function e(t){return t.source}function i(t){return t.target}function u(t){function n(){var n,e=d.a.call(arguments),i=u.apply(this,e),s=a.apply(this,e);if(f||(f=n=r.i(h.a)()),t(f,+o.apply(this,(e[0]=i,e)),+c.apply(this,e),+o.apply(this,(e[0]=s,e)),+c.apply(this,e)),n)return f=null,n+""||null}var u=e,a=i,o=v.a,c=v.b,f=null;return n.source=function(t){return arguments.length?(u=t,n):u},n.target=function(t){return arguments.length?(a=t,n):a},n.x=function(t){return arguments.length?(o="function"==typeof t?t:r.i(p.a)(+t),n):o},n.y=function(t){return arguments.length?(c="function"==typeof t?t:r.i(p.a)(+t),n):c},n.context=function(t){return arguments.length?(f=null==t?null:t,n):f},n}function a(t,n,r,e,i){t.moveTo(n,r),t.bezierCurveTo(n=(n+e)/2,r,n,i,e,i)}function o(t,n,r,e,i){t.moveTo(n,r),t.bezierCurveTo(n,r=(r+i)/2,e,r,e,i)}function c(t,n,e,i,u){var a=r.i(g.a)(n,e),o=r.i(g.a)(n,e=(e+u)/2),c=r.i(g.a)(i,e),f=r.i(g.a)(i,u);t.moveTo(a[0],a[1]),t.bezierCurveTo(o[0],o[1],c[0],c[1],f[0],f[1])}function f(){return u(a)}function s(){return u(o)}function l(){var t=u(c);return t.angle=t.x,delete t.x,t.radius=t.y,delete t.y,t}var h=r(14),d=r(152),p=r(16),v=r(84),g=r(157);n.a=f,n.b=s,n.c=l},function(t,n,r){"use strict";n.a=function(t,n){if((o=t.length)>1)for(var r,e,i,u,a,o,c=0,f=t[n[0]].length;c=0?(e[0]=u,e[1]=u+=i):i<0?(e[1]=a,e[0]=a+=i):e[0]=u}},function(t,n,r){"use strict";var e=r(30);n.a=function(t,n){if((u=t.length)>0){for(var i,u,a,o=0,c=t[0].length;o0){for(var i,u=0,a=t[n[0]],o=a.length;u0&&(u=(i=t[n[0]]).length)>0){for(var i,u,a,o=0,c=1;c0&&(p+=h);for(null!=o?v.sort(function(t,n){return o(g[t],g[n])}):null!=c&&v.sort(function(n,r){return c(t[n],t[r])}),r=0,i=p?(_-d*m)/p:0;r0?h*i:0)+m,g[e]={data:t[e],index:r,value:h,startAngle:y,endAngle:u,padAngle:b};return g}var n=u.a,o=i.a,c=null,f=r.i(e.a)(0),s=r.i(e.a)(a.c),l=r.i(e.a)(0);return t.value=function(i){return arguments.length?(n="function"==typeof i?i:r.i(e.a)(+i),t):n},t.sortValues=function(n){return arguments.length?(o=n,c=null,t):o},t.sort=function(n){return arguments.length?(c=n,o=null,t):c},t.startAngle=function(n){return arguments.length?(f="function"==typeof n?n:r.i(e.a)(+n),t):f},t.endAngle=function(n){return arguments.length?(s="function"==typeof n?n:r.i(e.a)(+n),t):s},t.padAngle=function(n){return arguments.length?(l="function"==typeof n?n:r.i(e.a)(+n),t):l},t}},function(t,n,r){"use strict";function e(t,n){return t[n]}var i=r(152),u=r(16),a=r(30),o=r(31);n.a=function(){function t(t){var r,e,i=n.apply(this,arguments),u=t.length,a=i.length,o=new Array(a);for(r=0;r0?t>1?r.i(e.a)(function(n){n.setTime(Math.floor(n/t)*t)},function(n,r){n.setTime(+n+r*t)},function(n,r){return(r-n)/t}):i:null},n.a=i;var u=i.range},function(t,n,r){"use strict";var e=r(2),i=r(9);r.d(n,"b",function(){return a});var u=r.i(e.a)(function(t){t.setTime(Math.floor(t/i.d)*i.d)},function(t,n){t.setTime(+t+n*i.d)},function(t,n){return(n-t)/i.d},function(t){return t.getMinutes()});n.a=u;var a=u.range},function(t,n,r){"use strict";var e=r(2);r.d(n,"b",function(){return u});var i=r.i(e.a)(function(t){t.setDate(1),t.setHours(0,0,0,0)},function(t,n){t.setMonth(t.getMonth()+n)},function(t,n){return n.getMonth()-t.getMonth()+12*(n.getFullYear()-t.getFullYear())},function(t){return t.getMonth()});n.a=i;var u=i.range},function(t,n,r){"use strict";var e=r(2),i=r(9);r.d(n,"b",function(){return a});var u=r.i(e.a)(function(t){t.setTime(Math.floor(t/i.e)*i.e)},function(t,n){t.setTime(+t+n*i.e)},function(t,n){return(n-t)/i.e},function(t){return t.getUTCSeconds()});n.a=u;var a=u.range},function(t,n,r){"use strict";var e=r(2),i=r(9);r.d(n,"b",function(){return a});var u=r.i(e.a)(function(t){t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+n)},function(t,n){return(n-t)/i.b},function(t){return t.getUTCDate()-1});n.a=u;var a=u.range},function(t,n,r){"use strict";var e=r(2),i=r(9);r.d(n,"b",function(){return a});var u=r.i(e.a)(function(t){t.setUTCMinutes(0,0,0)},function(t,n){t.setTime(+t+n*i.c)},function(t,n){return(n-t)/i.c},function(t){return t.getUTCHours()});n.a=u;var a=u.range},function(t,n,r){"use strict";var e=r(2),i=r(9);r.d(n,"b",function(){return a});var u=r.i(e.a)(function(t){t.setUTCSeconds(0,0)},function(t,n){t.setTime(+t+n*i.d)},function(t,n){return(n-t)/i.d},function(t){return t.getUTCMinutes()});n.a=u;var a=u.range},function(t,n,r){"use strict";var e=r(2);r.d(n,"b",function(){return u});var i=r.i(e.a)(function(t){t.setUTCDate(1),t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCMonth(t.getUTCMonth()+n)},function(t,n){return n.getUTCMonth()-t.getUTCMonth()+12*(n.getUTCFullYear()-t.getUTCFullYear())},function(t){return t.getUTCMonth()});n.a=i;var u=i.range},function(t,n,r){"use strict";function e(t){return r.i(i.a)(function(n){n.setUTCDate(n.getUTCDate()-(n.getUTCDay()+7-t)%7),n.setUTCHours(0,0,0,0)},function(t,n){t.setUTCDate(t.getUTCDate()+7*n)},function(t,n){return(n-t)/u.a})}var i=r(2),u=r(9);r.d(n,"a",function(){return a}),r.d(n,"c",function(){return o}),r.d(n,"e",function(){return c}),r.d(n,"g",function(){return f}),r.d(n,"i",function(){return s}),r.d(n,"k",function(){return l}),r.d(n,"m",function(){return h}),r.d(n,"b",function(){return d}),r.d(n,"d",function(){return p}),r.d(n,"f",function(){return v}),r.d(n,"h",function(){return g}),r.d(n,"j",function(){return y}),r.d(n,"l",function(){return _}),r.d(n,"n",function(){return b});var a=e(0),o=e(1),c=e(2),f=e(3),s=e(4),l=e(5),h=e(6),d=a.range,p=o.range,v=c.range,g=f.range,y=s.range,_=l.range,b=h.range},function(t,n,r){"use strict";var e=r(2);r.d(n,"b",function(){return u});var i=r.i(e.a)(function(t){t.setUTCMonth(0,1),t.setUTCHours(0,0,0,0)},function(t,n){t.setUTCFullYear(t.getUTCFullYear()+n)},function(t,n){return n.getUTCFullYear()-t.getUTCFullYear()},function(t){return t.getUTCFullYear()});i.every=function(t){return isFinite(t=Math.floor(t))&&t>0?r.i(e.a)(function(n){n.setUTCFullYear(Math.floor(n.getUTCFullYear()/t)*t),n.setUTCMonth(0,1),n.setUTCHours(0,0,0,0)},function(n,r){n.setUTCFullYear(n.getUTCFullYear()+r*t)}):null},n.a=i;var u=i.range},function(t,n,r){"use strict";function e(t){return r.i(i.a)(function(n){n.setDate(n.getDate()-(n.getDay()+7-t)%7),n.setHours(0,0,0,0)},function(t,n){t.setDate(t.getDate()+7*n)},function(t,n){return(n-t-(n.getTimezoneOffset()-t.getTimezoneOffset())*u.d)/u.a})}var i=r(2),u=r(9);r.d(n,"a",function(){return a}),r.d(n,"c",function(){return o}),r.d(n,"e",function(){return c}),r.d(n,"g",function(){return f}),r.d(n,"i",function(){return s}),r.d(n,"k",function(){return l}),r.d(n,"m",function(){return h}),r.d(n,"b",function(){return d}),r.d(n,"d",function(){return p}),r.d(n,"f",function(){return v}),r.d(n,"h",function(){return g}),r.d(n,"j",function(){return y}),r.d(n,"l",function(){return _}),r.d(n,"n",function(){return b});var a=e(0),o=e(1),c=e(2),f=e(3),s=e(4),l=e(5),h=e(6),d=a.range,p=o.range,v=c.range,g=f.range,y=s.range,_=l.range,b=h.range},function(t,n,r){"use strict";var e=r(2);r.d(n,"b",function(){return u});var i=r.i(e.a)(function(t){t.setMonth(0,1),t.setHours(0,0,0,0)},function(t,n){t.setFullYear(t.getFullYear()+n)},function(t,n){return n.getFullYear()-t.getFullYear()},function(t){return t.getFullYear()});i.every=function(t){return isFinite(t=Math.floor(t))&&t>0?r.i(e.a)(function(n){n.setFullYear(Math.floor(n.getFullYear()/t)*t),n.setMonth(0,1),n.setHours(0,0,0,0)},function(n,r){n.setFullYear(n.getFullYear()+r*t)}):null},n.a=i;var u=i.range},function(t,n,r){"use strict";var e=r(87);n.a=function(t,n,i){var u=new e.d,a=n;return null==n?(u.restart(t,n,i),u):(n=+n,i=null==i?r.i(e.a)():+i,u.restart(function r(e){e+=a,u.restart(r,a+=n,i),t(e)},n,i),u)}},function(t,n,r){"use strict";var e=r(87);n.a=function(t,n,r){var i=new e.d;return n=null==n?0:+n,i.restart(function(r){i.stop(),t(r+n)},n,r),i}},function(t,n,r){"use strict";var e=r(11),i=r(6),u=[null];n.a=function(t,n){var r,a,o=t.__transition;if(o){n=null==n?null:n+"";for(a in o)if((r=o[a]).state>i.d&&r.name===n)return new e.b([[t]],u,n,+a)}return null}},function(t,n,r){"use strict";var e=r(1),i=r(436),u=r(437);e.j.prototype.interrupt=i.a,e.j.prototype.transition=u.a},function(t,n,r){"use strict";var e=r(167);n.a=function(t){return this.each(function(){r.i(e.a)(this,t)})}},function(t,n,r){"use strict";function e(t,n){for(var e;!(e=t.__transition)||!(e=e[n]);)if(!(t=t.parentNode))return c.time=r.i(o.a)(),c;return e}var i=r(11),u=r(6),a=r(107),o=r(47),c={time:null,delay:0,duration:250,ease:a.i};n.a=function(t){var n,a;t instanceof i.b?(n=t._id,t=t._name):(n=r.i(i.c)(),(a=c).time=r.i(o.a)(),t=null==t?null:t+"");for(var f=this._groups,s=f.length,l=0;l=0&&(t=t.slice(0,n)),!t||"start"===t})}function i(t,n,r){var i,a,o=e(n)?u.g:u.e;return function(){var e=o(this,t),u=e.on;u!==i&&(a=(i=u).copy()).on(n,r),e.on=a}}var u=r(6);n.a=function(t,n){var e=this._id;return arguments.length<2?r.i(u.f)(this.node(),e).on.on(t):this.each(i(e,t,n))}},function(t,n,r){"use strict";function e(t){return function(){var n=this.parentNode;for(var r in this.__transition)if(+r!==t)return;n&&n.removeChild(this)}}n.a=function(){return this.on("end.remove",e(this._id))}},function(t,n,r){"use strict";var e=r(1),i=r(11),u=r(6);n.a=function(t){var n=this._name,a=this._id;"function"!=typeof t&&(t=r.i(e.k)(t));for(var o=this._groups,c=o.length,f=new Array(c),s=0;sp.b)v=v.L;else{if(!((a=o-f(v,s))>p.b)){u>-p.b?(n=v.P,e=v):a>-p.b?(n=v,e=v.N):n=e=v;break}if(!v.R){n=v;break}v=v.R}r.i(l.d)(t);var g=i(t);if(p.e.insert(n,g),n||e){if(n===e)return r.i(h.b)(n),e=i(n.site),p.e.insert(g,e),g.edge=e.edge=r.i(d.d)(n.site,g.site),r.i(h.c)(n),void r.i(h.c)(e);if(!e)return void(g.edge=r.i(d.d)(n.site,g.site));r.i(h.b)(n),r.i(h.b)(e);var y=n.site,_=y[0],b=y[1],m=t[0]-_,x=t[1]-b,w=e.site,M=w[0]-_,k=w[1]-b,T=2*(m*k-x*M),N=m*m+x*x,A=M*M+k*k,E=[(k*N-x*A)/T+_,(m*A-M*N)/T+b];r.i(d.c)(e.edge,y,w,E),g.edge=r.i(d.d)(y,t,null,E),e.edge=r.i(d.d)(t,w,null,E),r.i(h.c)(n),r.i(h.c)(e)}}function c(t,n){var r=t.site,e=r[0],i=r[1],u=i-n;if(!u)return e;var a=t.P;if(!a)return-1/0;r=a.site;var o=r[0],c=r[1],f=c-n;if(!f)return o;var s=o-e,l=1/u-1/f,h=s/f;return l?(-h+Math.sqrt(h*h-2*l*(s*s/(-2*f)-c+f/2+i-u/2)))/l+e:(e+o)/2}function f(t,n){var r=t.N;if(r)return c(r,n);var e=t.site;return e[1]===n?e[0]:1/0}var s=r(90),l=r(169),h=r(170),d=r(89),p=r(32);n.b=a,n.a=o;var v=[]},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(t){return t[0]}function i(t){return t[1]}n.a=e,n.b=i},function(t,n,r){"use strict";var e=r(456),i=r(457),u=r(32);n.a=function(){function t(t){return new u.a(t.map(function(r,e){var i=[Math.round(n(r,e,t)/u.b)*u.b,Math.round(a(r,e,t)/u.b)*u.b];return i.index=e,i.data=r,i}),o)}var n=i.a,a=i.b,o=null;return t.polygons=function(n){return t(n).polygons()},t.links=function(n){return t(n).links()},t.triangles=function(n){return t(n).triangles()},t.x=function(i){return arguments.length?(n="function"==typeof i?i:r.i(e.a)(+i),t):n},t.y=function(n){return arguments.length?(a="function"==typeof n?n:r.i(e.a)(+n),t):a},t.extent=function(n){return arguments.length?(o=null==n?null:[[+n[0][0],+n[0][1]],[+n[1][0],+n[1][1]]],t):o&&[[o[0][0],o[0][1]],[o[1][0],o[1][1]]]},t.size=function(n){return arguments.length?(o=null==n?null:[[0,0],[+n[0],+n[1]]],t):o&&[o[1][0]-o[0][0],o[1][1]-o[0][1]]},t}},function(t,n,r){"use strict";var e=r(463);r.d(n,"a",function(){return e.a});var i=r(171);r.d(n,"b",function(){return i.a}),r.d(n,"c",function(){return i.b})},function(t,n,r){"use strict";n.a=function(t){return function(){return t}}},function(t,n,r){"use strict";function e(t,n,r){this.target=t,this.type=n,this.transform=r}n.a=e},function(t,n,r){"use strict";function e(){i.q.stopImmediatePropagation()}var i=r(1);n.b=e,n.a=function(){i.q.preventDefault(),i.q.stopImmediatePropagation()}},function(t,n,r){"use strict";function e(){return!h.q.button}function i(){var t,n,r=this;return r instanceof SVGElement?(r=r.ownerSVGElement||r,t=r.width.baseVal.value,n=r.height.baseVal.value):(t=r.clientWidth,n=r.clientHeight),[[0,0],[t,n]]}function u(){return this.__zoom||g.b}function a(){return-h.q.deltaY*(h.q.deltaMode?120:1)/500}function o(){return"ontouchstart"in this}function c(t,n,r){var e=t.invertX(n[0][0])-r[0][0],i=t.invertX(n[1][0])-r[1][0],u=t.invertY(n[0][1])-r[0][1],a=t.invertY(n[1][1])-r[1][1];return t.translate(i>e?(e+i)/2:Math.min(0,e)||Math.max(0,i),a>u?(u+a)/2:Math.min(0,u)||Math.max(0,a))}var f=r(12),s=r(54),l=r(4),h=r(1),d=r(88),p=r(460),v=r(461),g=r(171),y=r(462);n.a=function(){function t(t){t.property("__zoom",u).on("wheel.zoom",M).on("mousedown.zoom",k).on("dblclick.zoom",T).filter(L).on("touchstart.zoom",N).on("touchmove.zoom",A).on("touchend.zoom touchcancel.zoom",E).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function n(t,n){return n=Math.max(R[0],Math.min(R[1],n)),n===t.k?t:new g.c(n,t.x,t.y)}function _(t,n,r){var e=n[0]-r[0]*t.k,i=n[1]-r[1]*t.k;return e===t.x&&i===t.y?t:new g.c(t.k,e,i)}function b(t){return[(+t[0][0]+ +t[1][0])/2,(+t[0][1]+ +t[1][1])/2]}function m(t,n,r){t.on("start.zoom",function(){x(this,arguments).start()}).on("interrupt.zoom end.zoom",function(){x(this,arguments).end()}).tween("zoom",function(){var t=this,e=arguments,i=x(t,e),u=z.apply(t,e),a=r||b(u),o=Math.max(u[1][0]-u[0][0],u[1][1]-u[0][1]),c=t.__zoom,f="function"==typeof n?n.apply(t,e):n,s=O(c.invert(a).concat(o/c.k),f.invert(a).concat(o/f.k));return function(t){if(1===t)t=f;else{var n=s(t),r=o/n[2];t=new g.c(r,a[0]-n[0]*r,a[1]-n[1]*r)}i.zoom(null,t)}})}function x(t,n){for(var r,e=0,i=I.length;eH}e.zoom("mouse",P(_(e.that.__zoom,e.mouse[0]=r.i(h.d)(e.that),e.mouse[1]),e.extent,U))}function n(){i.on("mousemove.zoom mouseup.zoom",null),r.i(s.c)(h.q.view,e.moved),r.i(y.a)(),e.end()}if(!C&&q.apply(this,arguments)){var e=x(this,arguments),i=r.i(h.h)(h.q.view).on("mousemove.zoom",t,!0).on("mouseup.zoom",n,!0),u=r.i(h.d)(this),a=h.q.clientX,o=h.q.clientY;r.i(s.b)(h.q.view),r.i(y.b)(),e.mouse=[u,this.__zoom.invert(u)],r.i(d.c)(this),e.start()}}function T(){if(q.apply(this,arguments)){var e=this.__zoom,i=r.i(h.d)(this),u=e.invert(i),a=e.k*(h.q.shiftKey?.5:2),o=P(_(n(e,a),i,u),z.apply(this,arguments),U);r.i(y.a)(),j>0?r.i(h.h)(this).transition().duration(j).call(m,o,i):r.i(h.h)(this).call(t.transform,o)}}function N(){if(q.apply(this,arguments)){var t,n,e,i,u=x(this,arguments),a=h.q.changedTouches,o=a.length;for(r.i(y.b)(),n=0;n0&&(l=e("port",s.attr("href"))),l||(l="53333");var h=new WebSocket("ws://localhost:"+l);h.onopen=function(t){},h.onclose=function(t){f.forEach(function(t){return t.stop()})},h.onmessage=function(e){var i=JSON.parse(e.data);switch(i.type){case"configure":t(i);break;case"data":r(i);break;case"status":n(i);break;default:console.log("Got unrecognized message type: "+i.type)}}}Object.defineProperty(n,"__esModule",{value:!0});var u=r(172),a=r(173),o=r(174),c=r(49);i()}]); //# sourceMappingURL=main.bundle.js.map \ No newline at end of file diff --git a/images/vs-code-screenshot.png b/images/vs-code-screenshot.png new file mode 100644 index 00000000..03923781 Binary files /dev/null and b/images/vs-code-screenshot.png differ diff --git a/package.json b/package.json index 99233c2f..ea0a0b31 100644 --- a/package.json +++ b/package.json @@ -14,6 +14,21 @@ { "command": "cortexPeripherals.selectedNode", "title": "Selected" + }, + { + "category": "Cortex-Debug", + "command": "marus25.cortex-debug-openocd.examineMemory", + "title": "View Memory" + }, + { + "category": "Cortex-Debug", + "command": "marus25.cortex-debug-jlink.examineMemory", + "title": "View Memory" + }, + { + "category": "Cortex-Debug", + "command": "marus25.cortex-debug-pyocd.examineMemory", + "title": "View Memory" } ], "debuggers": [ @@ -70,29 +85,25 @@ "description": "Minimum value for the Y-Axis", "type": "number" }, - "ports": { - "description": "SWO Port configuration. Ports selected must be configured as a \"graph\" format port in the \"swoConfig\" section", + "plots": { + "description": "Plot configurations. Data sources must be configured for \"graph\" (or \"advanced\" with a decoder that sends graph data) in the \"swoConfig\" section", "items": { "properties": { "color": { "pattern": "^#[0-9a-fA-F]{3}([0-9a-fA-F]{3})?$", "type": "string" }, + "graphId": { + "description": "Graph Data Source Id for the plot.", + "type": "string" + }, "label": { "description": "A label for this data set", "type": "string" - }, - "number": { - "default": 0, - "description": "The SWO port number", - "maximum": 31, - "minimum": 0, - "type": "number" } }, "required": [ - "number", - "label" + "graphId" ], "type": "object" }, @@ -112,7 +123,7 @@ }, "required": [ "label", - "ports", + "plots", "minimum", "maximum" ], @@ -135,6 +146,10 @@ ], "type": "string" }, + "xGraphId": { + "description": "Graph Data Source Id for the X axis", + "type": "string" + }, "xMaximum": { "default": 65535, "description": "Maximum value on the X-Axis", @@ -145,9 +160,9 @@ "description": "Minimum value on the X-Axis", "type": "number" }, - "xPort": { - "description": "SWO Port for the X axis", - "type": "number" + "yGraphId": { + "description": "Graph Data Source Id Port for the Y axis", + "type": "string" }, "yMaximum": { "default": 65535, @@ -158,15 +173,11 @@ "default": 0, "description": "Minimum value on the Y-Axis", "type": "number" - }, - "yPort": { - "description": "SWO Port for the Y axis", - "type": "number" } }, "required": [ - "xPort", - "yPort", + "xGraphId", + "yGraphId", "label" ], "type": "object" @@ -225,43 +236,142 @@ "ports": { "description": "SWO Port Configuration", "items": { - "properties": { - "encoding": { - "default": "unsigned", - "description": "This property is only used for binary and graph output formats.", - "enum": [ - "unsigned", - "signed", - "Q16.16" + "anyOf": [ + { + "properties": { + "label": { + "description": "A label for the output window.", + "type": "string" + }, + "number": { + "description": "SWO Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "type": { + "enum": [ + "console" + ], + "type": "string" + } + }, + "required": [ + "number" ], - "type": "string" - }, - "format": { - "description": "Output format for this port.", - "enum": [ - "console", - "binary", - "graph" + "type": "object" + }, + { + "properties": { + "encoding": { + "default": "unsigned", + "description": "This property is only used for binary and graph output formats.", + "enum": [ + "unsigned", + "signed", + "Q16.16", + "float" + ], + "type": "string" + }, + "label": { + "description": "A label for the output window.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "scale": { + "default": 1, + "description": "This setting will scale the raw value from the ITM port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", + "type": "number" + }, + "type": { + "enum": [ + "binary" + ], + "type": "string" + } + }, + "required": [ + "number" ], - "type": "string" - }, - "number": { - "description": "SWO Port Number", - "maximum": 31, - "minimum": 0, - "type": "number" + "type": "object" + }, + { + "properties": { + "encoding": { + "default": "unsigned", + "description": "This property is only used for binary and graph output formats.", + "enum": [ + "unsigned", + "signed", + "Q16.16", + "float" + ], + "type": "string" + }, + "graphId": { + "description": "The identifier to use for this data in graph configurations.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "scale": { + "default": 1, + "description": "This setting will scale the raw value from the ITM port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", + "type": "number" + }, + "type": { + "enum": [ + "graph" + ], + "type": "string" + } + }, + "required": [ + "number", + "graphId" + ], + "type": "object" }, - "scale": { - "default": 1, - "description": "This setting will scale the raw value from the SWO port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", - "type": "number" + { + "properties": { + "config": { + "additionalProperties": true, + "type": "object" + }, + "decoder": { + "description": "Path to a javascript module to implement the decoding functionality.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "type": { + "enum": [ + "advanced" + ], + "type": "string" + } + }, + "required": [ + "number", + "decoder" + ], + "type": "object" } - }, - "required": [ - "number", - "format" - ], - "type": "object" + ] }, "type": "array" }, @@ -331,29 +441,25 @@ "description": "Minimum value for the Y-Axis", "type": "number" }, - "ports": { - "description": "SWO Port configuration. Ports selected must be configured as a \"graph\" format port in the \"swoConfig\" section", + "plots": { + "description": "Plot configurations. Data sources must be configured for \"graph\" (or \"advanced\" with a decoder that sends graph data) in the \"swoConfig\" section", "items": { "properties": { "color": { "pattern": "^#[0-9a-fA-F]{3}([0-9a-fA-F]{3})?$", "type": "string" }, + "graphId": { + "description": "Graph Data Source Id for the plot.", + "type": "string" + }, "label": { "description": "A label for this data set", "type": "string" - }, - "number": { - "default": 0, - "description": "The SWO port number", - "maximum": 31, - "minimum": 0, - "type": "number" } }, "required": [ - "number", - "label" + "graphId" ], "type": "object" }, @@ -373,7 +479,7 @@ }, "required": [ "label", - "ports", + "plots", "minimum", "maximum" ], @@ -396,6 +502,10 @@ ], "type": "string" }, + "xGraphId": { + "description": "Graph Data Source Id for the X axis", + "type": "string" + }, "xMaximum": { "default": 65535, "description": "Maximum value on the X-Axis", @@ -406,9 +516,9 @@ "description": "Minimum value on the X-Axis", "type": "number" }, - "xPort": { - "description": "SWO Port for the X axis", - "type": "number" + "yGraphId": { + "description": "Graph Data Source Id Port for the Y axis", + "type": "string" }, "yMaximum": { "default": 65535, @@ -419,15 +529,11 @@ "default": 0, "description": "Minimum value on the Y-Axis", "type": "number" - }, - "yPort": { - "description": "SWO Port for the Y axis", - "type": "number" } }, "required": [ - "xPort", - "yPort", + "xGraphId", + "yGraphId", "label" ], "type": "object" @@ -486,43 +592,142 @@ "ports": { "description": "SWO Port Configuration", "items": { - "properties": { - "encoding": { - "default": "unsigned", - "description": "This property is only used for binary and graph output formats.", - "enum": [ - "unsigned", - "signed", - "Q16.16" + "anyOf": [ + { + "properties": { + "label": { + "description": "A label for the output window.", + "type": "string" + }, + "number": { + "description": "SWO Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "type": { + "enum": [ + "console" + ], + "type": "string" + } + }, + "required": [ + "number" ], - "type": "string" - }, - "format": { - "description": "Output format for this port.", - "enum": [ - "console", - "binary", - "graph" + "type": "object" + }, + { + "properties": { + "encoding": { + "default": "unsigned", + "description": "This property is only used for binary and graph output formats.", + "enum": [ + "unsigned", + "signed", + "Q16.16", + "float" + ], + "type": "string" + }, + "label": { + "description": "A label for the output window.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "scale": { + "default": 1, + "description": "This setting will scale the raw value from the ITM port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", + "type": "number" + }, + "type": { + "enum": [ + "binary" + ], + "type": "string" + } + }, + "required": [ + "number" ], - "type": "string" - }, - "number": { - "description": "SWO Port Number", - "maximum": 31, - "minimum": 0, - "type": "number" + "type": "object" + }, + { + "properties": { + "encoding": { + "default": "unsigned", + "description": "This property is only used for binary and graph output formats.", + "enum": [ + "unsigned", + "signed", + "Q16.16", + "float" + ], + "type": "string" + }, + "graphId": { + "description": "The identifier to use for this data in graph configurations.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "scale": { + "default": 1, + "description": "This setting will scale the raw value from the ITM port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", + "type": "number" + }, + "type": { + "enum": [ + "graph" + ], + "type": "string" + } + }, + "required": [ + "number", + "graphId" + ], + "type": "object" }, - "scale": { - "default": 1, - "description": "This setting will scale the raw value from the SWO port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", - "type": "number" + { + "properties": { + "config": { + "additionalProperties": true, + "type": "object" + }, + "decoder": { + "description": "Path to a javascript module to implement the decoding functionality.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "type": { + "enum": [ + "advanced" + ], + "type": "string" + } + }, + "required": [ + "number", + "decoder" + ], + "type": "object" } - }, - "required": [ - "number", - "format" - ], - "type": "object" + ] }, "type": "array" }, @@ -620,29 +825,25 @@ "description": "Minimum value for the Y-Axis", "type": "number" }, - "ports": { - "description": "SWO Port configuration. Ports selected must be configured as a \"graph\" format port in the \"swoConfig\" section", + "plots": { + "description": "Plot configurations. Data sources must be configured for \"graph\" (or \"advanced\" with a decoder that sends graph data) in the \"swoConfig\" section", "items": { "properties": { "color": { "pattern": "^#[0-9a-fA-F]{3}([0-9a-fA-F]{3})?$", "type": "string" }, + "graphId": { + "description": "Graph Data Source Id for the plot.", + "type": "string" + }, "label": { "description": "A label for this data set", "type": "string" - }, - "number": { - "default": 0, - "description": "The SWO port number", - "maximum": 31, - "minimum": 0, - "type": "number" } }, "required": [ - "number", - "label" + "graphId" ], "type": "object" }, @@ -662,7 +863,7 @@ }, "required": [ "label", - "ports", + "plots", "minimum", "maximum" ], @@ -685,6 +886,10 @@ ], "type": "string" }, + "xGraphId": { + "description": "Graph Data Source Id for the X axis", + "type": "string" + }, "xMaximum": { "default": 65535, "description": "Maximum value on the X-Axis", @@ -695,9 +900,9 @@ "description": "Minimum value on the X-Axis", "type": "number" }, - "xPort": { - "description": "SWO Port for the X axis", - "type": "number" + "yGraphId": { + "description": "Graph Data Source Id Port for the Y axis", + "type": "string" }, "yMaximum": { "default": 65535, @@ -708,15 +913,11 @@ "default": 0, "description": "Minimum value on the Y-Axis", "type": "number" - }, - "yPort": { - "description": "SWO Port for the Y axis", - "type": "number" } }, "required": [ - "xPort", - "yPort", + "xGraphId", + "yGraphId", "label" ], "type": "object" @@ -781,43 +982,142 @@ "ports": { "description": "SWO Port Configuration", "items": { - "properties": { - "encoding": { - "default": "unsigned", - "description": "This property is only used for binary and graph output formats.", - "enum": [ - "unsigned", - "signed", - "Q16.16" + "anyOf": [ + { + "properties": { + "label": { + "description": "A label for the output window.", + "type": "string" + }, + "number": { + "description": "SWO Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "type": { + "enum": [ + "console" + ], + "type": "string" + } + }, + "required": [ + "number" ], - "type": "string" - }, - "format": { - "description": "Output format for this port.", - "enum": [ - "console", - "binary", - "graph" + "type": "object" + }, + { + "properties": { + "encoding": { + "default": "unsigned", + "description": "This property is only used for binary and graph output formats.", + "enum": [ + "unsigned", + "signed", + "Q16.16", + "float" + ], + "type": "string" + }, + "label": { + "description": "A label for the output window.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "scale": { + "default": 1, + "description": "This setting will scale the raw value from the ITM port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", + "type": "number" + }, + "type": { + "enum": [ + "binary" + ], + "type": "string" + } + }, + "required": [ + "number" ], - "type": "string" - }, - "number": { - "description": "SWO Port Number", - "maximum": 31, - "minimum": 0, - "type": "number" + "type": "object" + }, + { + "properties": { + "encoding": { + "default": "unsigned", + "description": "This property is only used for binary and graph output formats.", + "enum": [ + "unsigned", + "signed", + "Q16.16", + "float" + ], + "type": "string" + }, + "graphId": { + "description": "The identifier to use for this data in graph configurations.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "scale": { + "default": 1, + "description": "This setting will scale the raw value from the ITM port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", + "type": "number" + }, + "type": { + "enum": [ + "graph" + ], + "type": "string" + } + }, + "required": [ + "number", + "graphId" + ], + "type": "object" }, - "scale": { - "default": 1, - "description": "This setting will scale the raw value from the SWO port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", - "type": "number" + { + "properties": { + "config": { + "additionalProperties": true, + "type": "object" + }, + "decoder": { + "description": "Path to a javascript module to implement the decoding functionality.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "type": { + "enum": [ + "advanced" + ], + "type": "string" + } + }, + "required": [ + "number", + "decoder" + ], + "type": "object" } - }, - "required": [ - "number", - "format" - ], - "type": "object" + ] }, "type": "array" }, @@ -885,29 +1185,25 @@ "description": "Minimum value for the Y-Axis", "type": "number" }, - "ports": { - "description": "SWO Port configuration. Ports selected must be configured as a \"graph\" format port in the \"swoConfig\" section", + "plots": { + "description": "Plot configurations. Data sources must be configured for \"graph\" (or \"advanced\" with a decoder that sends graph data) in the \"swoConfig\" section", "items": { "properties": { "color": { "pattern": "^#[0-9a-fA-F]{3}([0-9a-fA-F]{3})?$", "type": "string" }, + "graphId": { + "description": "Graph Data Source Id for the plot.", + "type": "string" + }, "label": { "description": "A label for this data set", "type": "string" - }, - "number": { - "default": 0, - "description": "The SWO port number", - "maximum": 31, - "minimum": 0, - "type": "number" } }, "required": [ - "number", - "label" + "graphId" ], "type": "object" }, @@ -927,7 +1223,7 @@ }, "required": [ "label", - "ports", + "plots", "minimum", "maximum" ], @@ -950,6 +1246,10 @@ ], "type": "string" }, + "xGraphId": { + "description": "Graph Data Source Id for the X axis", + "type": "string" + }, "xMaximum": { "default": 65535, "description": "Maximum value on the X-Axis", @@ -960,9 +1260,9 @@ "description": "Minimum value on the X-Axis", "type": "number" }, - "xPort": { - "description": "SWO Port for the X axis", - "type": "number" + "yGraphId": { + "description": "Graph Data Source Id Port for the Y axis", + "type": "string" }, "yMaximum": { "default": 65535, @@ -973,15 +1273,11 @@ "default": 0, "description": "Minimum value on the Y-Axis", "type": "number" - }, - "yPort": { - "description": "SWO Port for the Y axis", - "type": "number" } }, "required": [ - "xPort", - "yPort", + "xGraphId", + "yGraphId", "label" ], "type": "object" @@ -1046,43 +1342,142 @@ "ports": { "description": "SWO Port Configuration", "items": { - "properties": { - "encoding": { - "default": "unsigned", - "description": "This property is only used for binary and graph output formats.", - "enum": [ - "unsigned", - "signed", - "Q16.16" + "anyOf": [ + { + "properties": { + "label": { + "description": "A label for the output window.", + "type": "string" + }, + "number": { + "description": "SWO Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "type": { + "enum": [ + "console" + ], + "type": "string" + } + }, + "required": [ + "number" ], - "type": "string" - }, - "format": { - "description": "Output format for this port.", - "enum": [ - "console", - "binary", - "graph" + "type": "object" + }, + { + "properties": { + "encoding": { + "default": "unsigned", + "description": "This property is only used for binary and graph output formats.", + "enum": [ + "unsigned", + "signed", + "Q16.16", + "float" + ], + "type": "string" + }, + "label": { + "description": "A label for the output window.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "scale": { + "default": 1, + "description": "This setting will scale the raw value from the ITM port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", + "type": "number" + }, + "type": { + "enum": [ + "binary" + ], + "type": "string" + } + }, + "required": [ + "number" ], - "type": "string" - }, - "number": { - "description": "SWO Port Number", - "maximum": 31, - "minimum": 0, - "type": "number" + "type": "object" + }, + { + "properties": { + "encoding": { + "default": "unsigned", + "description": "This property is only used for binary and graph output formats.", + "enum": [ + "unsigned", + "signed", + "Q16.16", + "float" + ], + "type": "string" + }, + "graphId": { + "description": "The identifier to use for this data in graph configurations.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "scale": { + "default": 1, + "description": "This setting will scale the raw value from the ITM port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", + "type": "number" + }, + "type": { + "enum": [ + "graph" + ], + "type": "string" + } + }, + "required": [ + "number", + "graphId" + ], + "type": "object" }, - "scale": { - "default": 1, - "description": "This setting will scale the raw value from the SWO port by the specified value. Can be used, for example, to scale a raw n-bit ADC reading to a voltage value. (e.g to scale a 12-bit ADC reading to a 3.3v scale you would need a scale value of 3.3/4096 = 0.0008056640625", - "type": "number" + { + "properties": { + "config": { + "additionalProperties": true, + "type": "object" + }, + "decoder": { + "description": "Path to a javascript module to implement the decoding functionality.", + "type": "string" + }, + "number": { + "description": "ITM Port Number", + "maximum": 31, + "minimum": 0, + "type": "number" + }, + "type": { + "enum": [ + "advanced" + ], + "type": "string" + } + }, + "required": [ + "number", + "decoder" + ], + "type": "object" } - }, - "required": [ - "number", - "format" - ], - "type": "object" + ] }, "type": "array" }, @@ -1128,9 +1523,247 @@ "runtime": "node", "type": "jlink-gdb", "variables": {} + }, + { + "configurationAttributes": { + "attach": { + "properties": { + "boardId": { + "description": "Connect to board by board id. Only needed if multiple PyOCD compatible boards are connected.", + "type": "string" + }, + "cwd": { + "description": "Path of project", + "type": "string" + }, + "debugger_args": { + "default": [], + "description": "Additional arguments to pass to GDB", + "type": "array" + }, + "executable": { + "description": "Path of executable", + "type": "string" + }, + "gdbpath": { + "default": "arm-none-eabi-gdb", + "description": "Path to the gdb executable or the command if in PATH", + "type": "string" + }, + "printCalls": { + "default": false, + "description": "Prints all GDB calls to the console", + "type": "boolean" + }, + "pyocdPath": { + "default": "pyocd-gdbserver", + "description": "Path to the pyocd-gdbserver executable", + "type": "string" + }, + "showDevDebugOutput": { + "default": false, + "description": "Prints all GDB responses to the console", + "type": "boolean" + }, + "svdFile": { + "default": null, + "description": "Path to an SVD file describing the peripherals of the microcontroller; if not supplied then one may be selected based upon the 'device' entered.", + "type": "string" + }, + "target": { + "description": "PyOCD Target identifier. Needed if debugging custom hardware; not needed for official MBed boards.", + "enum": [ + "kl25z", + "kl26z", + "lpc824", + "k82f25615", + "lpc11xx_32", + "kinetis", + "lpc800", + "lpc4088qsb", + "maxwsnenv", + "kl05z", + "k64f", + "lpc1768", + "lpc4088", + "lpc4330", + "max32600mbed", + "k66f18", + "w7500", + "ke18f16", + "k22f", + "lpc4088dm", + "ke15z7", + "kv11z7", + "nrf51", + "nrf52", + "kv10z7", + "k20d50m", + "kl46z", + "stm32f103rc", + "kl27z4", + "kw40z4", + "cortex_m", + "lpc11u24", + "stm32f051", + "kl02z", + "ncs36510", + "kl28z", + "kl43z4", + "kw01z4" + ], + "type": "string" + } + }, + "required": [ + "executable" + ] + }, + "launch": { + "properties": { + "boardId": { + "description": "Connect to board by board id. Only needed if multiple PyOCD compatible boards are connected.", + "type": "string" + }, + "cwd": { + "description": "Path of project", + "type": "string" + }, + "debugger_args": { + "default": [], + "description": "Additional arguments to pass to GDB", + "type": "array" + }, + "executable": { + "description": "Path of executable", + "type": "string" + }, + "gdbpath": { + "default": "arm-none-eabi-gdb", + "description": "Path to the gdb executable or the command if in PATH", + "type": "string" + }, + "printCalls": { + "default": false, + "description": "Prints all GDB calls to the console", + "type": "boolean" + }, + "pyocdPath": { + "default": "pyocd-gdbserver", + "description": "Path to the pyocd-gdbserver executable", + "type": "string" + }, + "showDevDebugOutput": { + "default": false, + "description": "Prints all GDB responses to the console", + "type": "boolean" + }, + "svdFile": { + "default": null, + "description": "Path to an SVD file describing the peripherals of the microcontroller; if not supplied then one may be selected based upon the 'device' entered.", + "type": "string" + }, + "target": { + "description": "PyOCD Target identifier. Needed if debugging custom hardware; not needed for official MBed boards.", + "enum": [ + "kl25z", + "kl26z", + "lpc824", + "k82f25615", + "lpc11xx_32", + "kinetis", + "lpc800", + "lpc4088qsb", + "maxwsnenv", + "kl05z", + "k64f", + "lpc1768", + "lpc4088", + "lpc4330", + "max32600mbed", + "k66f18", + "w7500", + "ke18f16", + "k22f", + "lpc4088dm", + "ke15z7", + "kv11z7", + "nrf51", + "nrf52", + "kv10z7", + "k20d50m", + "kl46z", + "stm32f103rc", + "kl27z4", + "kw40z4", + "cortex_m", + "lpc11u24", + "stm32f051", + "kl02z", + "ncs36510", + "kl28z", + "kl43z4", + "kw01z4" + ], + "type": "string" + } + }, + "required": [ + "executable" + ] + } + }, + "configurationSnippets": [ + { + "body": { + "cwd": "^\"\\${workspaceRoot}\"", + "executable": "${1:./bin/executable.elf}", + "name": "${6:Debug Microcontroller}", + "request": "launch", + "type": "pyocd-gdb" + }, + "description": "Debugs an embedded ARM Cortex-M microcontroller using GDB + PyOCD", + "label": "Cortex Debug: PyOCD" + } + ], + "enableBreakpointsFor": { + "languageIds": [ + "c", + "cpp", + "asm" + ] + }, + "extensions": [], + "label": "Cortex Debug: PyOCD", + "program": "./out/src/pyocd.js", + "runtime": "node", + "type": "pyocd-gdb", + "variables": {} } ], "menus": { + "commandPalette": [ + { + "command": "cortexPeripherals.updateNode", + "when": "false" + }, + { + "command": "cortexPeripherals.selectedNode", + "when": "false" + }, + { + "command": "marus25.cortex-debug-openocd.examineMemory", + "when": "debugType == openocd-gdb" + }, + { + "command": "marus25.cortex-debug-jlink.examineMemory", + "when": "debugType == jlink-gdb" + }, + { + "command": "marus25.cortex-debug-pyocd.examineMemory", + "when": "debugType == pyocd-gdb" + } + ], "view/item/context": [ { "command": "cortexPeripherals.updateNode", @@ -1168,6 +1801,16 @@ "id": "cortexRegisters-openocd", "name": "Cortex Registers", "when": "debugType == openocd-gdb" + }, + { + "id": "cortexPeripherals-pyocd", + "name": "Cortex Peripherals", + "when": "debugType == pyocd-gdb" + }, + { + "id": "cortexRegisters-pyocd", + "name": "Cortex Registers", + "when": "debugType == pyocd-gdb" } ] } @@ -1176,9 +1819,11 @@ "binary-parser": "^1.3.0", "cbarrick-circular-buffer": "^1.2.3", "portastic": "^1.0.1", + "protobufjs": "~6.8.4", "tmp": "0.0.33", "vscode-debugadapter": "^1.16.0", "vscode-debugprotocol": "^1.16.0", + "vscode-extension-telemetry": "0.0.10", "ws": "^3.3.2", "xml2js": "^0.4.19" }, @@ -1203,7 +1848,8 @@ ], "main": "./out/src/frontend/extension", "name": "cortex-debug", - "publisher": "marus", + "preview": true, + "publisher": "marus25", "repository": { "type": "git", "url": "https://github.com/Marus/cortex-debug.git" @@ -1213,5 +1859,5 @@ "postinstall": "node ./node_modules/vscode/bin/install", "vscode:prepublish": "tsc -p ./" }, - "version": "0.1.2" + "version": "0.1.6" } \ No newline at end of file diff --git a/src/backend/jlink.ts b/src/backend/jlink.ts index cae22af2..ae799efb 100644 --- a/src/backend/jlink.ts +++ b/src/backend/jlink.ts @@ -6,10 +6,12 @@ export class JLink extends EventEmitter { private process: any; private buffer: string; private errbuffer: string; + private initSent: boolean; constructor(public application: string, public device: string, public gdb_port: number, public swo_raw_port: number, public swo_port: number, public ipAddress: string, public serialNumber: string, public rtos: string) { super(); + this.initSent = false; this.buffer = ""; this.errbuffer = ""; } @@ -41,7 +43,7 @@ export class JLink extends EventEmitter { } exit() : void { - this.process.exit(); + this.process.kill(); } error() : void { @@ -58,6 +60,13 @@ export class JLink extends EventEmitter { else this.buffer += data.toString("utf8"); + if(this.buffer.indexOf('Waiting for GDB connection...') !== -1) { + if (!this.initSent) { + this.emit('jlink-init'); + this.initSent = true; + } + } + let end = this.buffer.lastIndexOf('\n'); if(end != -1) { this.onOutput(this.buffer.substr(0, end)); diff --git a/src/backend/mi2/mi2.ts b/src/backend/mi2/mi2.ts index 269576c6..42fb2920 100644 --- a/src/backend/mi2/mi2.ts +++ b/src/backend/mi2/mi2.ts @@ -191,18 +191,6 @@ export class MI2 extends EventEmitter implements IBackend { start(): Thenable { return Promise.resolve(true); - - // return new Promise((resolve, reject) => { - // this.once("ui-break-done", () => { - // this.log("console", "Running executable"); - // this.sendCommand("exec-continue").then((info) => { - // if (info.resultRecords.resultClass == "running") - // resolve(); - // else - // reject(); - // }, reject); - // }); - // }); } stop() { diff --git a/src/backend/pyocd.ts b/src/backend/pyocd.ts new file mode 100644 index 00000000..42526592 --- /dev/null +++ b/src/backend/pyocd.ts @@ -0,0 +1,106 @@ +import * as ChildProcess from 'child_process'; +import { EventEmitter } from "events"; +import * as portastic from 'portastic'; +import * as os from 'os'; + +let infoRegex = /^Info\s:\s([^\n])$/i; +let cpuRegex = /^([^\n\.]*)\.cpu([^\n]*)$/i; + +export class PyOCD extends EventEmitter { + private process: any; + private buffer: string; + private errbuffer: string; + + constructor(public application: string, public gdb_port: number, public boardId: string, public targetId: string) { + super(); + + this.buffer = ""; + this.errbuffer = ""; + } + + init(): Thenable { + return new Promise((resolve, reject) => { + let args = ['--persist', '--port', `${this.gdb_port}`, '--reset-break']; + + if (this.boardId) { + args.push('--board'); + args.push(this.boardId) + } + + if (this.targetId) { + args.push('--target'); + args.push(this.targetId); + } + + this.process = ChildProcess.spawn(this.application, args, {}); + this.process.stdout.on('data', this.stdout.bind(this)); + this.process.stderr.on('data', this.stderr.bind(this)); + this.process.on("exit", (() => { this.emit("quit"); }).bind(this)); + this.process.on("error", ((err) => { this.emit("launcherror", err); }).bind(this)); + + setTimeout(_ => { + console.log('Started PyOCD'); + resolve(); + }, 1000); + }); + } + + exit() : void { + this.process.kill(); + } + + error() : void { + + } + + close(code, signal) { + console.log('Closed PyOCD with ', code, signal); + } + + stdout(data) { + if(typeof data =="string") + this.buffer += data; + else + this.buffer += data.toString("utf8"); + + let end = this.buffer.lastIndexOf('\n'); + if(end != -1) { + this.onOutput(this.buffer.substr(0, end)); + this.buffer = this.buffer.substr(end + 1); + } + } + + stderr(data) { + if(typeof data =="string") + this.errbuffer += data; + else + this.errbuffer += data.toString("utf8"); + + let end = this.errbuffer.lastIndexOf('\n'); + if(end != -1) { + this.onOutput(this.errbuffer.substr(0, end)); + this.errbuffer = this.errbuffer.substr(end + 1); + } + } + + stop() { + this.process.kill(); + } + + onOutput(text: string) { + let m = text.match(infoRegex); + if(text.startsWith('INFO:')) { + let infostring = text.substr(5); + this.emit('pyocd-info', infostring); + if (infostring.indexOf('GDB server started at port') != -1) { + this.emit('pyocd-init'); + } + } + + this.emit('pyocd-output', text); + } + + onErrOutput(text: string) { + this.emit('pyocd-stderr', text); + } +} \ No newline at end of file diff --git a/src/common.ts b/src/common.ts index d219ede0..8814599d 100644 --- a/src/common.ts +++ b/src/common.ts @@ -35,4 +35,18 @@ export function makeObjectFromArrays(arrays: any[]) { obj[key] = value; }); return obj; +} + +export class TelemetryEvent extends Event implements DebugProtocol.Event { + body: { + event: string, + parameters: { [key: string]: string }, + measures: { [key: string]: number } + }; + event: string; + + constructor(event: string, parameters: { [key: string]: string }, measures: { [key: string]: number }) { + let body = { event: event, parameters: parameters, measures: measures }; + super('record-telemetry-event', body); + } } \ No newline at end of file diff --git a/src/frontend/extension.ts b/src/frontend/extension.ts index 87967630..c2817ddb 100644 --- a/src/frontend/extension.ts +++ b/src/frontend/extension.ts @@ -7,22 +7,19 @@ import * as os from "os"; import { PeripheralTreeProvider, TreeNode, FieldNode, RecordType, BaseNode } from './peripheral'; import { RegisterTreeProvider, TreeNode as RTreeNode, RecordType as RRecordType, BaseNode as RBaseNode } from './registers'; import { setTimeout } from "timers"; -import { SWOCore, JLinkSWOSource, OpenOCDSWOSource, SWOSource, OpenOCDFileSWOSource } from './swo'; +import { SWOCore } from './swo/core'; +import { SWOSource } from './swo/sources/common'; +import { JLinkSWOSource } from './swo/sources/jlink'; +import { OpenOCDSWOSource, OpenOCDFileSWOSource } from './swo/sources/openocd'; import { SWOConfigureEvent } from "../common"; - +import { MemoryContentProvider } from './memory_content_provider'; +import Reporting from '../reporting'; interface SVDInfo { expression: RegExp; path: string; } -var SVDDirectory: SVDInfo[] = []; - -function getSVDFile(device: string): string { - let entry = SVDDirectory.find(de => de.expression.test(device)); - return entry ? entry.path : null; -} - class CortexDebugExtension { private adapterOutputChannel: vscode.OutputChannel = null; private swo: SWOCore = null; @@ -52,13 +49,22 @@ class CortexDebugExtension { return { expression: exp, path: de.path }; }); + Reporting.activate(context); + + context.subscriptions.push(vscode.workspace.registerTextDocumentContentProvider('examinememory', new MemoryContentProvider())); + context.subscriptions.push(vscode.commands.registerCommand('cortexPeripherals.updateNode', this.peripheralsUpdateNode.bind(this))); context.subscriptions.push(vscode.commands.registerCommand('cortexPeripherals.selectedNode', this.peripheralsSelectedNode.bind(this))); + context.subscriptions.push(vscode.commands.registerCommand('marus25.cortex-debug-jlink.examineMemory', this.examineMemory.bind(this))); + context.subscriptions.push(vscode.commands.registerCommand('marus25.cortex-debug-openocd.examineMemory', this.examineMemory.bind(this))); + context.subscriptions.push(vscode.commands.registerCommand('marus25.cortex-debug-pyocd.examineMemory', this.examineMemory.bind(this))); context.subscriptions.push(vscode.window.registerTreeDataProvider('cortexPeripherals-jlink', this.peripheralProvider)); context.subscriptions.push(vscode.window.registerTreeDataProvider('cortexPeripherals-openocd', this.peripheralProvider)); + context.subscriptions.push(vscode.window.registerTreeDataProvider('cortexPeripherals-pyocd', this.peripheralProvider)); context.subscriptions.push(vscode.window.registerTreeDataProvider('cortexRegisters-jlink', this.registerProvider)); context.subscriptions.push(vscode.window.registerTreeDataProvider('cortexRegisters-openocd', this.registerProvider)); + context.subscriptions.push(vscode.window.registerTreeDataProvider('cortexRegisters-pyocd', this.registerProvider)); context.subscriptions.push(vscode.debug.onDidReceiveDebugSessionCustomEvent(this.receivedCustomEvent.bind(this))); context.subscriptions.push(vscode.debug.onDidStartDebugSession(this.debugSessionStarted.bind(this))); @@ -66,7 +72,65 @@ class CortexDebugExtension { } getSVDFile(device: string): string { - return ''; + let entry = this.SVDDirectory.find(de => de.expression.test(device)); + return entry ? entry.path : null; + } + + examineMemory() { + function validateValue(address) { + if(/^0x[0-9a-f]{1,8}$/i.test(address)) { + return address; + } + else if(/^[0-9]+$/i.test(address)) { + return address; + } + else { + return null; + } + } + + if(!vscode.debug.activeDebugSession) { + vscode.window.showErrorMessage('No debugging session available'); + return; + } + + vscode.window.showInputBox({ + placeHolder: 'Prefix with 0x for hexidecimal format', + ignoreFocusOut: true, + prompt: 'Memory Address' + }).then( + address => { + if (!validateValue(address)) { + vscode.window.showErrorMessage('Invalid memory address entered'); + Reporting.sendEvent('examine-memory-invalid-address', { address: address }, {}); + return; + } + + vscode.window.showInputBox({ + placeHolder: 'Prefix with 0x for hexidecimal format', + ignoreFocusOut: true, + prompt: 'Length' + }).then( + (length) => { + if (!validateValue(length)) { + vscode.window.showErrorMessage('Invalid length entered'); + Reporting.sendEvent('examine-memory-invalid-length', { length: length }, {}); + return; + } + + Reporting.sendEvent('examine-memory', {}, {}); + let timestamp = new Date().getTime(); + vscode.window.showTextDocument(vscode.Uri.parse(`examinememory:///Memory%20[${address}+${length}]?address=${address}&length=${length}×tamp=${timestamp}`), { viewColumn: 2 }); + }, + (error) => { + + } + ); + }, + (error) => { + + } + ); } // Peripherals @@ -97,11 +161,6 @@ class CortexDebugExtension { // Debug Events debugSessionStarted(session: vscode.DebugSession) { // Clean-up Old output channels - if (this.adapterOutputChannel) { - this.adapterOutputChannel.dispose(); - this.adapterOutputChannel = null; - } - if (this.swo) { this.swo.dispose(); this.swo = null; @@ -116,6 +175,18 @@ class CortexDebugExtension { } } + let info = { + type: args.type, + swo: args.SWOConfig.enabled ? 'enabled' : 'disabled', + graphing: (args.GraphConfig && args.GraphConfig.length > 0) ? 'enabled' : 'disabled' + }; + + if (args.type == 'jlink-gdb') { + info['device'] = args.device; + } + + Reporting.sendEvent('debug-session-started', info, {}); + this.registerProvider.debugSessionStarted(); this.peripheralProvider.debugSessionStarted(svdfile ? svdfile : null); @@ -126,6 +197,8 @@ class CortexDebugExtension { } debugSessionTerminated(session: vscode.DebugSession) { + Reporting.sendEvent('debug-session-terminated', {}, {}); + this.registerProvider.debugSessionTerminated(); this.peripheralProvider.debugSessionTerminated(); if (this.swo) { @@ -151,6 +224,9 @@ class CortexDebugExtension { case 'adapter-output': this.receivedAdapterOutput(e); break; + case 'record-telemetry-event': + this.receivedTelemetryEvent(e); + break; default: break; @@ -169,6 +245,10 @@ class CortexDebugExtension { if (this.swo) { this.swo.debugContinued(); } } + receivedTelemetryEvent(e) { + Reporting.sendEvent(e.body.event, e.body.properties || {}, e.body.measures || {}); + } + receivedSWOConfigureEvent(e) { if (e.body.type == 'jlink') { this.swosource = new JLinkSWOSource(e.body.port); diff --git a/src/frontend/memory_content_provider.ts b/src/frontend/memory_content_provider.ts new file mode 100644 index 00000000..99c7f3b0 --- /dev/null +++ b/src/frontend/memory_content_provider.ts @@ -0,0 +1,74 @@ +import * as vscode from "vscode"; +import { hexFormat } from './utils'; + +export class MemoryContentProvider implements vscode.TextDocumentContentProvider { + provideTextDocumentContent(uri: vscode.Uri, token: vscode.CancellationToken): Thenable { + return new Promise((resolve, reject) => { + let highlightAt = -1; + let query = this.parseQuery(uri.query); + + let address: number = query['address'].startsWith('0x') ? parseInt(query['address'].substring(2), 16) : parseInt(query['address'], 10); + let length: number = query['length'].startsWith('0x') ? parseInt(query['length'].substring(2), 16) : parseInt(query['length'], 10); + + vscode.debug.activeDebugSession.customRequest('read-memory', { address: address, length: length || 32 }).then((data) => { + let bytes = data.bytes; + + let lineAddress = address & 0xFFFFFFF0; + let lineLength = 16; + let offset = address - lineAddress; + + let output = ''; + output += 'Address \t|\tData \t|\tCharacter\n'; + output += '-------------------------------------------------------------------------------------------------------\n'; + + output += hexFormat(lineAddress, 8) + '\t|\t'; + + let lineend = ''; + + for (let i = 0; i < offset; i++) { output += ' '; lineend += ' '; } + + for (let i = 0; i < length; i++) { + let byte = bytes[i]; + output += hexFormat(byte, 2, false) + ' '; + if (byte <= 32 || (byte >= 127 && byte <= 159)) { + lineend += '. '; + } + else { + lineend += String.fromCharCode(bytes[i]) + ' '; + } + + if ((address + i) % 16 === 15 && i < length - 1) { + output += '\t|\t' + lineend; + lineend = ''; + output += '\n'; + lineAddress += 16; + output += hexFormat(lineAddress, 8) + '\t|\t'; + } + } + + let endaddress = address + length; + let extra = (16 - (endaddress % 16)) % 16; + + for (let i = 0; i < extra; i++) { output += ' '; } + output += '\t|\t' + lineend; + + output += '\n'; + + resolve(output); + }, (error) => { + vscode.window.showErrorMessage(`Unable to read memory from ${hexFormat(address, 8)} to ${hexFormat(address + length, 8)}`); + reject(error.toString()); + }); + }); + } + + private parseQuery(queryString) { + var query = {}; + var pairs = (queryString[0] === '?' ? queryString.substr(1) : queryString).split('&'); + for (var i = 0; i < pairs.length; i++) { + var pair = pairs[i].split('='); + query[decodeURIComponent(pair[0])] = decodeURIComponent(pair[1] || ''); + } + return query; + } +} \ No newline at end of file diff --git a/src/frontend/peripheral.ts b/src/frontend/peripheral.ts index 9a79186c..44d9c8be 100644 --- a/src/frontend/peripheral.ts +++ b/src/frontend/peripheral.ts @@ -47,6 +47,69 @@ export class BaseNode { } +function parseInteger(value: string): number { + if((/^0b([01]+)$/i).test(value)) { + return parseInt(value.substring(2), 2); + } + else if((/^0x([0-9a-f]+)$/i).test(value)) { + return parseInt(value.substring(2), 16); + } + else if ((/^[0-9]+/i).test(value)) { + return parseInt(value, 10); + } + else if ((/^#[0-1]+/i).test(value)) { + return parseInt(value.substring(1), 2); + } + return undefined; +} + +function parseDimIndex(spec: string, count: number) : string[] { + if (spec.indexOf(',') !== -1) { + let components = spec.split(',').map(c => c.trim()); + if (components.length !== count) { + throw new Error(`dimIndex Element has invalid specification.`); + } + return components; + } + + if (/^([0-9]+)\-([0-9]+)$/i.test(spec)) { + let parts = spec.split('-').map(p => parseInteger(p)); + let start = parts[0]; + let end = parts[1]; + + let diff = end - start; + if (diff < count) { + throw new Error(`dimIndex Element has invalid specification.`); + } + + let components = []; + for (let i = 0; i < count; i++) { + components.push(`${start + i}`); + } + + return components; + } + + if (/^[a-zA-Z]\-[a-zA-Z]$/.test(spec)) { + let start = spec.charCodeAt(0); + let end = spec.charCodeAt(2); + + let diff = end - start; + if (diff < count) { + throw new Error(`dimIndex Element has invalid specification.`); + } + + let components = []; + for (let i = 0; i < count; i++) { + components.push(String.fromCharCode(start + i)); + } + + return components; + } + + return []; +} + interface EnumerationMap { [value:number] : EnumeratedValue; @@ -155,12 +218,13 @@ export class RegisterNode extends BaseNode { else if(this.access == AccessType.WriteOnly) { cv = 'registerWO'; } let label = this.name + ' [' + hexFormat(this.offset, 2) + '] = ' + hexFormat(this.currentValue, this.length); - - return new TreeNode(label, this.expanded ? vscode.TreeItemCollapsibleState.Expanded : vscode.TreeItemCollapsibleState.Collapsed, cv, this); + let collapseState = this.fields && this.fields.length > 0 ? (this.expanded ? vscode.TreeItemCollapsibleState.Expanded : vscode.TreeItemCollapsibleState.Collapsed) : vscode.TreeItemCollapsibleState.None + + return new TreeNode(label, collapseState, cv, this); } getChildren(): FieldNode[] { - return this.fields; + return this.fields || []; } performUpdate() : Thenable { @@ -286,17 +350,8 @@ export class FieldNode extends BaseNode { } else { vscode.window.showInputBox({ prompt: "Enter new value: (prefix hex with 0x, binary with 0b)" }).then(val => { - let numval; - if((/^0b([01]+)$/i).test(val)) { - numval = parseInt(val.substring(2), 2); - } - else if((/^0x([0-9a-f]+)$/i).test(val)) { - numval = parseInt(val.substring(2), 16); - } - else if ((/^[0-9]+/i).test(val)) { - numval = parseInt(val, 10); - } - else { + let numval = parseInteger(val); + if (numval === undefined) { return reject('Unable to parse input value.'); } this.register.updateBits(this.offset, this.width, numval).then(resolve, reject); @@ -348,8 +403,9 @@ export class PeripheralTreeProvider implements vscode.TreeDataProvider ev.enumeratedValue.map(ev => { let evname = ev.name[0]; let evdesc = ev.description[0]; - let evvalue = parseInt(ev.value[0]); - + let val = ev.value[0].toLowerCase(); + let evvalue = parseInteger(val); + value_map[evvalue] = new EnumeratedValue(evname, evdesc, evvalue); }); } @@ -358,8 +414,10 @@ export class PeripheralTreeProvider implements vscode.TreeDataProvider }); } - _parseRegisters(registers: any[], peripheral: PeripheralNode): RegisterNode[] { - return registers.map(r => { + _parseRegisters(regInfo: any[], peripheral: PeripheralNode): RegisterNode[] { + let registers: RegisterNode[] = []; + + regInfo.forEach(r => { let accessType = AccessType.ReadWrite; if(r.access && r.access.length == 1) { let access = r.access[0]; @@ -372,11 +430,45 @@ export class PeripheralTreeProvider implements vscode.TreeDataProvider size = parseInt(r.size[0]); } - let register = new RegisterNode(r.name[0], parseInt(r.addressOffset[0], 16), size, accessType, parseInt(r.resetValue[0]), peripheral); - let fields = this._parseFields(r.fields[0].field, register); - register.fields = fields; - return register; + if (r.dim) { + if (!r.dimIncrement) { throw new Error(`Unable to parse SVD file: register ${r.name[0]} has dim element, with no dimIncrement element`); } + + let count = parseInteger(r.dim[0]); + let increment = parseInteger(r.dimIncrement[0]); + let index = parseDimIndex(r.dimIndex[0], count); + + let namebase: string = r.name[0]; + let offsetbase = parseInteger(r.addressOffset[0]); + let resetvalue = parseInteger(r.resetValue[0]); + + for (let i = 0; i < count; i++) { + let name = namebase.replace('%s', index[i]); + + let register = new RegisterNode(name, offsetbase + (increment * i), size, accessType, resetvalue, peripheral); + if (r.fields && r.fields.length == 1) { + let fields = this._parseFields(r.fields[0].field, register); + register.fields = fields; + } + registers.push(register); + } + } + else { + let register = new RegisterNode(r.name[0], parseInteger(r.addressOffset[0]), size, accessType, parseInteger(r.resetValue[0]), peripheral); + if (r.fields && r.fields.length == 1) { + let fields = this._parseFields(r.fields[0].field, register); + register.fields = fields; + } + registers.push(register); + } + }); + + registers.sort((a, b) => { + if (a.offset < b.offset) { return -1; } + else if(a.offset > b.offset) { return 1; } + else { return 0; } }); + + return registers; } _parsePeripheral(p: any): PeripheralNode { @@ -455,7 +547,15 @@ export class PeripheralTreeProvider implements vscode.TreeDataProvider this._loaded = false; if(svdfile) { - this._loadSVD(svdfile).then(_ => { resolve(); }); + try { + this._loadSVD(svdfile).then(resolve, reject); + } + catch (e) { + this._peripherials = []; + this._loaded = false; + vscode.window.showErrorMessage(`Unable to parse SVD file: ${e.toString()}`); + reject(); + } } else { resolve(); diff --git a/src/frontend/swo.ts b/src/frontend/swo.ts deleted file mode 100644 index 79b4c5e2..00000000 --- a/src/frontend/swo.ts +++ /dev/null @@ -1,510 +0,0 @@ -import * as net from 'net'; -import * as fs from 'fs'; -import * as path from 'path'; -import * as vscode from "vscode"; -import { hexFormat } from './utils'; -import { clearTimeout, setTimeout, setInterval, clearInterval } from 'timers'; -import * as portastic from 'portastic'; -import { Parser } from 'binary-parser'; -import { EventEmitter } from 'events'; -import * as os from 'os'; - -var WebSocket = require('ws'); -var CircularBuffer = require('cbarrick-circular-buffer'); - -let SignedParser = new Parser().endianess('little').int32('value'); -let UnsignedParser = new Parser().endianess('little').uint32('value'); -let FloatParser = new Parser().endianess('little').floatle('value'); - -function parseFloat(buffer: Buffer) { - if(buffer.length < 4) { - let tmp = new Buffer(4); - buffer.copy(tmp); - buffer = tmp; - } - - let result = FloatParser.parse(buffer); - return result.value; -} - -function parseSigned(buffer: Buffer) { - if(buffer.length < 4) { - let tmp = new Buffer(4); - buffer.copy(tmp); - buffer = tmp; - } - - let result = SignedParser.parse(buffer); - return result.value; -} - -function parseUnsigned(buffer: Buffer) { - if(buffer.length < 4) { - let tmp = new Buffer(4); - buffer.copy(tmp); - buffer = tmp; - } - - let result = UnsignedParser.parse(buffer); - return result.value; -} - -function parseQ(buffer: Buffer, mask: number, shift: number) { - let value = parseSigned(buffer); - - var fractional = value & mask; - var integer = value >> shift; - - return integer + (fractional / mask); -} - -function parseUQ(buffer: Buffer, mask: number, shift: number) { - let value = parseUnsigned(buffer); - - var fractional = value & mask; - var integer = value >>> shift; - - return integer + (fractional / mask); -} - -let DECODER_MAP = { - 'signed': parseSigned, - 'float': parseFloat, - 'Q8.24': (buffer) => parseQ(buffer, 0xFFFFFF, 24), - 'Q16.16': (buffer) => parseQ(buffer, 0xFFFF, 16), - 'Q24.8': (buffer) => parseQ(buffer, 0xFF, 8), - 'UQ8.24': (buffer) => parseUQ(buffer, 0xFFFFFF, 24), - 'UQ16.16': (buffer) => parseUQ(buffer, 0xFFFF, 16), - 'UQ24.8': (buffer) => parseUQ(buffer, 0xFF, 8), - 'unsigned': parseUnsigned -}; - -function parseEncoded(buffer: Buffer, encoding: string) { - return DECODER_MAP[encoding] ? DECODER_MAP[encoding](buffer) : parseUnsigned(buffer); -} - -interface SWOProcessor { - port: number; - format: string; - - processMessage(buffer: Buffer); - dispose(); -} - -interface SWOWebsocketProcessor extends SWOProcessor { - getMessages(); -} - -interface WebsocketMessage { - type: string; -} - -interface WebsocketDataMessage extends WebsocketMessage { - timestamp: number; - data: number; - port: number; - raw: string; -} - -interface WebsocketStatusMessage extends WebsocketMessage { - status: string; -} - -interface SWOPortConfig { - number: number; - format: string; - encoding: string; - scale: number; - label: string; -}; - -interface GraphConfiguration { - type: string; - label: string; -}; - -interface RealtimeGraphConfiguration extends GraphConfiguration { - minimum: number; - maximum: number; - ports: { - number: number, - label: string, - color: string - }[]; -}; - -interface XYGraphConfiguration extends GraphConfiguration { - xPort: number; - yPort: number; - xMinimum: number; - xMaximum: number; - yMinimum: number; - yMaximum: number; -} - -class SWOBinaryProcessor implements SWOProcessor { - output: vscode.OutputChannel; - format: string = 'binary'; - port: number; - scale: number; - encoding: string; - - constructor(config: SWOPortConfig, private core: SWOCore) { - this.port = config.number; - this.scale = config.scale || 1; - this.encoding = config.encoding || 'unsigned'; - - this.output = vscode.window.createOutputChannel(`SWO: ${config.label || ''} [port: ${this.port}, encoding: ${this.encoding}]`); - } - - processMessage(buffer: Buffer) { - let date = new Date(); - - let hexvalue = buffer.toString('hex'); - let decodedValue = parseEncoded(buffer, this.encoding); - let scaledValue = decodedValue * this.scale; - - this.output.appendLine(`[${date.toISOString()}] ${hexvalue} - ${decodedValue} - ${scaledValue}`); - } - - dispose() { - this.output.dispose(); - } -} - -class SWOConsoleProcessor implements SWOProcessor { - positionCount: number; - output: vscode.OutputChannel; - position: number = 0; - timeout: any = null; - format: string = 'console'; - port: number; - - constructor(config: SWOPortConfig, private core: SWOCore) { - this.port = config.number; - this.output = vscode.window.createOutputChannel(`SWO: ${config.label || ''} [port: ${this.port}, format: console]`); - } - - processMessage(buffer: Buffer) { - if(this.timeout) { clearTimeout(this.timeout); this.timeout = null; } - - var data = parseUnsigned(buffer); - - let letter = String.fromCharCode(data); - if(letter == '\n') { - this.output.append('\n'); - this.position = 0; - return; - } - - if(this.position == 0) { - let date = new Date(); - let header = `[${date.toISOString()}] `; - this.output.append(header); - } - - this.output.append(letter); - this.position += 1; - - if(this.position >= 80) { - this.output.append('\n'); - this.position = 0; - } - else { - this.timeout = setTimeout(() => { - this.output.append('\n'); - this.position = 0; - this.timeout = null; - }, 5000); - } - } - - dispose() { - this.output.dispose(); - } -} - -class SWOGraphProcessor implements SWOWebsocketProcessor { - // buffer: CircularBuffer; - format: string = 'graph'; - port: number; - scale: number; - encoding: string; - - constructor(config: SWOPortConfig, private core: SWOCore) { - core.socketServer.registerProcessor(this); - this.port = config.number; - this.encoding = config.encoding || 'unsigned'; - this.scale = config.scale || 1; - } - - processMessage(buffer: Buffer) { - let raw = buffer.toString('hex'); - let decodedValue = parseEncoded(buffer, this.encoding); - let scaledValue = decodedValue * this.scale; - - let message = { type: 'data', timestamp: new Date().getTime(), data: scaledValue, port: this.port, raw: raw }; - this.core.socketServer.broadcastMessage(message); - } - - dispose() { - - } - - getMessages(): WebsocketMessage[] { - return []; - } -} - -const PROCESSOR_MAP = { - "console": SWOConsoleProcessor, - "binary": SWOBinaryProcessor, - "graph": SWOGraphProcessor -}; - -class SWOSocketServer { - processors: SWOWebsocketProcessor[]; - socket: any; - currentStatus: string = 'stopped'; - - constructor(serverPort: number, public graphs: GraphConfiguration[]) { - this.processors = []; - this.socket = new WebSocket.Server({ port: serverPort }); - this.socket.on('connection', this.connected.bind(this)); - } - - connected(client) { - client.on('message', (message) => this.message(client, message)); - let activePorts = this.processors.map(p => { return { 'port': p.port }; }); - client.send(JSON.stringify({ type: 'configure', 'activePorts': activePorts, 'graphs': this.graphs, 'status': this.currentStatus })); - } - - message(client, message) { - } - - registerProcessor(processor: SWOWebsocketProcessor) { - this.processors.push(processor); - } - - broadcastMessage(message: WebsocketMessage) { - let encoded = JSON.stringify(message); - this.socket.clients.forEach(client => { - if(client.readyState == WebSocket.OPEN) { - client.send(encoded); - } - }); - } - - dispose() { - this.socket.close(); - } -} - -export interface SWOSource extends EventEmitter { - connected: boolean; - dispose(); -} - -export class JLinkSWOSource extends EventEmitter implements SWOSource { - client: net.Socket = null; - connected: boolean = false; - - constructor(private SWOPort: number) { - super(); - this.client = net.createConnection({ port: this.SWOPort, host: 'localhost' }, () => { this.connected = true; this.emit('connected'); }); - this.client.on('data', (buffer) => { this.emit('data', buffer); }); - this.client.on('end', () => { this.emit('disconnected'); }); - } - - dispose() { - this.client.destroy(); - } -} - -export class OpenOCDSWOSource extends EventEmitter implements SWOSource { - stream: fs.ReadStream; - connected: boolean = false; - - constructor(private SWOPath: string) { - super(); - this.stream = fs.createReadStream(this.SWOPath, { highWaterMark: 128, encoding: null, autoClose: false }) - this.stream.on('data', (buffer) => { this.emit('data', buffer); }); - this.stream.on('close', (buffer) => { this.emit('disconnected'); }); - this.connected = true; - } - - dispose() { - this.stream.close(); - } -} - -export class OpenOCDFileSWOSource extends EventEmitter implements SWOSource { - connected: boolean = false; - fd: number = null; - interval: any = null; - - constructor(private SWOPath: string) { - super(); - fs.open(SWOPath, 'r', (err, fd) => { - if(err) { - console.log('Error Opening File') - } - else { - this.fd = fd; - this.interval = setInterval(this.read.bind(this), 2); - this.connected = true; - this.emit('connected'); - } - }) - } - - read() { - let buf: Buffer = new Buffer(64); - fs.read(this.fd, buf, 0, 64, null, (err, bytesRead, buffer) => { - if(bytesRead > 0) { - this.emit('data', buffer.slice(0, bytesRead)); - } - }); - } - - dispose() { - this.emit('disconnected'); - clearInterval(this.interval); - fs.closeSync(this.fd); - } -} - -export class SWOCore { - processors: SWOProcessor[] = [];; - socketServer: SWOSocketServer; - connected: boolean = false; - - buffer = null; - - LENGTH_MASK = 0x03; - SPECIAL_MASK = 0x0F; - PORT_MASK = 0xF8; - - constructor(private source: SWOSource, configuration: SWOPortConfig[], graphs: GraphConfiguration[], extensionPath: string) { - this.buffer = new CircularBuffer({ size: 250, encoding: null }); - - if(this.source.connected) { this.connected = true; } - else { this.source.on('connected', () => { this.connected = true; }); } - this.source.on('data', this.handleData.bind(this)); - this.source.on('disconnected', () => { this.connected = false; }); - - portastic.find({ min: 53333, max: 54333, retrieve: 1 }).then(ports => { - let port = ports[0]; - this.socketServer = new SWOSocketServer(port, graphs); - var hasGraph = configuration.filter(c => c.format == 'graph').length > 0 && graphs.length > 1; - - if(hasGraph) { - let now = new Date(); - let timestamp = now.getTime(); - let time = now.toTimeString(); - var grapherURL = `file://${extensionPath}/grapher/index.html?port=${port}×tamp=${timestamp}`; - if(os.platform() == 'win32') { - let ep = extensionPath.replace(/\\/g, '/'); - grapherURL = `file:///${ep}/grapher/index.html?port=${port}×tamp=${timestamp}`; - } - - vscode.commands.executeCommand('vscode.previewHtml', grapherURL, vscode.ViewColumn.Two, `SWO Graphs [${time}]`).then(e => { - console.log('Preview HTML: ', e); - }, - error => { - console.log('Preview HTML Error: ', error); - }); - } - }).then(result => { - configuration.forEach(conf => { - let pc = PROCESSOR_MAP[conf.format]; - if(pc) { - let processor = new pc(conf, this); - this.processors.push(processor); - } - }); - }); - } - - handleData(data) { - this.buffer.write(data); - this._processBuffer(); - } - - _processBuffer() { - while(this.buffer.length > 0) { - let headerbuf = this.buffer.peek(1, null); - let header = headerbuf[0]; - if((header & this.SPECIAL_MASK) === 0) { - // this._processTimestamp(); - console.log("Invalid Content - dropping buffer"); - this.buffer.read(this.buffer.length, null); - continue; - } - if((header & 0x4) !== 0) { - console.log("Invalid Content - dropping buffer"); - this.buffer.read(this.buffer.length, null); - continue; - } - - let lh = header & this.LENGTH_MASK; - let length = (lh == 0x3 ? 4 : lh); - let port = (header & this.PORT_MASK) >>> 3; - - if(this.buffer.length < length + 1) { break; } // Not enough bytes to process yet - - this.buffer.read(1, null); - - let buf = this.buffer.read(length, null); - this._processSWIT(port, buf); - } - } - - _processSWIT(port: number, data: Buffer) { - this.processors.forEach(p => { if(p.port == port) { p.processMessage(data); } }); - } - - _processTimestamp() { - - } - - calculatePortMask(configuration: SWOPortConfig[]) { - let mask: number = 0; - configuration.forEach(c => { - mask = (mask | (1 << c.number)) >>> 0; - }); - return mask; - } - - debugSessionTerminated() { - let message : WebsocketStatusMessage = { type: 'status', status: 'terminated' }; - this.socketServer.broadcastMessage(message); - this.socketServer.currentStatus = 'terminated'; - setTimeout(() => { - this.socketServer.dispose(); - this.socketServer = null; - }, 250); - } - - debugStopped() { - let message : WebsocketStatusMessage = { type: 'status', status: 'stopped' }; - this.socketServer.broadcastMessage(message); - this.socketServer.currentStatus = 'stopped'; - } - - debugContinued() { - let message : WebsocketStatusMessage = { type: 'status', status: 'continued' }; - this.socketServer.broadcastMessage(message); - this.socketServer.currentStatus = 'continued'; - } - - dispose() { - if(this.socketServer) { - this.socketServer.dispose(); - this.socketServer = null; - } - this.processors.forEach(p => p.dispose()); - this.processors = null; - this.connected = false; - } -} \ No newline at end of file diff --git a/src/frontend/swo/common.ts b/src/frontend/swo/common.ts new file mode 100644 index 00000000..fdf7d317 --- /dev/null +++ b/src/frontend/swo/common.ts @@ -0,0 +1,70 @@ +export interface SWOPortConfig { + type: string; + number: number; +} + +export interface SWOConsolePortConfig extends SWOPortConfig { + label: string; +} + +export interface SWOBinaryPortConfig extends SWOPortConfig { + encoding: string; + scale: number; + label: string; +} + +export interface SWOGraphPortConfig extends SWOPortConfig { + encoding: string; + scale: number; + graphId: string; +} + +export interface SWOAdvancedPortConfig extends SWOPortConfig { + decoder: string; + config: any; +} + +export interface GraphConfiguration { + type: string; + label: string; +} + +export interface RealtimeGraphConfiguration extends GraphConfiguration { + minimum: number; + maximum: number; + ports: { + number: number, + label: string, + color: string + }[]; +} + +export interface XYGraphConfiguration extends GraphConfiguration { + xPort: number; + yPort: number; + xMinimum: number; + xMaximum: number; + yMinimum: number; + yMaximum: number; +} + +export interface WebsocketMessage { + type: string; +} + +export interface WebsocketDataMessage extends WebsocketMessage { + timestamp: number; + data: number; + id: string; +} + +export interface WebsocketStatusMessage extends WebsocketMessage { + status: string; +} + +export interface AdvancedDecoder { + name: string; + + processData(buffer: Buffer): void; + outputLabel(): string; +} \ No newline at end of file diff --git a/src/frontend/swo/core.ts b/src/frontend/swo/core.ts new file mode 100644 index 00000000..7cec58cb --- /dev/null +++ b/src/frontend/swo/core.ts @@ -0,0 +1,167 @@ +import * as vscode from "vscode"; + +import * as portastic from 'portastic'; +import * as os from 'os'; + +import { SWOConsoleProcessor } from './decoders/console'; +import { SWOBinaryProcessor } from './decoders/binary'; +import { SWOGraphProcessor } from './decoders/graph'; +import { SWOProcessor } from './decoders/common'; +import { SWOSource } from './sources/common'; +import { SWOSocketServer } from './websocket_server'; +import { SWOPortConfig, GraphConfiguration, WebsocketStatusMessage, SWOAdvancedPortConfig, SWOGraphPortConfig, SWOBinaryPortConfig, SWOConsolePortConfig } from './common'; +import { SWOAdvancedProcessor } from "./decoders/advanced"; + +var CircularBuffer = require('cbarrick-circular-buffer'); + +export class SWOCore { + processors: SWOProcessor[] = [];; + socketServer: SWOSocketServer; + connected: boolean = false; + + buffer = null; + + LENGTH_MASK = 0x03; + SPECIAL_MASK = 0x0F; + PORT_MASK = 0xF8; + + constructor(private source: SWOSource, configuration: SWOPortConfig[], graphs: GraphConfiguration[], extensionPath: string) { + this.buffer = new CircularBuffer({ size: 250, encoding: null }); + + if(this.source.connected) { this.connected = true; } + else { this.source.on('connected', () => { this.connected = true; }); } + this.source.on('data', this.handleData.bind(this)); + this.source.on('disconnected', () => { this.connected = false; }); + + portastic.find({ min: 53333, max: 54333, retrieve: 1 }).then(ports => { + let port = ports[0]; + this.socketServer = new SWOSocketServer(port, graphs); + + if(graphs.length > 1) { + let now = new Date(); + let timestamp = now.getTime(); + let time = now.toTimeString(); + var grapherURL = `file://${extensionPath}/grapher/index.html?port=${port}×tamp=${timestamp}`; + if(os.platform() == 'win32') { + let ep = extensionPath.replace(/\\/g, '/'); + grapherURL = `file:///${ep}/grapher/index.html?port=${port}×tamp=${timestamp}`; + } + + vscode.commands.executeCommand('vscode.previewHtml', grapherURL, vscode.ViewColumn.Two, `SWO Graphs [${time}]`).then(e => { + console.log('Preview HTML: ', e); + }, + error => { + console.log('Preview HTML Error: ', error); + }); + } + }).then(result => { + configuration.forEach(conf => { + let processor; + + switch (conf.type) { + case 'console': + this.processors.push(new SWOConsoleProcessor(conf as SWOConsolePortConfig)); + break; + case 'binary': + this.processors.push(new SWOBinaryProcessor(conf as SWOBinaryPortConfig)); + break; + case 'graph': + processor = new SWOGraphProcessor(conf as SWOGraphPortConfig); + this.socketServer.registerProcessor(processor); + this.processors.push(processor); + break; + case 'advanced': + processor = new SWOAdvancedProcessor(conf as SWOAdvancedPortConfig); + this.socketServer.registerProcessor(processor); + this.processors.push(processor); + break; + default: + console.log(`Unrecognized SWO Processor: ${conf.type}`); + break; + } + }); + }); + } + + handleData(data) { + this.buffer.write(data); + this._processBuffer(); + } + + _processBuffer() { + while(this.buffer.length > 0) { + let headerbuf = this.buffer.peek(1, null); + let header = headerbuf[0]; + if((header & this.SPECIAL_MASK) === 0) { + // this._processTimestamp(); + console.log("Invalid Content - dropping buffer"); + this.buffer.read(this.buffer.length, null); + continue; + } + if((header & 0x4) !== 0) { + console.log("Invalid Content - dropping buffer"); + this.buffer.read(this.buffer.length, null); + continue; + } + + let lh = header & this.LENGTH_MASK; + let length = (lh == 0x3 ? 4 : lh); + let port = (header & this.PORT_MASK) >>> 3; + + if(this.buffer.length < length + 1) { break; } // Not enough bytes to process yet + + this.buffer.read(1, null); + + let buf = this.buffer.read(length, null); + this._processSWIT(port, buf); + } + } + + _processSWIT(port: number, data: Buffer) { + this.processors.forEach(p => { if(p.port == port) { p.processMessage(data); } }); + } + + _processTimestamp() { + + } + + calculatePortMask(configuration: SWOPortConfig[]) { + let mask: number = 0; + configuration.forEach(c => { + mask = (mask | (1 << c.number)) >>> 0; + }); + return mask; + } + + debugSessionTerminated() { + let message : WebsocketStatusMessage = { type: 'status', status: 'terminated' }; + this.socketServer.broadcastMessage(message); + this.socketServer.currentStatus = 'terminated'; + setTimeout(() => { + this.socketServer.dispose(); + this.socketServer = null; + }, 250); + } + + debugStopped() { + let message : WebsocketStatusMessage = { type: 'status', status: 'stopped' }; + this.socketServer.broadcastMessage(message); + this.socketServer.currentStatus = 'stopped'; + } + + debugContinued() { + let message : WebsocketStatusMessage = { type: 'status', status: 'continued' }; + this.socketServer.broadcastMessage(message); + this.socketServer.currentStatus = 'continued'; + } + + dispose() { + if(this.socketServer) { + this.socketServer.dispose(); + this.socketServer = null; + } + this.processors.forEach(p => p.dispose()); + this.processors = null; + this.connected = false; + } +} \ No newline at end of file diff --git a/src/frontend/swo/decoders/advanced.ts b/src/frontend/swo/decoders/advanced.ts new file mode 100644 index 00000000..57e2b64a --- /dev/null +++ b/src/frontend/swo/decoders/advanced.ts @@ -0,0 +1,59 @@ +import * as vscode from "vscode"; +import { SWOProcessor } from './common'; +import { SWOAdvancedPortConfig, WebsocketDataMessage, AdvancedDecoder } from '../common'; +import { decoders as DECODER_MAP } from './utils'; +import { EventEmitter } from 'events'; +import { decoders } from './utils'; + + +export class SWOAdvancedProcessor extends EventEmitter implements SWOProcessor { + output: vscode.OutputChannel; + format: string = 'advanced'; + port: number; + decoder: AdvancedDecoder; + + constructor(config: SWOAdvancedPortConfig) { + super(); + this.port = -1; + + let decoderPath = config.decoder; + + var decoderModule = require(decoderPath); + + if(decoderModule && decoderModule.default) { + let decoderClass = decoderModule.default; + + try { + this.decoder = new decoderClass(config.config, decoders, this.displayOutput.bind(this), this.graphData.bind(this)); + } + catch(e) { + vscode.window.showErrorMessage(`Error instantiating decoder class: ${e.toString()}`); + return; + } + + this.port = config.number; + this.output = vscode.window.createOutputChannel(`SWO: ${this.decoder.outputLabel() || ''} [port: ${this.port}, type: ${this.decoder.name}]`); + } + else { + vscode.window.showErrorMessage(`Unable to load decoder class from: ${config.decoder}`); + } + + } + + processMessage(buffer: Buffer) { + this.decoder.processData(buffer); + } + + displayOutput(output: string) { + this.output.append(output); + } + + graphData(data: number, id: string) { + let message: WebsocketDataMessage = { type: 'data', timestamp: new Date().getTime(), data: data, id: id }; + this.emit('data', message); + } + + dispose() { + this.output.dispose(); + } +}; \ No newline at end of file diff --git a/src/frontend/swo/decoders/binary.ts b/src/frontend/swo/decoders/binary.ts new file mode 100644 index 00000000..dd0cb6a6 --- /dev/null +++ b/src/frontend/swo/decoders/binary.ts @@ -0,0 +1,38 @@ +import * as vscode from "vscode"; +import { SWOProcessor } from './common'; +import { SWOBinaryPortConfig } from '../common'; +import { decoders as DECODER_MAP } from './utils'; + +function parseEncoded(buffer: Buffer, encoding: string) { + return DECODER_MAP[encoding] ? DECODER_MAP[encoding](buffer) : DECODER_MAP.unsigned(buffer); +} + +export class SWOBinaryProcessor implements SWOProcessor { + output: vscode.OutputChannel; + format: string = 'binary'; + port: number; + scale: number; + encoding: string; + + constructor(config: SWOBinaryPortConfig) { + this.port = config.number; + this.scale = config.scale || 1; + this.encoding = (config.encoding || 'unsigned').replace('.', '_'); + + this.output = vscode.window.createOutputChannel(`SWO: ${config.label || ''} [port: ${this.port}, encoding: ${this.encoding}]`); + } + + processMessage(buffer: Buffer) { + let date = new Date(); + + let hexvalue = buffer.toString('hex'); + let decodedValue = parseEncoded(buffer, this.encoding); + let scaledValue = decodedValue * this.scale; + + this.output.appendLine(`[${date.toISOString()}] ${hexvalue} - ${decodedValue} - ${scaledValue}`); + } + + dispose() { + this.output.dispose(); + } +} \ No newline at end of file diff --git a/src/frontend/swo/decoders/common.ts b/src/frontend/swo/decoders/common.ts new file mode 100644 index 00000000..7a97ca4d --- /dev/null +++ b/src/frontend/swo/decoders/common.ts @@ -0,0 +1,7 @@ +export interface SWOProcessor { + port: number; + format: string; + + processMessage(buffer: Buffer); + dispose(); +} \ No newline at end of file diff --git a/src/frontend/swo/decoders/console.ts b/src/frontend/swo/decoders/console.ts new file mode 100644 index 00000000..4efea36f --- /dev/null +++ b/src/frontend/swo/decoders/console.ts @@ -0,0 +1,57 @@ +import * as vscode from "vscode"; + +import { SWOProcessor } from './common'; +import { parseUnsigned } from './utils'; +import { SWOConsolePortConfig } from "../common"; + +export class SWOConsoleProcessor implements SWOProcessor { + positionCount: number; + output: vscode.OutputChannel; + position: number = 0; + timeout: any = null; + format: string = 'console'; + port: number; + + constructor(config: SWOConsolePortConfig) { + this.port = config.number; + this.output = vscode.window.createOutputChannel(`SWO: ${config.label || ''} [port: ${this.port}, type: console]`); + } + + processMessage(buffer: Buffer) { + if(this.timeout) { clearTimeout(this.timeout); this.timeout = null; } + + var data = parseUnsigned(buffer); + + let letter = String.fromCharCode(data); + if(letter == '\n') { + this.output.append('\n'); + this.position = 0; + return; + } + + if(this.position == 0) { + let date = new Date(); + let header = `[${date.toISOString()}] `; + this.output.append(header); + } + + this.output.append(letter); + this.position += 1; + + if(this.position >= 80) { + this.output.append('\n'); + this.position = 0; + } + else { + this.timeout = setTimeout(() => { + this.output.append('\n'); + this.position = 0; + this.timeout = null; + }, 5000); + } + } + + dispose() { + this.output.dispose(); + } +} \ No newline at end of file diff --git a/src/frontend/swo/decoders/graph.ts b/src/frontend/swo/decoders/graph.ts new file mode 100644 index 00000000..d19a0ec0 --- /dev/null +++ b/src/frontend/swo/decoders/graph.ts @@ -0,0 +1,39 @@ +import * as vscode from "vscode"; +import { SWOProcessor } from './common'; +import { decoders as DECODER_MAP } from './utils'; +import { EventEmitter } from 'events'; +import { SWOGraphPortConfig, WebsocketDataMessage } from '../common'; + +function parseEncoded(buffer: Buffer, encoding: string) { + return DECODER_MAP[encoding] ? DECODER_MAP[encoding](buffer) : DECODER_MAP.unsigned(buffer); +} + +export class SWOGraphProcessor extends EventEmitter implements SWOProcessor { + format: string = 'graph'; + port: number; + scale: number; + encoding: string; + graphId: string; + + constructor(config: SWOGraphPortConfig) { + super(); + // core.socketServer.registerProcessor(this); + this.port = config.number; + this.encoding = config.encoding || 'unsigned'; + this.scale = config.scale || 1; + this.graphId = config.graphId; + } + + processMessage(buffer: Buffer) { + let raw = buffer.toString('hex'); + let decodedValue = parseEncoded(buffer, this.encoding); + let scaledValue = decodedValue * this.scale; + + let message: WebsocketDataMessage = { type: 'data', timestamp: new Date().getTime(), data: scaledValue, id: this.graphId }; + this.emit('message', message); + } + + dispose() { + + } +} \ No newline at end of file diff --git a/src/frontend/swo/decoders/utils.ts b/src/frontend/swo/decoders/utils.ts new file mode 100644 index 00000000..07a9d14b --- /dev/null +++ b/src/frontend/swo/decoders/utils.ts @@ -0,0 +1,68 @@ +import { Parser } from 'binary-parser'; + +let SignedParser = new Parser().endianess('little').int32('value'); +let UnsignedParser = new Parser().endianess('little').uint32('value'); +let FloatParser = new Parser().endianess('little').floatle('value'); + +export function parseFloat(buffer: Buffer) { + if(buffer.length < 4) { + let tmp = new Buffer(4); + buffer.copy(tmp); + buffer = tmp; + } + + let result = FloatParser.parse(buffer); + return result.value; +} + +export function parseSigned(buffer: Buffer) { + if(buffer.length < 4) { + let tmp = new Buffer(4); + buffer.copy(tmp); + buffer = tmp; + } + + let result = SignedParser.parse(buffer); + return result.value; +} + +export function parseUnsigned(buffer: Buffer) { + if(buffer.length < 4) { + let tmp = new Buffer(4); + buffer.copy(tmp); + buffer = tmp; + } + + let result = UnsignedParser.parse(buffer); + return result.value; +} + +export function parseQ(buffer: Buffer, mask: number, shift: number) { + let value = parseSigned(buffer); + + var fractional = value & mask; + var integer = value >> shift; + + return integer + (fractional / mask); +} + +export function parseUQ(buffer: Buffer, mask: number, shift: number) { + let value = parseUnsigned(buffer); + + var fractional = value & mask; + var integer = value >>> shift; + + return integer + (fractional / mask); +} + +export const decoders = { + signed: parseSigned, + float: parseFloat, + Q8_24: (buffer) => parseQ(buffer, 0xFFFFFF, 24), + Q16_16: (buffer) => parseQ(buffer, 0xFFFF, 16), + Q24_8: (buffer) => parseQ(buffer, 0xFF, 8), + UQ8_24: (buffer) => parseUQ(buffer, 0xFFFFFF, 24), + UQ16_16: (buffer) => parseUQ(buffer, 0xFFFF, 16), + UQ24_8: (buffer) => parseUQ(buffer, 0xFF, 8), + unsigned: parseUnsigned +}; \ No newline at end of file diff --git a/src/frontend/swo/sources/common.ts b/src/frontend/swo/sources/common.ts new file mode 100644 index 00000000..d8ed6257 --- /dev/null +++ b/src/frontend/swo/sources/common.ts @@ -0,0 +1,6 @@ +import { EventEmitter } from 'events'; + +export interface SWOSource extends EventEmitter { + connected: boolean; + dispose(); +} \ No newline at end of file diff --git a/src/frontend/swo/sources/jlink.ts b/src/frontend/swo/sources/jlink.ts new file mode 100644 index 00000000..4b80b41c --- /dev/null +++ b/src/frontend/swo/sources/jlink.ts @@ -0,0 +1,19 @@ +import { SWOSource } from './common'; +import { EventEmitter } from 'events'; +import * as net from 'net'; + +export class JLinkSWOSource extends EventEmitter implements SWOSource { + client: net.Socket = null; + connected: boolean = false; + + constructor(private SWOPort: number) { + super(); + this.client = net.createConnection({ port: this.SWOPort, host: 'localhost' }, () => { this.connected = true; this.emit('connected'); }); + this.client.on('data', (buffer) => { this.emit('data', buffer); }); + this.client.on('end', () => { this.emit('disconnected'); }); + } + + dispose() { + this.client.destroy(); + } +} \ No newline at end of file diff --git a/src/frontend/swo/sources/openocd.ts b/src/frontend/swo/sources/openocd.ts new file mode 100644 index 00000000..645a1403 --- /dev/null +++ b/src/frontend/swo/sources/openocd.ts @@ -0,0 +1,56 @@ +import * as fs from 'fs'; +import { EventEmitter } from 'events'; +import { SWOSource } from './common'; + +export class OpenOCDSWOSource extends EventEmitter implements SWOSource { + stream: fs.ReadStream; + connected: boolean = false; + + constructor(private SWOPath: string) { + super(); + this.stream = fs.createReadStream(this.SWOPath, { highWaterMark: 128, encoding: null, autoClose: false }) + this.stream.on('data', (buffer) => { this.emit('data', buffer); }); + this.stream.on('close', (buffer) => { this.emit('disconnected'); }); + this.connected = true; + } + + dispose() { + this.stream.close(); + } +} + +export class OpenOCDFileSWOSource extends EventEmitter implements SWOSource { + connected: boolean = false; + fd: number = null; + interval: any = null; + + constructor(private SWOPath: string) { + super(); + fs.open(SWOPath, 'r', (err, fd) => { + if(err) { + console.log('Error Opening File') + } + else { + this.fd = fd; + this.interval = setInterval(this.read.bind(this), 2); + this.connected = true; + this.emit('connected'); + } + }) + } + + read() { + let buf: Buffer = new Buffer(64); + fs.read(this.fd, buf, 0, 64, null, (err, bytesRead, buffer) => { + if(bytesRead > 0) { + this.emit('data', buffer.slice(0, bytesRead)); + } + }); + } + + dispose() { + this.emit('disconnected'); + clearInterval(this.interval); + fs.closeSync(this.fd); + } +} \ No newline at end of file diff --git a/src/frontend/swo/websocket_server.ts b/src/frontend/swo/websocket_server.ts new file mode 100644 index 00000000..2b692eb8 --- /dev/null +++ b/src/frontend/swo/websocket_server.ts @@ -0,0 +1,43 @@ +var WebSocket = require('ws'); +import { SWOGraphProcessor } from './decoders/graph'; +import { WebsocketMessage, GraphConfiguration } from './common'; +import { SWOAdvancedProcessor } from './decoders/advanced'; + +export class SWOSocketServer { + processors: (SWOGraphProcessor|SWOAdvancedProcessor)[]; + socket: any; + currentStatus: string = 'stopped'; + + constructor(serverPort: number, public graphs: GraphConfiguration[]) { + this.processors = []; + this.socket = new WebSocket.Server({ port: serverPort }); + this.socket.on('connection', this.connected.bind(this)); + } + + connected(client) { + client.on('message', (message) => this.message(client, message)); + let activePorts = this.processors.map(p => { return { 'port': p.port }; }); + client.send(JSON.stringify({ type: 'configure', 'activePorts': activePorts, 'graphs': this.graphs, 'status': this.currentStatus })); + } + + message(client, message) { + } + + registerProcessor(processor: SWOGraphProcessor | SWOAdvancedProcessor) { + processor.on('message', this.broadcastMessage.bind(this)); + this.processors.push(processor); + } + + broadcastMessage(message: WebsocketMessage) { + let encoded = JSON.stringify(message); + this.socket.clients.forEach(client => { + if(client.readyState == WebSocket.OPEN) { + client.send(encoded); + } + }); + } + + dispose() { + this.socket.close(); + } +} \ No newline at end of file diff --git a/src/frontend/utils.ts b/src/frontend/utils.ts index b2df1078..50518a50 100644 --- a/src/frontend/utils.ts +++ b/src/frontend/utils.ts @@ -1,7 +1,7 @@ -export function hexFormat(value: number, padding: number = 8) : string { +export function hexFormat(value: number, padding: number = 8, includePrefix: boolean = true) : string { var base = value.toString(16); while(base.length < padding) { base = '0' + base; } - return '0x' + base; + return includePrefix ? '0x' + base : base; } export function binaryFormat(value: number, padding: number = 0) : string { diff --git a/src/gdb.ts b/src/gdb.ts index d2b2de60..6310b2f2 100644 --- a/src/gdb.ts +++ b/src/gdb.ts @@ -3,6 +3,7 @@ import { DebugSession, InitializedEvent, TerminatedEvent, StoppedEvent, OutputEv import { DebugProtocol } from 'vscode-debugprotocol'; import { MI2 } from "./backend/mi2/mi2"; import { hexFormat } from './frontend/utils'; +import { TelemetryEvent } from './common'; export class GDBDebugSession extends MI2DebugSession { protected initializeRequest(response: DebugProtocol.InitializeResponse, args: DebugProtocol.InitializeRequestArguments): void { @@ -65,7 +66,8 @@ export class GDBDebugSession extends MI2DebugSession { }, error => { response.body = { 'error': error }; this.sendErrorResponse(response, 114, `Unable to read memory: ${error.toString()}`); - }) + this.sendEvent(new TelemetryEvent('error-reading-memory', { address: startAddress.toString(), length: length.toString() }, {})); + }); } protected writeMemoryRequest(response: DebugProtocol.Response, startAddress: number, data: string) { @@ -75,12 +77,13 @@ export class GDBDebugSession extends MI2DebugSession { }, error => { response.body = { 'error': error }; this.sendErrorResponse(response, 114, `Unable to write memory: ${error.toString()}`); - }) + this.sendEvent(new TelemetryEvent('error-writing-memory', { address: startAddress.toString(), length: data.length.toString() }, {})); + }); } protected readRegistersRequest(response: DebugProtocol.Response) { this.miDebugger.sendCommand('data-list-register-values x').then(node => { - if(node.resultRecords.resultClass == 'done') { + if (node.resultRecords.resultClass == 'done') { let rv = node.resultRecords.results[0][1]; response.body = rv.map(n => { let val = {}; @@ -99,15 +102,16 @@ export class GDBDebugSession extends MI2DebugSession { }, error => { response.body = { 'error': error }; this.sendErrorResponse(response, 115, `Unable to read registers: ${error.toString()}`); - }); + this.sendEvent(new TelemetryEvent('error-reading-registers', {}, {})); + }); } protected readRegisterListRequest(response: DebugProtocol.Response) { this.miDebugger.sendCommand('data-list-register-names').then(node => { - if(node.resultRecords.resultClass == 'done') { + if (node.resultRecords.resultClass == 'done') { let registerNames; node.resultRecords.results.forEach(rr => { - if(rr[0] == 'register-names') { + if (rr[0] == 'register-names') { registerNames = rr[1]; } }); @@ -120,6 +124,7 @@ export class GDBDebugSession extends MI2DebugSession { }, error => { response.body = { 'error': error }; this.sendErrorResponse(response, 116, `Unable to read register list: ${error.toString()}`); + this.sendEvent(new TelemetryEvent('error-reading-register-list', {}, {})); }); } } diff --git a/src/jlink.ts b/src/jlink.ts index d33c1194..4dd81410 100644 --- a/src/jlink.ts +++ b/src/jlink.ts @@ -6,6 +6,7 @@ import { MI2 } from "./backend/mi2/mi2"; import { AdapterOutputEvent, SWOConfigureEvent } from './common'; import * as portastic from 'portastic'; import * as os from 'os'; +import { TelemetryEvent } from './common'; export interface ConfigurationArguments extends DebugProtocol.LaunchRequestArguments { gdbpath: string; @@ -45,6 +46,12 @@ class JLinkGDBDebugSession extends GDBDebugSession { } private processLaunchAttachRequest(response: DebugProtocol.LaunchResponse, args: ConfigurationArguments, attach: boolean) { + this.quit = false; + this.attached = false; + this.started = false; + this.crashed = false; + this.debugReady = false; + portastic.find({ min: 50000, max: 52000, retrieve: 3 }).then(ports => { this.gdbPort = ports[0]; this.swoPort = ports[1]; @@ -60,16 +67,28 @@ class JLinkGDBDebugSession extends GDBDebugSession { this.jlink = new JLink(args.jlinkpath || defaultExecutable, args.device, this.gdbPort, this.swoPort, this.consolePort, args.ipAddress, args.serialNumber, args.rtos); this.jlink.on('jlink-output', this.handleJLinkOutput.bind(this)); this.jlink.on('jlink-stderr', this.handleJLinkErrorOutput.bind(this)); - this.jlink.on("launcherror", this.launchError.bind(this)); - this.jlink.on("quit", this.quitEvent.bind(this)); - this.quit = false; - this.attached = false; - this.started = false; - this.crashed = false; - this.debugReady = false; - - this.jlink.init().then(_ => { + this.jlink.on("launcherror", (err) => { + this.sendErrorResponse(response, 103, `Failed to launch J-Link GDB Server: ${err.toString()}`); + }); + this.jlink.on("quit", () => { + if (this.started) { + this.quitEvent.bind(this) + } + else { + this.sendErrorResponse(response, 103, `J-Link GDB Server Quit Unexpectedly. See Adapter Output for more details.`); + this.sendErrorResponse(response, 103, `J-Link GDB Server Quit Unexpectedly.`); + } + }); + + let timeout = null; + + this.jlink.on('jlink-init', () => { + if(timeout) { + clearTimeout(timeout); + timeout = null; + } + this.miDebugger = new MI2(args.gdbpath || defaultGDBExecutable, ["-q", "--interpreter=mi2"], args.debugger_args); this.initDebugger(); @@ -87,23 +106,32 @@ class JLinkGDBDebugSession extends GDBDebugSession { this.miDebugger.emit("ui-break-done"); }, 50); - this.sendResponse(response); this.miDebugger.start().then(() => { this.started = true; + this.sendResponse(response); + if (this.crashed) this.handlePause(undefined); }, err => { - this.sendErrorResponse(response, 100, `Failed to Start MI Debugger: ${err.toString()}`); + this.sendErrorResponse(response, 100, `Failed to launch GDB: ${err.toString()}`); + this.sendEvent(new TelemetryEvent('error-launching-gdb', { error: err.toString() }, {})); }); }, err => { - this.sendErrorResponse(response, 103, `Failed to load MI Debugger: ${err.toString()}`); - }); - }, err => { - this.sendErrorResponse(response, 103, `Failed to launch JLink Server: ${err.toString()}`); + this.sendErrorResponse(response, 103, `Failed to launch GDB: ${err.toString()}`); + this.sendEvent(new TelemetryEvent('error-launching-gdb', { error: err.toString() }, {})); + }); }); - }, error => { - console.log('Unable to launch'); - this.sendErrorResponse(response, 103, `Failed to launch JLink Server: ${error.toString()}`); + + this.jlink.init().then(_ => {}, _ => {}); + + timeout = setTimeout(() => { + this.jlink.exit(); + this.sendEvent(new TelemetryEvent('error-launching-jlink', { error: `Failed to launch JLink Server: Timeout.` }, {})); + this.sendErrorResponse(response, 103, `Failed to launch JLink Server: Timeout.`); + }, 10000); + }, err => { + this.sendEvent(new TelemetryEvent('error-launching-jlink', { error: err.toString() }, {})); + this.sendErrorResponse(response, 103, `Failed to launch JLink Server: ${err.toString()}`); }); } @@ -153,7 +181,7 @@ class JLinkGDBDebugSession extends GDBDebugSession { 'exec-interrupt', 'interpreter-exec console "monitor halt"', 'interpreter-exec console "monitor reset"', - 'exec-continue' + 'exec-step-instruction' ]; } diff --git a/src/openocd.ts b/src/openocd.ts index 71f8c979..b6890001 100644 --- a/src/openocd.ts +++ b/src/openocd.ts @@ -9,6 +9,7 @@ import * as os from 'os'; import * as fs from 'fs'; import { AdapterOutputEvent, SWOConfigureEvent } from './common'; import { clearTimeout } from 'timers'; +import { TelemetryEvent } from './common'; interface ConfigurationArguments extends DebugProtocol.LaunchRequestArguments { debugger_args: string[]; @@ -48,6 +49,12 @@ class OpenOCDGDBDebugSession extends GDBDebugSession { } private processLaunchAttachRequest(response: DebugProtocol.AttachResponse, args: ConfigurationArguments, attach: boolean) { + this.quit = false; + this.attached = false; + this.started = false; + this.crashed = false; + this.debugReady = false; + portastic.find({ min: 50000, max: 52000, retrieve: 1 }).then(ports => { this.gdbPort = ports[0]; @@ -76,14 +83,18 @@ class OpenOCDGDBDebugSession extends GDBDebugSession { }); this.openocd.on('openocd-output', this.handleAdapterOutput.bind(this)); this.openocd.on('openocd-stderr', this.handleAdapterErrorOutput.bind(this)); - this.openocd.on("launcherror", this.launchError.bind(this)); - this.openocd.on("quit", this.quitEvent.bind(this)); - - this.quit = false; - this.attached = false; - this.started = false; - this.crashed = false; - this.debugReady = false; + this.openocd.on("launcherror", (error) => { + this.sendErrorResponse(response, 103, `Failed to launch OpenOCD Server: ${error.toString()}`); + }); + this.openocd.on("quit", () => { + if (this.started) { + this.quitEvent.bind(this) + } + else { + this.sendErrorResponse(response, 103, `OpenOCD GDB Server Quit Unexpectedly. See Adapter Output for more details.`); + this.sendErrorResponse(response, 103, `OpenOCD GDB Server Quit Unexpectedly.`); + } + }); let timeout = null; @@ -109,16 +120,18 @@ class OpenOCDGDBDebugSession extends GDBDebugSession { this.miDebugger.emit("ui-break-done"); }, 50); - this.sendResponse(response); this.miDebugger.start().then(() => { this.started = true; + this.sendResponse(response); if (this.crashed) this.handlePause(undefined); }, err => { - this.sendErrorResponse(response, 100, `Failed to Start MI Debugger: ${err.toString()}`); + this.sendErrorResponse(response, 100, `Failed to launch GDB: ${err.toString()}`); + this.sendEvent(new TelemetryEvent('error-launching-gdb', { error: err.toString() }, {})); }); }, err => { - this.sendErrorResponse(response, 103, `Failed to load MI Debugger: ${err.toString()}`); + this.sendErrorResponse(response, 103, `Failed to launch GDB: ${err.toString()}`); + this.sendEvent(new TelemetryEvent('error-launching-gdb', { error: err.toString() }, {})); }); }) @@ -128,16 +141,18 @@ class OpenOCDGDBDebugSession extends GDBDebugSession { } }, err => { this.sendErrorResponse(response, 103, `Failed to launch OpenOCD Server: ${err.toString()}`); + this.sendEvent(new TelemetryEvent('error-launching-openocd', { error: err.toString() }, {})); }); timeout = setTimeout(() => { this.openocd.exit(); this.sendErrorResponse(response, 103, `Failed to launch OpenOCD Server. Timeout.`); + this.sendEvent(new TelemetryEvent('error-launching-openocd', { error: `Failed to launch OpenOCD Server. Timeout.` }, {})); }, 10000); // Timeout Launching - }, error => { - console.log('Unable to launch'); - this.sendErrorResponse(response, 103, `Failed to launch OpenOCD Server: ${error.toString()}`); + }, err => { + this.sendErrorResponse(response, 103, `Failed to launch OpenOCD Server: ${err.toString()}`); + this.sendEvent(new TelemetryEvent('error-launching-openocd', { error: err.toString() }, {})); }); } @@ -167,7 +182,7 @@ class OpenOCDGDBDebugSession extends GDBDebugSession { return [ 'exec-interrupt', 'interpreter-exec console "monitor reset halt"', - 'exec-continue' + 'exec-step-instruction' ]; } diff --git a/src/pyocd.ts b/src/pyocd.ts new file mode 100644 index 00000000..d69bd3dd --- /dev/null +++ b/src/pyocd.ts @@ -0,0 +1,226 @@ +import { GDBDebugSession } from './gdb'; +import { DebugSession, InitializedEvent, TerminatedEvent, StoppedEvent, OutputEvent, Thread, StackFrame, Scope, Source, Handles, Event } from 'vscode-debugadapter'; +import { DebugProtocol } from 'vscode-debugprotocol'; +import { PyOCD } from './backend/pyocd'; +import { MI2 } from "./backend/mi2/mi2"; +import * as portastic from 'portastic'; +import * as tmp from 'tmp'; +import * as os from 'os'; +import { AdapterOutputEvent, SWOConfigureEvent } from './common'; +import { clearTimeout } from 'timers'; +import { TelemetryEvent } from './common'; + +interface ConfigurationArguments extends DebugProtocol.LaunchRequestArguments { + debugger_args: string[]; + executable: string; + svdFile: string; + configFiles: string[]; + gdbpath: string; + pyocdPath: string; + cwd: string; + showDevDebugOutput: boolean; + boardId: string; + targetId: string; +} + +class PyOCDGDBDebugSession extends GDBDebugSession { + protected pyocd : PyOCD; + private args: ConfigurationArguments; + private gdbPort: number; + private swoPath: string; + private device: string; + + protected launchRequest(response: DebugProtocol.LaunchResponse, args: ConfigurationArguments): void { + this.args = args; + + this.processLaunchAttachRequest(response, args, false); + } + + protected attachRequest(response: DebugProtocol.AttachResponse, args: ConfigurationArguments): void { + this.args = args; + + this.processLaunchAttachRequest(response, args, true); + } + + private processLaunchAttachRequest(response: DebugProtocol.AttachResponse, args: ConfigurationArguments, attach: boolean) { + this.quit = false; + this.attached = false; + this.started = false; + this.crashed = false; + this.debugReady = false; + + portastic.find({ min: 50000, max: 52000, retrieve: 1 }).then(ports => { + this.gdbPort = ports[0]; + + let defaultExecutable = 'pyocd-gdbserver'; + let defaultGDBExecutable = 'arm-none-eabi-gdb'; + if(os.platform() === 'win32') { + defaultExecutable = 'pyocd-gdbserver'; + defaultGDBExecutable = 'arm-none-eabi-gdb.exe'; + } + + this.pyocd = new PyOCD(args.pyocdPath || defaultExecutable, this.gdbPort, args.boardId, args.targetId); + + this.pyocd.on('pyocd-output', this.handleAdapterOutput.bind(this)); + this.pyocd.on('pyocd-stderr', this.handleAdapterErrorOutput.bind(this)); + this.pyocd.on("launcherror", (error) => { + this.sendErrorResponse(response, 103, `Failed to launch PyOCD GDB Server: ${error.toString()}`); + }); + this.pyocd.on("quit", () => { + if (this.started) { + this.quitEvent.bind(this) + } + else { + this.sendErrorResponse(response, 103, `PyOCD GDB Server Quit Unexpectedly. See Adapter Output for more details.`); + this.sendErrorResponse(response, 103, `PyOCD GDB Server Quit Unexpectedly.`); + } + }); + + let timeout = null; + + this.pyocd.on('pyocd-init', (cpu: string) => { + if(timeout) { + clearTimeout(timeout); + timeout = null; + } + + this.miDebugger = new MI2(args.gdbpath || defaultGDBExecutable, ["-q", "--interpreter=mi2"], args.debugger_args); + this.initDebugger(); + + this.miDebugger.printCalls = !!args.showDevDebugOutput; + this.miDebugger.debugOutput = !!args.showDevDebugOutput + + let commands = attach ? this.attachCommands(this.gdbPort, args) : this.launchCommands(this.gdbPort, args); + + this.miDebugger.connect(args.cwd, args.executable, commands).then(() => { + setTimeout(() => { + this.miDebugger.emit("ui-break-done"); + }, 50); + + this.miDebugger.start().then(() => { + this.started = true; + this.sendResponse(response); + if (this.crashed) + this.handlePause(undefined); + }, err => { + this.sendErrorResponse(response, 100, `Failed to launch GDB: ${err.toString()}`); + this.sendEvent(new TelemetryEvent('error-launching-gdb', { error: err.toString() }, {})); + }); + }, err => { + this.sendErrorResponse(response, 103, `Failed to launch GDB: ${err.toString()}`); + this.sendEvent(new TelemetryEvent('error-launching-gdb', { error: err.toString() }, {})); + }); + }) + + this.pyocd.init().then(_ => {}, err => { + this.sendErrorResponse(response, 103, `Failed to launch PyOCD GDB Server: ${err.toString()}`); + this.sendEvent(new TelemetryEvent('error-launching-pyocd', { error: err.toString() }, {})); + }); + + timeout = setTimeout(() => { + this.pyocd.exit(); + this.sendErrorResponse(response, 103, `Failed to launch PyOCD GDB Server. Timeout.`); + this.sendEvent(new TelemetryEvent('error-launching-pyocd', { error: `Failed to launch PyOCD GDB Server. Timeout.` }, {})); + }, 10000); // Timeout Launching + + }, err => { + this.sendErrorResponse(response, 103, `Failed to launch PyOCD GDB Server: ${err.toString()}`); + this.sendEvent(new TelemetryEvent('error-launching-pyocd', { error: err.toString() }, {})); + }); + } + + protected launchCommands(gdbport: number, args: ConfigurationArguments): string[] { + let commands = [ + `target-select extended-remote localhost:${gdbport}`, + 'interpreter-exec console "monitor reset halt"', + 'target-download', + 'interpreter-exec console "monitor reset halt"', + 'enable-pretty-printing' + ]; + + return commands; + } + + protected attachCommands(gdbport: number, args: ConfigurationArguments): string[] { + let commands = [ + `target-select extended-remote localhost:${gdbport}`, + 'interpreter-exec console "monitor halt"', + 'enable-pretty-printing' + ]; + + return commands; + } + + protected restartCommands(): string[] { + return [ + 'exec-interrupt', + 'interpreter-exec console "monitor reset"', + 'exec-step-instruction' + ]; + } + + protected disconnectRequest(response: DebugProtocol.DisconnectResponse, args: DebugProtocol.DisconnectArguments): void { + if(this.miDebugger) { + if (this.attached) + this.miDebugger.detach(); + else + this.miDebugger.stop(); + } + if(this.commandServer) { + this.commandServer.close(); + this.commandServer = undefined; + } + + try { this.pyocd.stop(); } + catch(e) {} + + this.sendResponse(response); + } + + protected restartRequest(response: DebugProtocol.RestartResponse, args: DebugProtocol.RestartArguments): void { + this.miDebugger.restart(this.restartCommands()).then(done => { + this.sendResponse(response); + }, msg => { + this.sendErrorResponse(response, 6, `Could not restart: ${msg}`); + }) + } + + protected handleAdapterOutput(output) { + this.sendEvent(new AdapterOutputEvent(output, 'out')); + } + + protected handleAdapterErrorOutput(output) { + this.sendEvent(new AdapterOutputEvent(output, 'err')); + } + + protected customRequest(command: string, response: DebugProtocol.Response, args: any): void { + switch(command) { + case 'get-arguments': + response.body = { + type: 'pyocd', + GDBPort: this.gdbPort, + SWOPath: this.swoPath, + configFiles: this.args.configFiles, + SVDFile: this.args.svdFile, + SWOConfig: { enabled: false }, + GraphConfig: [], + device: this.device + }; + this.sendResponse(response); + break; + default: + super.customRequest(command, response, args); + break; + } + } + + private calculatePortMask(configuration: any[]) { + let mask: number = 0; + configuration.forEach(c => { + mask = (mask | (1 << c.number)) >>> 0; + }); + return mask; + } +} + +DebugSession.run(PyOCDGDBDebugSession); \ No newline at end of file diff --git a/src/reporting.ts b/src/reporting.ts new file mode 100644 index 00000000..7a869e34 --- /dev/null +++ b/src/reporting.ts @@ -0,0 +1,27 @@ +import * as vscode from 'vscode'; +import TelemetryReporter from 'vscode-extension-telemetry'; +let reporter: TelemetryReporter; + +const extension = vscode.extensions.getExtension('marus25.cortex-debug'); + +const extensionId = extension.id; +const extensionVersion = extension.packageJSON.version; +const key = '1b93f859-5da5-4127-aa82-edcf77f7ab3e'; + +function activate(context: vscode.ExtensionContext) { + reporter = new TelemetryReporter(extensionId, extensionVersion, key) +} + +function deactivate() { + if (reporter) { reporter.dispose(); } +} + +function sendEvent(name: string, properties: { [key: string]: string; }, measures: { [key: string]: number; }) { + reporter.sendTelemetryEvent(name, properties, measures); +} + +export default { + activate: activate, + deactivate: deactivate, + sendEvent: sendEvent +}; \ No newline at end of file diff --git a/updatePackage.py b/updatePackage.py index 3cfe127e..1857179a 100644 --- a/updatePackage.py +++ b/updatePackage.py @@ -41,6 +41,11 @@ def make_config(dtype, request): properties.update(properties_2) properties.update(properties_3) properties.update(properties_4) + + if 'removeProperties' in config_base[dtype]: + for prop in config_base[dtype]['removeProperties']: + if prop in properties: + del properties[prop] return { 'required': required, 'properties': properties }